diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-07-10 15:01:41 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-07-12 15:18:17 +0100 |
commit | 9aa104f6a709198527538c6553a0a96db1ecc5e9 (patch) | |
tree | b5973624d406f88ea4c179d2bc6e7b17965572d8 /src/libmime/message.h | |
parent | 4c1013fbdd26d37a31ac5895e0ecefb248fa4c6d (diff) | |
download | rspamd-9aa104f6a709198527538c6553a0a96db1ecc5e9.tar.gz rspamd-9aa104f6a709198527538c6553a0a96db1ecc5e9.zip |
[Project] Start mime structures refactoring
Diffstat (limited to 'src/libmime/message.h')
-rw-r--r-- | src/libmime/message.h | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/libmime/message.h b/src/libmime/message.h index 17c4ec5b9..7d58fa88f 100644 --- a/src/libmime/message.h +++ b/src/libmime/message.h @@ -12,6 +12,8 @@ #include "cryptobox.h" #include "mime_headers.h" #include "content_type.h" +#include "libutil/ref.h" +#include "libutil/str_util.h" #include <unicode/uchar.h> #include <unicode/utext.h> @@ -129,6 +131,36 @@ struct rspamd_mime_text_part { guint unicode_scripts; }; +struct rspamd_message { + const gchar *message_id; + gchar *subject; + + GPtrArray *parts; /**< list of parsed parts */ + GPtrArray *text_parts; /**< list of text parts */ + struct { + const gchar *begin; + gsize len; + const gchar *body_start; + } raw_headers_content; /**< list of raw headers */ + GPtrArray *received; /**< list of received headers */ + GHashTable *urls; /**< list of parsed urls */ + GHashTable *emails; /**< list of parsed emails */ + GHashTable *raw_headers; /**< list of raw headers */ + GQueue *headers_order; /**< order of raw headers */ + GPtrArray *rcpt_mime; + GPtrArray *from_mime; + enum rspamd_newlines_type nlines_type; /**< type of newlines (detected on most of headers */ + ref_entry_t ref; +}; + +#ifndef FULL_DEBUG +#define MESSAGE_FIELD(task, field) ((task)->message->(field)) +#else +#define MESSAGE_FIELD(task, field) do { \ + if (!task->message) {msg_err_task("no message when getting field %s", #field); g_assert(0);} \ + } while(0), ((task)->message->(field)) +#endif + /** * Parse and pre-process mime message * @param task worker_task object @@ -191,6 +223,12 @@ enum rspamd_cte rspamd_cte_from_string (const gchar *str); */ const gchar *rspamd_cte_to_string (enum rspamd_cte ct); +struct rspamd_message* rspamd_message_new (struct rspamd_task *task); + +struct rspamd_message *rspamd_message_ref (struct rspamd_message *msg); + +void rspamd_message_unref (struct rspamd_message *msg); + #ifdef __cplusplus } #endif |