diff options
Diffstat (limited to 'src/plugins/fuzzy_check.c')
-rw-r--r-- | src/plugins/fuzzy_check.c | 126 |
1 files changed, 73 insertions, 53 deletions
diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c index c11ab40bf..721f1257a 100644 --- a/src/plugins/fuzzy_check.c +++ b/src/plugins/fuzzy_check.c @@ -1397,6 +1397,66 @@ fuzzy_process_reply (guchar **pos, gint *r, GPtrArray *req, return NULL; } +static void +fuzzy_insert_result (struct fuzzy_client_session *session, + const struct rspamd_fuzzy_reply *rep, + struct rspamd_fuzzy_cmd *cmd, guint flag) +{ + const gchar *symbol; + struct fuzzy_mapping *map; + struct rspamd_task *task = session->task; + double nval; + guchar buf[2048]; + + /* Get mapping by flag */ + if ((map = + g_hash_table_lookup (session->rule->mappings, + GINT_TO_POINTER (rep->flag))) == NULL) { + /* Default symbol and default weight */ + symbol = session->rule->symbol; + + } + else { + /* Get symbol and weight from map */ + symbol = map->symbol; + } + + + /* + * Hash is assumed to be found if probability is more than 0.5 + * In that case `value` means number of matches + * Otherwise `value` means error code + */ + + nval = fuzzy_normalize (rep->value, + session->rule->max_score); + nval *= rep->prob; + msg_info_task ( + "found fuzzy hash %*xs with weight: " + "%.2f, in list: %s:%d%s", + rspamd_fuzzy_hash_len, cmd->digest, + nval, + symbol, + rep->flag, + map == NULL ? "(unknown)" : ""); + if (map != NULL || !session->rule->skip_unknown) { + rspamd_snprintf (buf, + sizeof (buf), + "%d:%*xs:%.2f", + rep->flag, + rspamd_fuzzy_hash_len, cmd->digest, + rep->prob, + nval); + rspamd_task_insert_result_single (session->task, + symbol, + nval, + g_list_prepend (NULL, + rspamd_mempool_strdup ( + session->task->task_pool, + buf))); + } +} + /* Fuzzy check callback */ static void fuzzy_check_io_callback (gint fd, short what, void *arg) @@ -1404,14 +1464,12 @@ fuzzy_check_io_callback (gint fd, short what, void *arg) struct fuzzy_client_session *session = arg; const struct rspamd_fuzzy_reply *rep; struct rspamd_task *task; - struct fuzzy_mapping *map; guchar buf[2048], *p; - const gchar *symbol; struct fuzzy_cmd_io *io; struct rspamd_fuzzy_cmd *cmd = NULL; guint i; gint r; - double nval; + enum { return_error = 0, return_want_more, @@ -1434,68 +1492,30 @@ fuzzy_check_io_callback (gint fd, short what, void *arg) while ((rep = fuzzy_process_reply (&p, &r, session->commands, session->rule, &cmd)) != NULL) { - /* Get mapping by flag */ - if ((map = - g_hash_table_lookup (session->rule->mappings, - GINT_TO_POINTER (rep->flag))) == NULL) { - /* Default symbol and default weight */ - symbol = session->rule->symbol; - - } - else { - /* Get symbol and weight from map */ - symbol = map->symbol; - } - - - /* - * Hash is assumed to be found if probability is more than 0.5 - * In that case `value` means number of matches - * Otherwise `value` means error code - */ if (rep->prob > 0.5) { - nval = fuzzy_normalize (rep->value, - session->rule->max_score); - nval *= rep->prob; - msg_info_task ( - "found fuzzy hash %*xs with weight: " - "%.2f, in list: %s:%d%s", - rspamd_fuzzy_hash_len, cmd->digest, - nval, - symbol, - rep->flag, - map == NULL ? "(unknown)" : ""); - if (map != NULL || !session->rule->skip_unknown) { - rspamd_snprintf (buf, - sizeof (buf), - "%d:%*xs:%.2f", - rep->flag, - rspamd_fuzzy_hash_len, cmd->digest, - rep->prob, - nval); - rspamd_task_insert_result_single (session->task, - symbol, - nval, - g_list_prepend (NULL, - rspamd_mempool_strdup ( - session->task->task_pool, - buf))); + if (rep->flag & (1U << 31)) { + /* Multi-flag */ + for (i = 0; i < 31; i ++) { + if ((1U << i) & rep->flag) { + fuzzy_insert_result (session, rep, cmd, i + 1); + } + } + } + else { + fuzzy_insert_result (session, rep, cmd, rep->flag); } } else if (rep->value == 403) { msg_info_task ( - "fuzzy check error for %s(%d): forbidden", - symbol, + "fuzzy check error for %d: forbidden", rep->flag); } else if (rep->value != 0) { msg_info_task ( - "fuzzy check error for %s(%d): unknown error (%d)", - symbol, + "fuzzy check error for %d: unknown error (%d)", rep->flag, rep->value); } - /* Not found */ ret = return_finished; } |