diff options
-rw-r--r-- | src/protocol.c | 6 | ||||
-rw-r--r-- | src/worker.c | 49 |
2 files changed, 49 insertions, 6 deletions
diff --git a/src/protocol.c b/src/protocol.c index ffc56bde6..bb66f29d4 100644 --- a/src/protocol.c +++ b/src/protocol.c @@ -445,8 +445,14 @@ parse_header (struct worker_task *task, f_str_t * line) else { rspamd_set_dispatcher_policy (task->dispatcher, BUFFER_CHARACTER, task->content_length); task->state = READ_MESSAGE; + task->msg = memory_pool_alloc0 (task->task_pool, sizeof (f_str_t)); } } + else if (task->cmd != CMD_LEARN && task->cmd != CMD_OTHER) { + rspamd_set_dispatcher_policy (task->dispatcher, BUFFER_ANY, 0); + task->state = READ_MESSAGE; + task->msg = memory_pool_alloc0 (task->task_pool, sizeof (f_str_t)); + } else { task->last_error = "Unknown content length"; task->error_code = RSPAMD_LENGTH_ERROR; diff --git a/src/worker.c b/src/worker.c index ce4041897..d37e3f9a2 100644 --- a/src/worker.c +++ b/src/worker.c @@ -298,13 +298,50 @@ read_socket (f_str_t * in, void *arg) } break; case READ_MESSAGE: - task->msg = memory_pool_alloc (task->task_pool, sizeof (f_str_t)); - task->msg->begin = in->begin; - task->msg->len = in->len; - debug_task ("got string of length %z", task->msg->len); - task->state = WAIT_FILTER; - /* No more need of reading allowing half-closed connections to be proceed */ + /* Allow half-closed connections to be proceed */ task->dispatcher->want_read = FALSE; + if (task->content_length > 0) { + task->msg->begin = in->begin; + task->msg->len = in->len; + debug_task ("got string of length %z", task->msg->len); + task->state = WAIT_FILTER; + + } + else { + if (in->len > 0) { + if (task->msg->begin == NULL) { + /* Allocate buf */ + task->msg->size = MAX (BUFSIZ, in->len); + task->msg->begin = g_malloc (task->msg->size); + memcpy (task->msg->begin, in->begin, in->len); + task->msg->len = in->len; + } + else if (task->msg->size >= task->msg->len + in->len) { + memcpy (task->msg->begin + task->msg->len, in->begin, in->len); + task->msg->len += in->len; + } + else { + /* Need to realloc */ + task->msg->size = MAX (task->msg->size * 2, task->msg->size + in->len); + task->msg->begin = g_realloc (task->msg->begin, task->msg->size); + memcpy (task->msg->begin + task->msg->len, in->begin, in->len); + task->msg->len += in->len; + } + /* Want more */ + return TRUE; + } + else if (task->msg->len > 0) { + memory_pool_add_destructor (task->task_pool, (pool_destruct_func)g_free, task->msg->begin); + } + else { + msg_warn ("empty message passed"); + task->last_error = "MIME processing error"; + task->error_code = RSPAMD_FILTER_ERROR; + task->state = WRITE_ERROR; + return write_socket (task); + } + } + r = process_message (task); if (r == -1) { msg_warn ("processing of message failed"); |