diff options
Diffstat (limited to 'src/libserver/cfg_rcl.c')
-rw-r--r-- | src/libserver/cfg_rcl.c | 59 |
1 files changed, 41 insertions, 18 deletions
diff --git a/src/libserver/cfg_rcl.c b/src/libserver/cfg_rcl.c index a14a43146..46dd1b60f 100644 --- a/src/libserver/cfg_rcl.c +++ b/src/libserver/cfg_rcl.c @@ -250,9 +250,10 @@ rspamd_rcl_options_handler (rspamd_mempool_t *pool, const ucl_object_t *obj, */ static gboolean rspamd_rcl_insert_symbol (struct rspamd_config *cfg, struct metric *metric, - const ucl_object_t *obj, const gchar *group, gboolean is_legacy, GError **err) + const ucl_object_t *obj, struct rspamd_symbols_group *gr, + gboolean is_legacy, GError **err) { - const gchar *description = NULL, *sym_name; + const gchar *description = NULL, *sym_name, *group; gdouble symbol_score; const ucl_object_t *val; gboolean one_shot = FALSE; @@ -280,9 +281,13 @@ rspamd_rcl_insert_symbol (struct rspamd_config *cfg, struct metric *metric, sym_name = ucl_object_key (obj); } - if (group == NULL) { + if (gr == NULL) { group = "ungrouped"; } + else { + group = gr->name; + one_shot = gr->one_shot; + } if (ucl_object_todouble_safe (obj, &symbol_score)) { description = NULL; @@ -336,7 +341,7 @@ rspamd_rcl_insert_symbol (struct rspamd_config *cfg, struct metric *metric, static gboolean rspamd_rcl_symbols_handler (rspamd_mempool_t *pool, const ucl_object_t *obj, struct rspamd_config *cfg, struct metric *metric, - const gchar *group, gboolean new, GError **err) + struct rspamd_symbols_group *gr, gboolean new, GError **err) { const ucl_object_t *val, *cur; ucl_object_iter_t it = NULL; @@ -350,7 +355,7 @@ rspamd_rcl_symbols_handler (rspamd_mempool_t *pool, const ucl_object_t *obj, } it = NULL; while ((cur = ucl_iterate_object (val, &it, true)) != NULL) { - if (!rspamd_rcl_insert_symbol (cfg, metric, cur, group, FALSE, err)) { + if (!rspamd_rcl_insert_symbol (cfg, metric, cur, gr, FALSE, err)) { return FALSE; } } @@ -369,7 +374,7 @@ rspamd_rcl_symbols_handler (rspamd_mempool_t *pool, const ucl_object_t *obj, it = NULL; while ((cur = ucl_iterate_object (val, &it, false)) != NULL) { - if (!rspamd_rcl_insert_symbol (cfg, metric, cur, group, TRUE, err)) { + if (!rspamd_rcl_insert_symbol (cfg, metric, cur, gr, TRUE, err)) { return FALSE; } } @@ -504,23 +509,41 @@ rspamd_rcl_metric_handler (rspamd_mempool_t *pool, const ucl_object_t *obj, elt = ucl_object_find_key (cur, "name"); if (elt) { - if (!rspamd_rcl_symbols_handler (pool, cur, cfg, metric, - ucl_object_tostring (elt), - !have_symbols, err)) { - return FALSE; - } - - have_symbols = TRUE; gr = g_hash_table_lookup (cfg->symbols_groups, ucl_object_tostring (elt)); + if (gr == NULL) { + gr = + rspamd_mempool_alloc0 (cfg->cfg_pool, + sizeof (struct rspamd_symbols_group)); + gr->name = rspamd_mempool_strdup (cfg->cfg_pool, + ucl_object_tostring (elt)); + g_hash_table_insert (cfg->symbols_groups, gr->name, gr); + } - if (gr != NULL) { - elt = ucl_object_find_key (cur, "max_score"); + elt = ucl_object_find_key (cur, "max_score"); - if (elt) { - gr->max_score = ucl_object_todouble (elt); - } + if (elt) { + gr->max_score = ucl_object_todouble (elt); } + + elt = ucl_object_find_key (cur, "disabled"); + + if (elt) { + gr->disabled = ucl_object_toboolean (elt); + } + + elt = ucl_object_find_key (cur, "one_shot"); + + if (elt) { + gr->one_shot = ucl_object_toboolean (elt); + } + + if (!rspamd_rcl_symbols_handler (pool, cur, cfg, metric, + gr, !have_symbols, err)) { + return FALSE; + } + + have_symbols = TRUE; } } } |