aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-11-05 13:13:59 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-11-05 13:13:59 +0000
commitb9d38aa0978e89c981d9d12785b51c6b01b42a88 (patch)
treeca7eef87ef7685c80ea2d87d52f90c64a60c0fbe /src/libserver
parent5b8fcdbc7947633efbfce1f461da3379d8ff6de8 (diff)
downloadrspamd-b9d38aa0978e89c981d9d12785b51c6b01b42a88.tar.gz
rspamd-b9d38aa0978e89c981d9d12785b51c6b01b42a88.zip
[Fix] Deal with unknown weight
Diffstat (limited to 'src/libserver')
-rw-r--r--src/libserver/cfg_file.h2
-rw-r--r--src/libserver/symbols_cache.c9
2 files changed, 6 insertions, 5 deletions
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h
index 412cd4bb0..f724a82c8 100644
--- a/src/libserver/cfg_file.h
+++ b/src/libserver/cfg_file.h
@@ -279,8 +279,6 @@ struct rspamd_config {
#ifdef WITH_GPERF_TOOLS
gchar *profile_path;
#endif
-
- gboolean accept_unknown_symbols; /**< if true unknown symbols are registered here */
gdouble unknown_weight; /**< weight of unknown symbols */
gdouble grow_factor; /**< grow factor for metric */
GHashTable *symbols; /**< weights of symbols in metric */
diff --git a/src/libserver/symbols_cache.c b/src/libserver/symbols_cache.c
index 9b8fba25b..719f8aabd 100644
--- a/src/libserver/symbols_cache.c
+++ b/src/libserver/symbols_cache.c
@@ -1030,7 +1030,7 @@ rspamd_symbols_cache_validate_cb (gpointer k, gpointer v, gpointer ud)
(SYMBOL_TYPE_NORMAL|SYMBOL_TYPE_VIRTUAL|SYMBOL_TYPE_COMPOSITE|SYMBOL_TYPE_CLASSIFIER))
&& g_hash_table_lookup (cfg->symbols, item->symbol) == NULL) {
- if (cfg->accept_unknown_symbols) {
+ if (cfg->unknown_weight != 0) {
skipped = FALSE;
item->st->weight = cfg->unknown_weight;
@@ -1043,14 +1043,17 @@ rspamd_symbols_cache_validate_cb (gpointer k, gpointer v, gpointer ud)
msg_info_cache ("adding unknown symbol %s", item->symbol);
ghost = FALSE;
}
+ else {
+ skipped = TRUE;
+ }
}
else {
skipped = FALSE;
}
- if (skipped) {
+ if (!ghost && skipped) {
item->type |= SYMBOL_TYPE_SKIPPED;
- msg_warn_cache ("symbol %s is not registered in any metric, so skip its check",
+ msg_warn_cache ("symbol %s has no score registered, skip its check",
item->symbol);
}