aboutsummaryrefslogtreecommitdiffstats
path: root/src/libmime/mime_headers.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/libmime/mime_headers.c')
-rw-r--r--src/libmime/mime_headers.c77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/libmime/mime_headers.c b/src/libmime/mime_headers.c
index 9b65f1ecf..eaee0a5ae 100644
--- a/src/libmime/mime_headers.c
+++ b/src/libmime/mime_headers.c
@@ -17,15 +17,90 @@
#include "mime_headers.h"
#include "smtp_parsers.h"
#include "mime_encoding.h"
+#include "email_addr.h"
#include "task.h"
+#include "cryptobox.h"
#include "contrib/libottery/ottery.h"
static void
+rspamd_mime_header_check_special (struct rspamd_task *task,
+ struct rspamd_mime_header *rh)
+{
+ guint64 h;
+ struct received_header *recv;
+
+ h = rspamd_icase_hash (rh->name, strlen (rh->name), 0xdeadbabe);
+
+ switch (h) {
+ case 0x88705DC4D9D61ABULL: /* received */
+ recv = rspamd_mempool_alloc0 (task->task_pool,
+ sizeof (struct received_header));
+ rspamd_smtp_recieved_parse (task, rh->decoded,
+ strlen (rh->decoded), recv);
+ g_ptr_array_add (task->received, recv);
+ break;
+ case 0x76F31A09F4352521ULL: /* to */
+ task->rcpt_mime = rspamd_email_address_from_mime (task->task_pool,
+ rh->value, strlen (rh->value), task->rcpt_mime);
+ break;
+ case 0x7EB117C1480B76ULL: /* cc */
+ task->rcpt_mime = rspamd_email_address_from_mime (task->task_pool,
+ rh->value, strlen (rh->value), task->rcpt_mime);
+ break;
+ case 0xE4923E11C4989C8DULL: /* bcc */
+ task->rcpt_mime = rspamd_email_address_from_mime (task->task_pool,
+ rh->value, strlen (rh->value), task->rcpt_mime);
+ break;
+ case 0x41E1985EDC1CBDE4ULL: /* from */
+ task->from_mime = rspamd_email_address_from_mime (task->task_pool,
+ rh->value, strlen (rh->value), task->from_mime);
+ break;
+ case 0x43A558FC7C240226ULL: /* message-id */ {
+ gchar *p, *end;
+
+ p = rh->decoded;
+ end = p + strlen (p);
+
+ if (*p == '<') {
+ p ++;
+
+ if (end > p && *(end - 1) == '>') {
+ *(end - 1) = '\0';
+ p = rspamd_mempool_strdup (task->task_pool, p);
+ *(end - 1) = '>';
+ }
+ }
+
+ task->message_id = p;
+ break;
+ }
+ case 0xB91D3910358E8212ULL: /* subject */
+ if (task->subject == NULL) {
+ task->subject = rh->decoded;
+ }
+ break;
+ case 0xEE4AA2EAAC61D6F4ULL: /* return-path */
+ if (task->from_envelope == NULL) {
+ task->from_envelope = rspamd_email_address_from_smtp (rh->decoded,
+ strlen (rh->decoded));
+ }
+ break;
+ case 0xB9EEFAD2E93C2161ULL: /* delivered-to */
+ if (task->deliver_to == NULL) {
+ task->deliver_to = rh->decoded;
+ }
+ break;
+ }
+}
+
+static void
rspamd_mime_header_add (struct rspamd_task *task,
GHashTable *target, struct rspamd_mime_header *rh)
{
GPtrArray *ar;
+ rspamd_mime_header_check_special (task, rh);
+
if ((ar = g_hash_table_lookup (target, rh->name)) != NULL) {
g_ptr_array_add (ar, rh);
msg_debug_task ("append raw header %s: %s", rh->name, rh->value);
@@ -36,6 +111,8 @@ rspamd_mime_header_add (struct rspamd_task *task,
g_hash_table_insert (target, rh->name, ar);
msg_debug_task ("add new raw header %s: %s", rh->name, rh->value);
}
+
+ rspamd_mime_header_check_special (task, rh);
}
/* Convert raw headers to a list of struct raw_header * */