diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-08-17 16:17:45 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-08-17 16:17:45 +0100 |
commit | 59b33944544ab47404bf72448bfc89ddc78991fe (patch) | |
tree | d7b6c6bdfb96739266588555506c0fa8a42431a8 | |
parent | bd4ce0b8093c0b49c841ffdf43e72570dc70ca33 (diff) | |
download | rspamd-59b33944544ab47404bf72448bfc89ddc78991fe.tar.gz rspamd-59b33944544ab47404bf72448bfc89ddc78991fe.zip |
Rework symbols adding.
Now if no metric defines a symbol (explicitly or implicitly by means of
`unknown_weight` attribute), this symbol is skipped completely.
-rw-r--r-- | src/libserver/symbols_cache.c | 84 |
1 files changed, 42 insertions, 42 deletions
diff --git a/src/libserver/symbols_cache.c b/src/libserver/symbols_cache.c index 75862b3b7..185b1e105 100644 --- a/src/libserver/symbols_cache.c +++ b/src/libserver/symbols_cache.c @@ -298,8 +298,10 @@ register_symbol_common (struct symbols_cache **cache, { struct cache_item *item = NULL; struct symbols_cache *pcache = *cache; - GList **target; + GList **target, *cur; + struct metric *m; double *w; + gboolean skipped; if (*cache == NULL) { pcache = g_new0 (struct symbols_cache, 1); @@ -342,6 +344,44 @@ register_symbol_common (struct symbols_cache **cache, item->s->weight = weight; } + /* Check whether this item is skipped */ + skipped = TRUE; + if (!item->is_callback && + g_hash_table_lookup (pcache->cfg->metrics_symbols, name) == NULL) { + cur = g_list_first (pcache->cfg->metrics_list); + while (cur) { + m = cur->data; + + if (m->accept_unknown_symbols) { + GList *mlist; + + skipped = FALSE; + + item->s->weight = weight * (m->unknown_weight); + g_hash_table_insert (m->symbols, item->s->symbol, + &item->s->weight); + mlist = g_hash_table_lookup (pcache->cfg->metrics_symbols, name); + mlist = g_list_prepend (mlist, m); + g_hash_table_insert (pcache->cfg->metrics_symbols, + item->s->symbol, mlist); + + msg_info ("adding unknown symbol %s to metric %s", name, + m->name); + } + + cur = g_list_next (cur); + } + } + else { + skipped = FALSE; + } + + item->is_skipped = skipped; + if (skipped) { + msg_warn ("symbol %s is not registered in any metric, so skip its check", + name); + } + /* If we have undefined priority determine list according to weight */ if (priority == 0) { if (item->s->weight > 0) { @@ -887,46 +927,6 @@ validate_cache (struct symbols_cache *cache, msg_err ("empty cache is invalid"); return FALSE; } - - /* Check each symbol in a cache and find its weight definition */ - cur = cache->negative_items; - while (cur) { - item = cur->data; - if (!item->is_callback) { - if (g_hash_table_lookup (cfg->metrics_symbols, - item->s->symbol) == NULL) { - if (strict) { - msg_warn ("no weight registered for symbol %s", - item->s->symbol); - return FALSE; - } - else { - msg_info ("no weight registered for symbol %s", - item->s->symbol); - } - } - } - cur = g_list_next (cur); - } - cur = cache->static_items; - while (cur) { - item = cur->data; - if (!item->is_callback) { - if (g_hash_table_lookup (cfg->metrics_symbols, - item->s->symbol) == NULL) { - if (strict) { - msg_warn ("no weight registered for symbol %s", - item->s->symbol); - return FALSE; - } - else { - msg_info ("no weight registered for symbol %s", - item->s->symbol); - } - } - } - cur = g_list_next (cur); - } #ifndef GLIB_HASH_COMPAT /* Now check each metric item and find corresponding symbol in a cache */ metric_symbols = g_hash_table_get_keys (cfg->metrics_symbols); @@ -1163,7 +1163,7 @@ call_symbol_callback (struct rspamd_task * task, if (!item) { return FALSE; } - if (!item->is_virtual) { + if (!item->is_virtual && !item->is_skipped) { #ifdef HAVE_CLOCK_GETTIME # ifdef HAVE_CLOCK_PROCESS_CPUTIME_ID clock_gettime (CLOCK_PROCESS_CPUTIME_ID, &ts1); |