diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-04-29 17:31:34 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-04-29 17:31:34 +0100 |
commit | 54d25a96213d766b07355d07968cce6c2eb6b413 (patch) | |
tree | df0f8fba925b6a982e5b9ecf38eed4faddd42fbc | |
parent | 0bafc268eb35e05c230cfc44a0cd877cb7e962dd (diff) | |
download | rspamd-54d25a96213d766b07355d07968cce6c2eb6b413.tar.gz rspamd-54d25a96213d766b07355d07968cce6c2eb6b413.zip |
[Fix] Fix parsing of long regexp types
-rw-r--r-- | src/libmime/mime_expressions.c | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/src/libmime/mime_expressions.c b/src/libmime/mime_expressions.c index 64344f4b5..139b61b07 100644 --- a/src/libmime/mime_expressions.c +++ b/src/libmime/mime_expressions.c @@ -177,49 +177,58 @@ rspamd_mime_expr_quark (void) return g_quark_from_static_string ("mime-expressions"); } +#define TYPE_CHECK(str, type, len) (sizeof(type) - 1 == (len) && rspamd_lc_cmp((str), (type), (len)) == 0) static gboolean rspamd_parse_long_option (const gchar *start, gsize len, struct rspamd_regexp_atom *a) { gboolean ret = FALSE; - if (rspamd_lc_cmp (start, "body", len) == 0) { + if (TYPE_CHECK (start, "body", len)) { ret = TRUE; a->type = RSPAMD_RE_BODY; } - else if (rspamd_lc_cmp (start, "part", len) == 0) { + else if (TYPE_CHECK (start, "part", len) || + TYPE_CHECK (start, "mime", len)) { ret = TRUE; a->type = RSPAMD_RE_MIME; } - else if (rspamd_lc_cmp (start, "raw_part", len) == 0) { + else if (TYPE_CHECK (start, "raw_part", len) || + TYPE_CHECK (start, "raw_mime", len) || + TYPE_CHECK (start, "mime_raw", len)) { ret = TRUE; a->type = RSPAMD_RE_RAWMIME; } - else if (rspamd_lc_cmp (start, "header", len) == 0) { + else if (TYPE_CHECK (start, "header", len)) { ret = TRUE; a->type = RSPAMD_RE_HEADER; } - else if (rspamd_lc_cmp (start, "mime_header", len) == 0) { + else if (TYPE_CHECK (start, "mime_header", len) || + TYPE_CHECK (start, "header_mime", len)) { ret = TRUE; a->type = RSPAMD_RE_MIMEHEADER; } - else if (rspamd_lc_cmp (start, "raw_header", len) == 0) { + else if (rspamd_lc_cmp (start, "raw_header", len) || + TYPE_CHECK (start, "header_raw", len)) { ret = TRUE; a->type = RSPAMD_RE_RAWHEADER; } - else if (rspamd_lc_cmp (start, "all_header", len) == 0) { + else if (rspamd_lc_cmp (start, "all_header", len) || + TYPE_CHECK (start, "header_all", len) || + TYPE_CHECK (start, "all_headers", len)) { ret = TRUE; a->type = RSPAMD_RE_ALLHEADER; } - else if (rspamd_lc_cmp (start, "url", len) == 0) { + else if (rspamd_lc_cmp (start, "url", len)) { ret = TRUE; a->type = RSPAMD_RE_URL; } - else if (rspamd_lc_cmp (start, "sa_body", len) == 0) { + else if (rspamd_lc_cmp (start, "sa_body", len)) { ret = TRUE; a->type = RSPAMD_RE_SABODY; } - else if (rspamd_lc_cmp (start, "sa_raw_body", len) == 0) { + else if (rspamd_lc_cmp (start, "sa_raw_body", len) || + TYPE_CHECK (start, "sa_body_raw", len)) { ret = TRUE; a->type = RSPAMD_RE_SARAWBODY; } |