aboutsummaryrefslogtreecommitdiffstats
path: root/src/libmime
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-03 17:29:19 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-09-03 17:29:19 +0100
commit0c38419795a244e650385a4f34b34192b11980a6 (patch)
tree48fa834110e4fff7b805d562288893f14ce593df /src/libmime
parent6bb4f58571bf1ee001d3aeb73aa5acd125add2c3 (diff)
downloadrspamd-0c38419795a244e650385a4f34b34192b11980a6.tar.gz
rspamd-0c38419795a244e650385a4f34b34192b11980a6.zip
Return content-type headers.
Diffstat (limited to 'src/libmime')
-rw-r--r--src/libmime/message.c32
1 files changed, 31 insertions, 1 deletions
diff --git a/src/libmime/message.c b/src/libmime/message.c
index 7adde3d95..41e571b79 100644
--- a/src/libmime/message.c
+++ b/src/libmime/message.c
@@ -1712,6 +1712,30 @@ local_message_get_sender (GMimeMessage * message)
return res;
}
+#ifdef GMIME24
+static const gchar*
+local_message_get_content_type (GMimeMessage * message)
+{
+ GMimeContentType *ct;
+
+ ct = g_mime_object_get_content_type (GMIME_OBJECT (message));
+ if (ct) {
+ return g_mime_content_type_to_string (ct);
+ }
+ return NULL;
+}
+static void
+local_message_set_content_type (GMimeMessage * message, const gchar *in)
+{
+ GMimeContentType *ct;
+
+ ct = g_mime_content_type_new_from_string (in);
+ if (ct) {
+ g_mime_object_set_content_type (GMIME_OBJECT (message), ct);
+ }
+}
+#endif
+
static const gchar *
local_message_get_reply_to (GMimeMessage * message)
{
@@ -1845,6 +1869,9 @@ static struct {
}, {
"Date", (GetFunc)g_mime_message_get_date_as_string, NULL, NULL,
local_mime_message_set_date_from_string, NULL, FUNC_CHARFREEPTR
+ }, {
+ "Content-Type", local_message_get_content_type, NULL, NULL,
+ local_message_set_content_type, NULL, FUNC_CHARFREEPTR
},
#endif
{
@@ -1887,7 +1914,10 @@ message_set_header (GMimeMessage * message,
strlen (fieldfunc[i].name))) {
switch (fieldfunc[i].functype) {
case FUNC_CHARPTR:
- (*(fieldfunc[i].setfunc))(message, value);
+ case FUNC_CHARFREEPTR:
+ if (fieldfunc[i].setfunc) {
+ (*(fieldfunc[i].setfunc))(message, value);
+ }
break;
case FUNC_IA:
(*(fieldfunc[i].setlfunc))(message, fieldfunc[i].name, value);