diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-03-25 12:31:39 +0300 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-03-25 12:31:39 +0300 |
commit | 62aaf7da57503a257aecede98ba2ae2e1f2ee3e2 (patch) | |
tree | ff6d99673a8ebf08d27716beaf4ea689d4aa98f9 /src | |
parent | f592edf20b6d91fb6c25d9d3b1021d2ab4c5fcb3 (diff) | |
download | rspamd-62aaf7da57503a257aecede98ba2ae2e1f2ee3e2.tar.gz rspamd-62aaf7da57503a257aecede98ba2ae2e1f2ee3e2.zip |
* Log scan time and scan length of messages
* Remove 2 memory leaks
Diffstat (limited to 'src')
-rw-r--r-- | src/main.h | 1 | ||||
-rw-r--r-- | src/message.c | 3 | ||||
-rw-r--r-- | src/protocol.c | 4 | ||||
-rw-r--r-- | src/util.c | 14 | ||||
-rw-r--r-- | src/util.h | 1 | ||||
-rw-r--r-- | src/worker.c | 1 |
6 files changed, 23 insertions, 1 deletions
diff --git a/src/main.h b/src/main.h index e26ab3fda..431ed8f4b 100644 --- a/src/main.h +++ b/src/main.h @@ -184,6 +184,7 @@ struct worker_task { char *last_error; /**< last error */ int error_code; /**< code of last error */ memory_pool_t *task_pool; /**< memory pool for task */ + struct timespec ts; /**< time of connection */ }; /** diff --git a/src/message.c b/src/message.c index 561c49457..6d770bbe8 100644 --- a/src/message.c +++ b/src/message.c @@ -292,6 +292,7 @@ mime_foreach_callback (GMimeObject *part, gpointer user_data) if (type == NULL) { msg_warn ("mime_foreach_callback: type of part is unknown, assume text/plain"); type = g_mime_content_type_new ("text", "plain"); + memory_pool_add_destructor (task->task_pool, (pool_destruct_func)g_mime_content_type_destroy, type); } wrapper = g_mime_part_get_content_object (GMIME_PART (part)); if (wrapper != NULL) { @@ -802,6 +803,7 @@ message_get_header (memory_pool_t *pool, GMimeMessage *message, const char *fiel while (ia && ia->address) { ia_string = internet_address_to_string ((InternetAddress *)ia->address, FALSE); + memory_pool_add_destructor (pool, (pool_destruct_func)g_free, ia_string); gret = g_list_prepend (gret, ia_string); ia = ia->next; } @@ -809,6 +811,7 @@ message_get_header (memory_pool_t *pool, GMimeMessage *message, const char *fiel i = internet_address_list_length (ia); while (i > 0) { ia_string = internet_address_to_string (internet_address_list_get_address (ia, i), FALSE); + memory_pool_add_destructor (pool, (pool_destruct_func)g_free, ia_string); gret = g_list_prepend (gret, ia_string); -- i; } diff --git a/src/protocol.c b/src/protocol.c index 6230495bf..c9e4925ff 100644 --- a/src/protocol.c +++ b/src/protocol.c @@ -24,6 +24,7 @@ #include "config.h" #include "main.h" +#include "util.h" #include "cfg_file.h" /* Max line size as it is defined in rfc2822 */ @@ -485,7 +486,8 @@ show_metric_result (gpointer metric_name, gpointer metric_value, void *user_data if (task->cmd == CMD_SYMBOLS && metric_value != NULL) { show_metric_symbols (metric_res, cd); } - cd->log_offset += snprintf (cd->log_buf + cd->log_offset, cd->log_size - cd->log_offset, "] )"); + cd->log_offset += snprintf (cd->log_buf + cd->log_offset, cd->log_size - cd->log_offset, "] ), len: %ld, time: %ldms", + (long int)task->msg->len, calculate_check_time (&task->ts)); } static int diff --git a/src/util.c b/src/util.c index 1fdd2758a..ef9531bd3 100644 --- a/src/util.c +++ b/src/util.c @@ -787,6 +787,20 @@ resolve_stat_filename (memory_pool_t *pool, char *pattern, char *rcpt, char *fro return new; } +long int +calculate_check_time (struct timespec *begin) +{ + struct timespec ts; + long int res; + + clock_gettime (CLOCK_REALTIME, &ts); + + res = (ts.tv_sec - begin->tv_sec) * 1000 + /* Seconds */ + (ts.tv_nsec - begin->tv_nsec) / 1000000; /* Nanoseconds */ + + return res; +} + /* * vi:ts=4 */ diff --git a/src/util.h b/src/util.h index fa47f21e1..67e3d3d01 100644 --- a/src/util.h +++ b/src/util.h @@ -55,5 +55,6 @@ void file_log_function (const gchar *log_domain, GLogLevelFlags log_level, const /* Replace %r with rcpt value and %f with from value, new string is allocated in pool */ char* resolve_stat_filename (memory_pool_t *pool, char *pattern, char *rcpt, char *from); +long int calculate_check_time (struct timespec *begin); #endif diff --git a/src/worker.c b/src/worker.c index bf5dfa159..295f331dc 100644 --- a/src/worker.c +++ b/src/worker.c @@ -254,6 +254,7 @@ accept_socket (int fd, short what, void *arg) new_task->state = READ_COMMAND; new_task->sock = nfd; new_task->cfg = worker->srv->cfg; + clock_gettime (CLOCK_REALTIME, &new_task->ts); io_tv.tv_sec = WORKER_IO_TIMEOUT; io_tv.tv_usec = 0; TAILQ_INIT (&new_task->urls); |