diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-08-04 16:38:52 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-08-04 16:38:52 +0100 |
commit | c5067f406a3a41fb3cd3d9ad881c0bd55798d423 (patch) | |
tree | b1467a0aa6747c1d5b9bcef7d5ad27e438c140b5 /src/libutil | |
parent | de16089822abd364dbe73b1f7ebd45dd185934b4 (diff) | |
download | rspamd-c5067f406a3a41fb3cd3d9ad881c0bd55798d423.tar.gz rspamd-c5067f406a3a41fb3cd3d9ad881c0bd55798d423.zip |
[Fix] Fix multiple values headers freeing
Diffstat (limited to 'src/libutil')
-rw-r--r-- | src/libutil/http.c | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/src/libutil/http.c b/src/libutil/http.c index 7e5da1b12..c9410690c 100644 --- a/src/libutil/http.c +++ b/src/libutil/http.c @@ -534,14 +534,13 @@ rspamd_http_finish_header (struct rspamd_http_connection *conn, HASH_FIND (hh, priv->msg->headers, priv->header->name->begin, priv->header->name->len, hdr); - if (hdr) { - DL_APPEND (priv->msg->headers, priv->header); - } - else { + if (hdr == NULL) { HASH_ADD_KEYPTR (hh, priv->msg->headers, priv->header->name->begin, priv->header->name->len, priv->header); } + DL_APPEND (hdr, priv->header); + rspamd_http_check_special_header (conn, priv); } @@ -549,7 +548,7 @@ rspamd_http_finish_header (struct rspamd_http_connection *conn, static void rspamd_http_init_header (struct rspamd_http_connection_private *priv) { - priv->header = g_slice_alloc (sizeof (struct rspamd_http_header)); + priv->header = g_slice_alloc0 (sizeof (struct rspamd_http_header)); priv->header->name = g_slice_alloc0 (sizeof (*priv->header->name)); priv->header->value = g_slice_alloc0 (sizeof (*priv->header->value)); priv->header->combined = rspamd_fstring_new (); @@ -2571,15 +2570,18 @@ rspamd_http_connection_set_max_size (struct rspamd_http_connection *conn, void rspamd_http_message_free (struct rspamd_http_message *msg) { - struct rspamd_http_header *hdr, *htmp; + struct rspamd_http_header *hdr, *htmp, *hcur, *hcurtmp; HASH_ITER (hh, msg->headers, hdr, htmp) { HASH_DEL (msg->headers, hdr); - rspamd_fstring_free (hdr->combined); - g_slice_free1 (sizeof (*hdr->name), hdr->name); - g_slice_free1 (sizeof (*hdr->value), hdr->value); - g_slice_free1 (sizeof (struct rspamd_http_header), hdr); + + DL_FOREACH_SAFE (hdr, hcur, hcurtmp) { + rspamd_fstring_free (hcur->combined); + g_slice_free1 (sizeof (*hcur->name), hcur->name); + g_slice_free1 (sizeof (*hcur->value), hcur->value); + g_slice_free1 (sizeof (struct rspamd_http_header), hcur); + } } |