diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-12-16 17:57:16 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-12-16 17:57:16 +0000 |
commit | c0728b83b8b9a2470e0b4f11d69b41bbd33bfc86 (patch) | |
tree | c7a3546a1b4c5dbbe0c3de079f30ca09a49c920d | |
parent | da7970857f420b4598e62f424e99f6d87a0035a3 (diff) | |
download | rspamd-c0728b83b8b9a2470e0b4f11d69b41bbd33bfc86.tar.gz rspamd-c0728b83b8b9a2470e0b4f11d69b41bbd33bfc86.zip |
[Rework|Minor] Fix fuzzy check plugin
-rw-r--r-- | src/plugins/fuzzy_check.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c index 0c270f9db..b33f1eb13 100644 --- a/src/plugins/fuzzy_check.c +++ b/src/plugins/fuzzy_check.c @@ -286,7 +286,7 @@ parse_fuzzy_headers (const gchar *str) } static gboolean -fuzzy_check_content_type (struct fuzzy_rule *rule, GMimeContentType *type) +fuzzy_check_content_type (struct fuzzy_rule *rule, struct rspamd_content_type *ct) { struct fuzzy_mime_type *ft; GList *cur; @@ -296,9 +296,10 @@ fuzzy_check_content_type (struct fuzzy_rule *rule, GMimeContentType *type) ft = cur->data; if (ft->type) { - if (g_pattern_match_string (ft->type, type->type)) { + if (g_pattern_match (ft->type, ct->type.len, ct->type.begin, NULL)) { if (ft->subtype) { - if (g_pattern_match_string (ft->subtype, type->subtype)) { + if (g_pattern_match (ft->subtype, ct->subtype.len, + ct->subtype.begin, NULL)) { return TRUE; } } @@ -2234,7 +2235,7 @@ fuzzy_generate_commands (struct rspamd_task *task, struct fuzzy_rule *rule, mime_part = g_ptr_array_index (task->parts, i); if (mime_part->flags & RSPAMD_MIME_PART_IMAGE) { - image = mime_part->specific_data; + image = mime_part->specific.img; if (image->data->len > 0) { if (fuzzy_module_ctx->min_height <= 0 || image->height >= @@ -2261,9 +2262,9 @@ fuzzy_generate_commands (struct rspamd_task *task, struct fuzzy_rule *rule, } } - if (mime_part->content->len > 0 && - fuzzy_check_content_type (rule, mime_part->type)) { - if (fuzzy_module_ctx->min_bytes <= 0 || mime_part->content->len >= + if (mime_part->parsed_data.len > 0 && + fuzzy_check_content_type (rule, mime_part->ct)) { + if (fuzzy_module_ctx->min_bytes <= 0 || mime_part->parsed_data.len >= fuzzy_module_ctx->min_bytes) { io = fuzzy_cmd_from_data_part (rule, c, flag, value, task->task_pool, |