aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/plugins/fuzzy_check.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c
index a6c22096d..e807bec68 100644
--- a/src/plugins/fuzzy_check.c
+++ b/src/plugins/fuzzy_check.c
@@ -296,12 +296,22 @@ fuzzy_rule_new (const char *default_symbol, rspamd_mempool_t *pool)
return rule;
}
+static void
+fuzzy_free_rule (gpointer r)
+{
+ struct fuzzy_rule *rule = (struct fuzzy_rule *)r;
+
+ g_string_free (rule->hash_key, TRUE);
+ g_string_free (rule->shingles_key, TRUE);
+}
+
static gint
fuzzy_parse_rule (struct rspamd_config *cfg, const ucl_object_t *obj)
{
const ucl_object_t *value, *cur;
struct fuzzy_rule *rule;
ucl_object_iter_t it = NULL;
+ const char *k = NULL;
if (obj->type != UCL_OBJECT) {
msg_err ("invalid rule definition");
@@ -352,6 +362,29 @@ fuzzy_parse_rule (struct rspamd_config *cfg, const ucl_object_t *obj)
}
}
+ if ((value = ucl_object_find_key (obj, "fuzzy_key")) != NULL) {
+ /* Create key from user's input */
+ k = ucl_object_tostring (value);
+ }
+
+ /* Setup keys */
+ if (k == NULL) {
+ /* Use some default key for all ops */
+ k = "rspamd";
+ }
+ rule->hash_key = g_string_sized_new (BLAKE2B_KEYBYTES);
+ blake2 (rule->hash_key->str, k, NULL, BLAKE2B_KEYBYTES, strlen (k), 0);
+
+ if ((value = ucl_object_find_key (obj, "fuzzy_shingles_key")) != NULL) {
+ k = ucl_object_tostring (value);
+ }
+ if (k == NULL) {
+ k = "rspamd";
+ }
+ rule->shingles_key = g_string_sized_new (16);
+ blake2 (rule->hash_key->str, k, NULL, 16, strlen (k), 0);
+
+
if (rspamd_upstreams_count (rule->servers) == 0) {
msg_err ("no servers defined for fuzzy rule with symbol: %s",
rule->symbol);
@@ -366,6 +399,9 @@ fuzzy_parse_rule (struct rspamd_config *cfg, const ucl_object_t *obj)
}
}
+ rspamd_mempool_add_destructor (fuzzy_module_ctx->fuzzy_pool, fuzzy_free_rule,
+ rule);
+
return 0;
}