diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2013-11-24 21:43:20 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2013-11-24 21:43:20 +0000 |
commit | c3882406f1bdae1603aae312af22120cc5c261c0 (patch) | |
tree | 7fa9940e5b531dc38a25f70a919e69c1f5e91a6c /src/cfg_rcl.c | |
parent | 07af1f62a168ce57c2dc847873f7488cacfaaa6d (diff) | |
download | rspamd-c3882406f1bdae1603aae312af22120cc5c261c0.tar.gz rspamd-c3882406f1bdae1603aae312af22120cc5c261c0.zip |
Add guess euristic for spam attribute of statfile.
Diffstat (limited to 'src/cfg_rcl.c')
-rw-r--r-- | src/cfg_rcl.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/cfg_rcl.c b/src/cfg_rcl.c index af4fbda93..b78a75fd6 100644 --- a/src/cfg_rcl.c +++ b/src/cfg_rcl.c @@ -742,6 +742,7 @@ rspamd_rcl_statfile_handler (struct config_file *cfg, ucl_object_t *obj, } } + if (rspamd_rcl_section_parse_defaults (section, cfg, obj, st, err)) { ccf->statfiles = g_list_prepend (ccf->statfiles, st); if (st->label != NULL) { @@ -768,6 +769,22 @@ rspamd_rcl_statfile_handler (struct config_file *cfg, ucl_object_t *obj, st->opts = obj; + val = ucl_object_find_key (obj, "spam"); + if (val == NULL) { + msg_info ("statfile %s has no explicit 'spam' setting, trying to guess by symbol", st->symbol); + if (rspamd_strncasestr (st->symbol, "spam", strlen (st->symbol)) != NULL) { + st->is_spam = TRUE; + } + else if (rspamd_strncasestr (st->symbol, "ham", strlen (st->symbol)) != NULL) { + st->is_spam = FALSE; + } + else { + g_set_error (err, CFG_RCL_ERROR, EINVAL, "cannot guess spam setting from %s", st->symbol); + return FALSE; + } + msg_info ("guessed that statfile with symbol %s is %s", st->symbol, st->is_spam ? + "spam" : "ham"); + } return TRUE; } @@ -794,6 +811,9 @@ rspamd_rcl_classifier_handler (struct config_file *cfg, ucl_object_t *obj, if (g_ascii_strcasecmp (key, "statfile") == 0) { LL_FOREACH (val, cur) { res = rspamd_rcl_statfile_handler (cfg, cur, ccf, stat_section, err); + if (!res) { + return FALSE; + } } } else if (g_ascii_strcasecmp (key, "type") == 0 && val->type == UCL_STRING) { |