diff options
-rw-r--r-- | src/libserver/cfg_file.h | 1 | ||||
-rw-r--r-- | src/libserver/cfg_utils.c | 5 | ||||
-rw-r--r-- | src/lua/lua_config.c | 19 |
3 files changed, 17 insertions, 8 deletions
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h index b368464a0..702325f62 100644 --- a/src/libserver/cfg_file.h +++ b/src/libserver/cfg_file.h @@ -130,6 +130,7 @@ enum rspamd_symbol_flags { RSPAMD_SYMBOL_FLAG_ONEPARAM = (1 << 2), RSPAMD_SYMBOL_FLAG_UNGROUPPED = (1 << 3), RSPAMD_SYMBOL_FLAG_DISABLED = (1 << 4), + RSPAMD_SYMBOL_FLAG_UNSCORED = (1 << 5), }; /** diff --git a/src/libserver/cfg_utils.c b/src/libserver/cfg_utils.c index 9a308a8a4..8486a029f 100644 --- a/src/libserver/cfg_utils.c +++ b/src/libserver/cfg_utils.c @@ -1625,6 +1625,7 @@ rspamd_config_new_symbol (struct rspamd_config *cfg, const gchar *symbol, score = 0.0; /* Also set priority to 0 to allow override by anything */ sym_def->priority = 0; + flags |= RSPAMD_SYMBOL_FLAG_UNSCORED; } else { sym_def->priority = priority; @@ -1725,7 +1726,8 @@ rspamd_config_add_symbol (struct rspamd_config *cfg, } } - if (sym_def->priority > priority) { + if (sym_def->priority > priority && + (isnan(score) || !(sym_def->flags & RSPAMD_SYMBOL_FLAG_UNSCORED))) { msg_debug_config ("symbol %s has been already registered with " "priority %ud, do not override (new priority: %ud)", symbol, @@ -1759,6 +1761,7 @@ rspamd_config_add_symbol (struct rspamd_config *cfg, *sym_def->weight_ptr = score; sym_def->score = score; sym_def->priority = priority; + sym_def->flags &= ~RSPAMD_SYMBOL_FLAG_UNSCORED; } sym_def->flags = flags; diff --git a/src/lua/lua_config.c b/src/lua/lua_config.c index 8afe8fbfe..fbaadd8bb 100644 --- a/src/lua/lua_config.c +++ b/src/lua/lua_config.c @@ -2049,7 +2049,7 @@ lua_config_register_symbol (lua_State * L) } else { rspamd_config_add_symbol (cfg, name, - 0.0, description, group, flags, + NAN, description, group, flags, 0, nshots); } @@ -2314,7 +2314,7 @@ lua_config_set_metric_symbol (lua_State * L) struct rspamd_config *cfg = lua_check_config (L, 1); const gchar *description = NULL, *group = NULL, *name = NULL, *flags_str = NULL; - double weight; + double score; gboolean one_shot = FALSE, one_param = FALSE; GError *err = NULL; gdouble priority = 0.0; @@ -2329,7 +2329,7 @@ lua_config_set_metric_symbol (lua_State * L) "*name=S;score=N;description=S;" "group=S;one_shot=B;one_param=B;priority=N;flags=S;" "nshots=I", - &name, &weight, &description, + &name, &score, &description, &group, &one_shot, &one_param, &priority, &flags_str, &nshots)) { msg_err_config ("bad arguments: %e", err); @@ -2340,7 +2340,7 @@ lua_config_set_metric_symbol (lua_State * L) } else { name = luaL_checkstring (L, 2); - weight = luaL_checknumber (L, 3); + score = luaL_checknumber (L, 3); if (lua_gettop (L) > 3 && lua_type (L, 4) == LUA_TSTRING) { description = luaL_checkstring (L, 4); @@ -2380,7 +2380,7 @@ lua_config_set_metric_symbol (lua_State * L) } rspamd_config_add_symbol (cfg, name, - weight, description, group, flags, (guint) priority, nshots); + score, description, group, flags, (guint) priority, nshots); if (lua_type (L, 2) == LUA_TTABLE) { @@ -2786,7 +2786,8 @@ lua_config_newindex (lua_State *L) * Now check if a symbol has not been registered in any metric and * insert default value if applicable */ - if (g_hash_table_lookup (cfg->symbols, name) == NULL) { + struct rspamd_symbol *sym = g_hash_table_lookup (cfg->symbols, name); + if (sym == NULL || (sym->flags & RSPAMD_SYMBOL_FLAG_UNSCORED)) { nshots = cfg->default_max_shots; lua_pushstring (L, "score"); @@ -2794,6 +2795,10 @@ lua_config_newindex (lua_State *L) if (lua_type (L, -1) == LUA_TNUMBER) { score = lua_tonumber (L, -1); + if (sym) { + /* Reset unscored flag */ + sym->flags &= ~RSPAMD_SYMBOL_FLAG_UNSCORED; + } } lua_pop (L, 1); @@ -2843,7 +2848,7 @@ lua_config_newindex (lua_State *L) } else if (group) { /* Add with zero score */ - rspamd_config_add_symbol (cfg, name, 0.0, + rspamd_config_add_symbol (cfg, name, NAN, description, group, flags, 0, nshots); } |