|
@@ -1,10 +1,8 @@
|
|
-#include "ht_var.h"
|
|
|
|
-#include "../../str.h"
|
|
|
|
#include "ht_serialize.h"
|
|
#include "ht_serialize.h"
|
|
-#include "../../basex.h"
|
|
|
|
|
|
|
|
/* snprintf - pretty ugly, but cds/serialize is unusable for the moment */
|
|
/* snprintf - pretty ugly, but cds/serialize is unusable for the moment */
|
|
-int serialize_ht_pair(pv_value_t* val, str* htname, str* s) {
|
|
|
|
|
|
+int serialize_ht_pair(str* key, pv_value_t* val, str* htname, str* s) {
|
|
|
|
+ str encoded_key = {0, 0};
|
|
str encoded_val = {0, 0};
|
|
str encoded_val = {0, 0};
|
|
str encoded_htname = {0, 0};
|
|
str encoded_htname = {0, 0};
|
|
int len;
|
|
int len;
|
|
@@ -17,7 +15,7 @@ int serialize_ht_pair(pv_value_t* val, str* htname, str* s) {
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
if(val->rs.len) {
|
|
if(val->rs.len) {
|
|
- encoded_val.len = base64_enc_len(val->rs.len);
|
|
|
|
|
|
+ encoded_val.len = base16_enc_len(val->rs.len);
|
|
encoded_val.s = pkg_malloc(encoded_val.len);
|
|
encoded_val.s = pkg_malloc(encoded_val.len);
|
|
len = base16_enc((unsigned char*)val->rs.s, val->rs.len, (unsigned char*)encoded_val.s, encoded_val.len);
|
|
len = base16_enc((unsigned char*)val->rs.s, val->rs.len, (unsigned char*)encoded_val.s, encoded_val.len);
|
|
if(len < 0) {
|
|
if(len < 0) {
|
|
@@ -26,7 +24,7 @@ int serialize_ht_pair(pv_value_t* val, str* htname, str* s) {
|
|
}
|
|
}
|
|
encoded_val.len = len;
|
|
encoded_val.len = len;
|
|
}
|
|
}
|
|
- encoded_htname.len = base64_enc_len(htname->len);
|
|
|
|
|
|
+ encoded_htname.len = base16_enc_len(htname->len);
|
|
encoded_htname.s = pkg_malloc(encoded_htname.len);
|
|
encoded_htname.s = pkg_malloc(encoded_htname.len);
|
|
len = base16_enc((unsigned char*)htname->s, htname->len, (unsigned char*)encoded_htname.s, encoded_htname.len);
|
|
len = base16_enc((unsigned char*)htname->s, htname->len, (unsigned char*)encoded_htname.s, encoded_htname.len);
|
|
if(len < 0) {
|
|
if(len < 0) {
|
|
@@ -34,7 +32,17 @@ int serialize_ht_pair(pv_value_t* val, str* htname, str* s) {
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
encoded_htname.len = len;
|
|
encoded_htname.len = len;
|
|
- s->len = snprintf(s->s, s->len, "%d %d %.*s %.*s", val->flags, val->ri, STR_FMT(&encoded_htname), STR_FMT(&encoded_val));
|
|
|
|
|
|
+
|
|
|
|
+ encoded_key.len = base16_enc_len(key->len);
|
|
|
|
+ encoded_key.s = pkg_malloc(encoded_key.len);
|
|
|
|
+ len = base16_enc((unsigned char*)key->s, key->len, (unsigned char*)encoded_key.s, encoded_key.len);
|
|
|
|
+ if(len < 0) {
|
|
|
|
+ LM_ERR("cannot encode key\n");
|
|
|
|
+ goto error;
|
|
|
|
+ }
|
|
|
|
+ encoded_key.len = len;
|
|
|
|
+
|
|
|
|
+ s->len = snprintf(s->s, s->len, "%d %d %.*s %.*s %.*s", val->flags, val->ri, STR_FMT(&encoded_htname), STR_FMT(&encoded_key), STR_FMT(&encoded_val));
|
|
if(s->len < 0) {
|
|
if(s->len < 0) {
|
|
LM_ERR("cannot serialize data - probably an small buffer\n");
|
|
LM_ERR("cannot serialize data - probably an small buffer\n");
|
|
goto error;
|
|
goto error;
|
|
@@ -57,32 +65,46 @@ error:
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
-int deserialize_ht_pair(pv_value_t* val, str* htname, str* src) {
|
|
|
|
|
|
+int deserialize_ht_pair(str* key, pv_value_t* val, str* htname, str* src) {
|
|
str encoded_htname = {0, 0};
|
|
str encoded_htname = {0, 0};
|
|
str encoded_val = {0, 0};
|
|
str encoded_val = {0, 0};
|
|
|
|
+ str encoded_key = {0, 0};
|
|
encoded_htname.s = pkg_malloc(src->len);
|
|
encoded_htname.s = pkg_malloc(src->len);
|
|
memset(encoded_htname.s, 0, src->len);
|
|
memset(encoded_htname.s, 0, src->len);
|
|
encoded_val.s = pkg_malloc(src->len);
|
|
encoded_val.s = pkg_malloc(src->len);
|
|
memset(encoded_val.s, 0, src->len);
|
|
memset(encoded_val.s, 0, src->len);
|
|
|
|
+ encoded_key.s = pkg_malloc(src->len);
|
|
|
|
+ memset(encoded_key.s, 0, src->len);
|
|
|
|
|
|
- sscanf(src->s, "%d %d %s %s", &val->flags, &val->ri, encoded_htname.s, encoded_val.s);
|
|
|
|
|
|
+ sscanf(src->s, "%d %d %s %s %s", &val->flags, &val->ri, encoded_htname.s, encoded_key.s, encoded_val.s);
|
|
encoded_htname.len = strlen(encoded_htname.s);
|
|
encoded_htname.len = strlen(encoded_htname.s);
|
|
|
|
+ encoded_key.len = strlen(encoded_key.s);
|
|
encoded_val.len = strlen(encoded_val.s);
|
|
encoded_val.len = strlen(encoded_val.s);
|
|
|
|
|
|
- if(base64_dec((unsigned char*)encoded_htname.s, encoded_htname.len, (unsigned char*)htname->s, htname->len) < 0) {
|
|
|
|
|
|
+ htname->len = base16_dec((unsigned char*)encoded_htname.s, encoded_htname.len, (unsigned char*)htname->s, htname->len);
|
|
|
|
+ if(htname->len < 0) {
|
|
LM_ERR("cannot decode htname\n");
|
|
LM_ERR("cannot decode htname\n");
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
- if(base64_dec((unsigned char*)encoded_val.s, encoded_val.len, (unsigned char*)val->rs.s, val->rs.len) < 0) {
|
|
|
|
|
|
+ val->rs.len = base16_dec((unsigned char*)encoded_val.s, encoded_val.len, (unsigned char*)val->rs.s, val->rs.len);
|
|
|
|
+ if(val->rs.len < 0) {
|
|
LM_ERR("cannot decode val\n");
|
|
LM_ERR("cannot decode val\n");
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ key->len = base16_dec((unsigned char*)encoded_key.s, encoded_key.len, (unsigned char*)key->s, key->len);
|
|
|
|
+ if(key->len < 0) {
|
|
|
|
+ LM_ERR("cannot decode key\n");
|
|
|
|
+ goto error;
|
|
|
|
+ }
|
|
|
|
+
|
|
pkg_free(encoded_htname.s);
|
|
pkg_free(encoded_htname.s);
|
|
|
|
+ pkg_free(encoded_key.s);
|
|
pkg_free(encoded_val.s);
|
|
pkg_free(encoded_val.s);
|
|
return 0;
|
|
return 0;
|
|
error:
|
|
error:
|
|
pkg_free(encoded_htname.s);
|
|
pkg_free(encoded_htname.s);
|
|
|
|
+ pkg_free(encoded_key.s);
|
|
pkg_free(encoded_val.s);
|
|
pkg_free(encoded_val.s);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|