diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-05-17 22:23:35 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-05-17 22:23:35 +0100 |
commit | a8829f343f1a2b2f3432be5b2e92ab46dcfec995 (patch) | |
tree | cd408438300ffcc5aeb2ac4415ed38c35b5a7b49 /src/libserver | |
parent | 748f6c6966500ca653418a4600868767f91ba70e (diff) | |
download | rspamd-a8829f343f1a2b2f3432be5b2e92ab46dcfec995.tar.gz rspamd-a8829f343f1a2b2f3432be5b2e92ab46dcfec995.zip |
[Fix] Use non-volatile memory for storing data
Diffstat (limited to 'src/libserver')
-rw-r--r-- | src/libserver/milter.c | 37 | ||||
-rw-r--r-- | src/libserver/milter_internal.h | 4 |
2 files changed, 30 insertions, 11 deletions
diff --git a/src/libserver/milter.c b/src/libserver/milter.c index 10bec4ffc..392d7198e 100644 --- a/src/libserver/milter.c +++ b/src/libserver/milter.c @@ -174,6 +174,8 @@ rspamd_milter_session_dtor (struct rspamd_milter_session *session) rspamd_fstring_free (session->hostname); } + rspamd_mempool_delete (priv->pool); + g_free (priv); g_free (session); } @@ -507,12 +509,16 @@ rspamd_milter_process_command (struct rspamd_milter_session *session, msg_debug_milter ("mail command"); while (pos < end) { - zero = memchr (pos, '\0', end - pos); struct rspamd_email_address *addr; + gchar *cpy; - if (zero) { - msg_debug_milter ("got mail: %*s", (int)(zero - pos), pos); - addr = rspamd_email_address_from_smtp (pos, zero - pos); + zero = memchr (pos, '\0', end - pos); + + if (zero && zero > pos) { + cpy = rspamd_mempool_alloc (priv->pool, zero - pos); + memcpy (cpy, pos, zero - pos); + msg_debug_milter ("got mail: %*s", (int)(zero - pos), cpy); + addr = rspamd_email_address_from_smtp (cpy, zero - pos); if (addr) { session->from = addr; @@ -525,7 +531,9 @@ rspamd_milter_process_command (struct rspamd_milter_session *session, msg_debug_milter ("got weird from: %*s", (int)(end - pos), pos); /* That actually should not happen */ - addr = rspamd_email_address_from_smtp (pos, end - pos); + cpy = rspamd_mempool_alloc (priv->pool, end - pos); + memcpy (cpy, pos, end - pos); + addr = rspamd_email_address_from_smtp (cpy, end - pos); if (addr) { session->from = addr; @@ -593,12 +601,17 @@ rspamd_milter_process_command (struct rspamd_milter_session *session, msg_debug_milter ("rcpt command"); while (pos < end) { - zero = memchr (pos, '\0', end - pos); struct rspamd_email_address *addr; + gchar *cpy; - if (zero) { - msg_debug_milter ("got rcpt: %*s", (int)(zero - pos), pos); - addr = rspamd_email_address_from_smtp (pos, zero - pos); + zero = memchr (pos, '\0', end - pos); + + if (zero && zero > pos) { + cpy = rspamd_mempool_alloc (priv->pool, end - pos); + memcpy (cpy, pos, end - pos); + + msg_debug_milter ("got rcpt: %*s", (int)(zero - pos), cpy); + addr = rspamd_email_address_from_smtp (cpy, zero - pos); if (addr) { if (!session->rcpts) { @@ -611,10 +624,13 @@ rspamd_milter_process_command (struct rspamd_milter_session *session, pos = zero + 1; } else { + cpy = rspamd_mempool_alloc (priv->pool, end - pos); + memcpy (cpy, pos, end - pos); + msg_debug_milter ("got weird rcpt: %*s", (int)(end - pos), pos); /* That actually should not happen */ - addr = rspamd_email_address_from_smtp (pos, end - pos); + addr = rspamd_email_address_from_smtp (cpy, end - pos); if (addr) { if (!session->rcpts) { @@ -952,6 +968,7 @@ rspamd_milter_handle_socket (gint fd, const struct timeval *tv, priv->parser.buf = rspamd_fstring_sized_new (RSPAMD_MILTER_MESSAGE_CHUNK + 5); priv->ev_base = ev_base; priv->state = RSPAMD_MILTER_READ_MORE; + priv->pool = rspamd_mempool_new (rspamd_mempool_suggest_size (), "milter"); ottery_rand_bytes (uidbuf, sizeof (uidbuf)); rspamd_encode_hex_buf (uidbuf, sizeof (uidbuf), priv->uid, sizeof (priv->uid) - 1); diff --git a/src/libserver/milter_internal.h b/src/libserver/milter_internal.h index 0008967ec..52dee2d7a 100644 --- a/src/libserver/milter_internal.h +++ b/src/libserver/milter_internal.h @@ -18,6 +18,7 @@ #define RSPAMD_MILTER_INTERNAL_H #include "config.h" +#include "libutil/mem_pool.h" #include <event.h> enum rspamd_milter_state { @@ -52,11 +53,12 @@ enum rspamd_milter_io_state { struct rspamd_milter_private { struct rspamd_milter_parser parser; - struct rspamd_milter_outbuf *out_chain; struct event ev; struct timeval tv; + struct rspamd_milter_outbuf *out_chain; struct timeval *ptv; struct event_base *ev_base; + rspamd_mempool_t *pool; rspamd_milter_finish fin_cb; rspamd_milter_error err_cb; void *ud; |