aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-22 20:54:30 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-22 20:54:30 +0100
commit460c4fad7efffafe99f7ac74ddd3e6950c4c744e (patch)
treed633c52c1fea8d77c53189a2cc1b3121600aba74
parent17e0a0778389ab4741747beb8cae5eedab0327a3 (diff)
downloadrspamd-460c4fad7efffafe99f7ac74ddd3e6950c4c744e.tar.gz
rspamd-460c4fad7efffafe99f7ac74ddd3e6950c4c744e.zip
Fix states for processing task.
-rw-r--r--src/worker.c30
1 files changed, 16 insertions, 14 deletions
diff --git a/src/worker.c b/src/worker.c
index 30da517fe..dc8765ea8 100644
--- a/src/worker.c
+++ b/src/worker.c
@@ -128,7 +128,7 @@ rspamd_worker_body_handler (struct rspamd_http_connection *conn,
}
if (!rspamd_task_process (task, msg, ctx->classify_pool, TRUE)) {
- rspamd_protocol_write_reply (task);
+ task->state = WRITE_REPLY;
}
return 0;
@@ -141,18 +141,8 @@ rspamd_worker_error_handler (struct rspamd_http_connection *conn, GError *err)
msg_info ("abnormally closing connection from: %s, error: %s",
rspamd_inet_address_to_string (&task->client_addr), err->message);
- if (task->state != WRITING_REPLY && task->state != CLOSING_CONNECTION) {
- /* We still need to write a reply */
- task->error_code = err->code;
- task->last_error =
- rspamd_mempool_strdup (task->task_pool, err->message);
- task->state = WRITE_REPLY;
- rspamd_protocol_write_reply (task);
- }
- else {
- /* Terminate session immediately */
- destroy_session (task->s);
- }
+ /* Terminate session immediately */
+ destroy_session (task->s);
}
static gint
@@ -161,12 +151,24 @@ rspamd_worker_finish_handler (struct rspamd_http_connection *conn,
{
struct rspamd_task *task = (struct rspamd_task *) conn->ud;
- if (msg->type == HTTP_RESPONSE) {
+ if (task->state == CLOSING_CONNECTION || task->state == WRITING_REPLY) {
/* We are done here */
msg_debug ("normally closing connection from: %s",
rspamd_inet_address_to_string (&task->client_addr));
destroy_session (task->s);
}
+ else if (task->state == WRITE_REPLY) {
+ /*
+ * We can come here if no filters has delayed their job and we want to
+ * write reply immediately. But this handler is executed when message
+ * is read
+ */
+ msg_debug ("want write message to the wire: %s",
+ rspamd_inet_address_to_string (&task->client_addr));
+ rspamd_protocol_write_reply (task);
+ /* Forcefully set the state */
+ task->state = CLOSING_CONNECTION;
+ }
else {
/*
* If all filters have finished their tasks, this function will trigger