aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlfredo Cardigliano <alfredo.cardigliano@gmail.com>2019-07-16 12:31:41 +0200
committerAlfredo Cardigliano <alfredo.cardigliano@gmail.com>2019-07-16 12:31:41 +0200
commit2ce4adf09d80cbe26febb05bf995334fa966bb52 (patch)
tree4e4dcf24e00a8129df1becdf843cdf76ab21b74b /src
parent1777841ec1300dd08310b73958eca7b027743f7f (diff)
Added ndpi_serialization_string_uint32
Diffstat (limited to 'src')
-rw-r--r--src/include/ndpi_api.h6
-rw-r--r--src/include/ndpi_typedefs.h1
-rw-r--r--src/lib/ndpi_utils.c48
3 files changed, 53 insertions, 2 deletions
diff --git a/src/include/ndpi_api.h b/src/include/ndpi_api.h
index c6666cda5..54d8837e4 100644
--- a/src/include/ndpi_api.h
+++ b/src/include/ndpi_api.h
@@ -825,8 +825,8 @@ extern "C" {
u_int32_t key, char *value);
int ndpi_serialize_string_string(ndpi_serializer *serializer,
char *key, char *value);
- int ndpi_serialize_string_string(ndpi_serializer *serializer,
- char *key, char *value);
+ int ndpi_serialize_string_uint32(ndpi_serializer *serializer,
+ char *key, u_int32_t value);
/* **** */
int ndpi_init_deserializer(ndpi_deserializer *deserializer,
@@ -843,6 +843,8 @@ extern "C" {
u_int32_t *key, ndpi_string *value);
int ndpi_deserialize_string_string(ndpi_deserializer *deserializer,
ndpi_string *key, ndpi_string *value);
+ int ndpi_deserialize_string_uint32(ndpi_deserializer *deserializer,
+ ndpi_string *key, u_int32_t *value);
#ifdef __cplusplus
}
diff --git a/src/include/ndpi_typedefs.h b/src/include/ndpi_typedefs.h
index 820973874..72547bc4a 100644
--- a/src/include/ndpi_typedefs.h
+++ b/src/include/ndpi_typedefs.h
@@ -1270,6 +1270,7 @@ typedef enum {
ndpi_serialization_uint32_uint32,
ndpi_serialization_uint32_string,
ndpi_serialization_string_string,
+ ndpi_serialization_string_uint32,
} ndpi_serialization_element_type;
typedef struct {
diff --git a/src/lib/ndpi_utils.c b/src/lib/ndpi_utils.c
index 9dcb5fda3..641c1091f 100644
--- a/src/lib/ndpi_utils.c
+++ b/src/lib/ndpi_utils.c
@@ -881,6 +881,33 @@ int ndpi_serialize_string_string(ndpi_serializer *serializer,
}
/* ********************************** */
+
+int ndpi_serialize_string_uint32(ndpi_serializer *serializer,
+ char *key, u_int32_t value) {
+ u_int32_t klen = strlen(key);
+ u_int32_t needed = 1 /* type */ + 2 /* key len */ + klen /* key */ + 4 /* value */;
+ u_int32_t buff_diff = serializer->buffer_size - serializer->size_used;
+
+ if(buff_diff < needed) {
+ ndpi_extend_serializer_buffer(serializer);
+ if(serializer->size_used < 10) return(-1);
+ }
+
+ serializer->buffer[serializer->size_used++] = ndpi_serialization_string_uint32;
+
+ if(serializer->fmt == ndpi_serialization_format_json) {
+ serializer->size_used += snprintf((char*)serializer->buffer, buff_diff, "%s\"%s\":%u",
+ (serializer->size_used > 2) ? "," : "",
+ key, value);
+ } else {
+ ndpi_serialize_single_string(serializer, key, klen);
+ ndpi_serialize_single_uint32(serializer, value);
+ }
+
+ return(0);
+}
+
+/* ********************************** */
/* ********************************** */
int ndpi_init_deserializer_buf(ndpi_deserializer *deserializer,
@@ -972,3 +999,24 @@ int ndpi_deserialize_string_string(ndpi_deserializer *deserializer,
} else
return(-1);
}
+
+/* ********************************** */
+
+int ndpi_deserialize_string_uint32(ndpi_deserializer *deserializer,
+ ndpi_string *key, u_int32_t *value) {
+ if(ndpi_deserialize_get_nextitem_type(deserializer) == ndpi_serialization_string_uint32) {
+ u_int32_t buff_diff = deserializer->buffer_size - deserializer->size_used;
+
+ if(buff_diff < 8) return(-2);
+
+ deserializer->size_used++; /* Skip element type */
+ ndpi_deserialize_single_string(deserializer, key);
+ ndpi_deserialize_single_uint32(deserializer, value);
+
+ return(0);
+ } else
+ return(-1);
+}
+
+/* ********************************** */
+