aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-05-17 22:23:35 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-05-17 22:23:35 +0100
commita8829f343f1a2b2f3432be5b2e92ab46dcfec995 (patch)
treecd408438300ffcc5aeb2ac4415ed38c35b5a7b49 /src/libserver
parent748f6c6966500ca653418a4600868767f91ba70e (diff)
downloadrspamd-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.c37
-rw-r--r--src/libserver/milter_internal.h4
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;