From: Vsevolod Stakhov Date: Wed, 27 Sep 2017 19:44:56 +0000 (+0100) Subject: [Fix] Check for magic when checking for an archive X-Git-Tag: 1.7.0~608 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d0106139487f80bc4fcc926d7329f3e0aada234d;p=thirdparty%2Frspamd.git [Fix] Check for magic when checking for an archive Issue: #1848 Closes: #1848 MFH: 1.6 --- diff --git a/src/libmime/archives.c b/src/libmime/archives.c index 0d24cb28fd..8cd45f0b43 100644 --- a/src/libmime/archives.c +++ b/src/libmime/archives.c @@ -697,7 +697,19 @@ rspamd_archive_cheat_detect (struct rspamd_mime_part *part, const gchar *str, &srch) == 0) { if (rspamd_substring_search_caseless (ct->subtype.begin, ct->subtype.len, str, strlen (str)) != -1) { - return TRUE; + /* We still need to check magic, see #1848 */ + if (magic_start != NULL) { + if (part->parsed_data.len > magic_len && + memcmp (part->parsed_data.begin, + magic_start, magic_len) == 0) { + return TRUE; + } + /* No magic, refuse this type of archive */ + return FALSE; + } + else { + return TRUE; + } } } @@ -709,6 +721,16 @@ rspamd_archive_cheat_detect (struct rspamd_mime_part *part, const gchar *str, if (rspamd_lc_cmp (p, str, strlen (str)) == 0) { if (*(p - 1) == '.') { + if (magic_start != NULL) { + if (part->parsed_data.len > magic_len && + memcmp (part->parsed_data.begin, + magic_start, magic_len) == 0) { + return TRUE; + } + /* No magic, refuse this type of archive */ + return FALSE; + } + return TRUE; } }