aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-08-15 18:32:42 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-08-15 18:32:42 +0100
commite33ea5e4782b4a6e3f706634d85058d1a4f42d6b (patch)
treea0a0becbb89642e3b44917293089a21efeffc4bf /src
parent1534fdca8c1d35ede2ce89c3604f344b8f74e5f5 (diff)
downloadrspamd-e33ea5e4782b4a6e3f706634d85058d1a4f42d6b.tar.gz
rspamd-e33ea5e4782b4a6e3f706634d85058d1a4f42d6b.zip
[Feature] Store task checksum
Diffstat (limited to 'src')
-rw-r--r--src/libmime/message.c29
-rw-r--r--src/libserver/task.h1
2 files changed, 26 insertions, 4 deletions
diff --git a/src/libmime/message.c b/src/libmime/message.c
index 09176cfe3..1f6356881 100644
--- a/src/libmime/message.c
+++ b/src/libmime/message.c
@@ -1375,6 +1375,8 @@ rspamd_message_parse (struct rspamd_task *task)
gint i;
gdouble diff, *pdiff;
guint tw, *ptw, dw;
+ rspamd_cryptobox_hash_state_t st;
+ guchar digest_out[rspamd_cryptobox_HASHBYTES];
if (RSPAMD_TASK_IS_EMPTY (task)) {
/* Don't do anything with empty task */
@@ -1430,6 +1432,7 @@ rspamd_message_parse (struct rspamd_task *task)
* pool allocator
*/
g_mime_stream_mem_set_owner (GMIME_STREAM_MEM (stream), FALSE);
+ rspamd_cryptobox_hash_init (&st, NULL, 0);
if (task->flags & RSPAMD_TASK_FLAG_MIME) {
@@ -1474,6 +1477,10 @@ rspamd_message_parse (struct rspamd_task *task)
task->raw_headers_content.len = hdr_pos;
task->raw_headers_content.body_start = p + body_pos;
+ rspamd_cryptobox_hash_update (&st,
+ task->raw_headers_content.begin,
+ task->raw_headers_content.len);
+
if (task->raw_headers_content.len > 0) {
process_raw_headers (task, task->raw_headers,
task->raw_headers_content.begin,
@@ -1718,13 +1725,27 @@ rspamd_message_parse (struct rspamd_task *task)
"them with each other");
}
+ for (i = 0; i < task->parts->len; i ++) {
+ struct rspamd_mime_part *part;
+
+ part = g_ptr_array_index (task->parts, i);
+ rspamd_cryptobox_hash_update (&st, part->digest, sizeof (part->digest));
+ }
+
+ rspamd_cryptobox_hash_final (&st, digest_out);
+ memcpy (task->digest, digest_out, sizeof (task->digest));
+
if (task->queue_id) {
- msg_info_task ("loaded message; id: <%s>; queue-id: <%s>; size: %z",
- task->message_id, task->queue_id, task->msg.len);
+ msg_info_task ("loaded message; id: <%s>; queue-id: <%s>; size: %z; "
+ "checksum: <%*xs>",
+ task->message_id, task->queue_id, task->msg.len,
+ (gint)sizeof (task->digest), task->digest);
}
else {
- msg_info_task ("loaded message; id: <%s>; size: %z",
- task->message_id, task->msg.len);
+ msg_info_task ("loaded message; id: <%s>; size: %z; "
+ "checksum: <%*xs>",
+ task->message_id, task->msg.len,
+ (gint)sizeof (task->digest), task->digest);
}
return TRUE;
diff --git a/src/libserver/task.h b/src/libserver/task.h
index c76dd614e..f436c8275 100644
--- a/src/libserver/task.h
+++ b/src/libserver/task.h
@@ -188,6 +188,7 @@ struct rspamd_task {
ucl_object_t *settings; /**< Settings applied to task */
const gchar *classifier; /**< Classifier to learn (if needed) */
+ guchar digest[16];
};
/**