summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-07-08 09:12:37 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-07-08 09:12:37 +0100
commitfbba0f6ef1a262fe3c43c538cfe0abb531c4910c (patch)
tree824c185478d07951007b318ea149d4e372792762
parenta1af120934a908292544b7848b3e62da0e8b9030 (diff)
downloadrspamd-fbba0f6ef1a262fe3c43c538cfe0abb531c4910c.tar.gz
rspamd-fbba0f6ef1a262fe3c43c538cfe0abb531c4910c.zip
[Minor] Neural: More fixes
-rw-r--r--src/plugins/lua/neural.lua29
1 files changed, 16 insertions, 13 deletions
diff --git a/src/plugins/lua/neural.lua b/src/plugins/lua/neural.lua
index b0f307803..10c1eadd4 100644
--- a/src/plugins/lua/neural.lua
+++ b/src/plugins/lua/neural.lua
@@ -271,8 +271,8 @@ local function new_ann_profile(task, rule, set, version)
local function add_cb(err, _)
if err then
- rspamd_logger.errx(task, 'cannot check if we can train %s:%s : %s',
- rule.prefix, set.name, err)
+ rspamd_logger.errx(task, 'cannot store ANN profile for %s:%s at %s : %s',
+ rule.prefix, set.name, profile.redis_key, err)
else
rspamd_logger.infox(task, 'created new ANN profile for %s:%s, data stored at prefix %s',
rule.prefix, set.name, profile.redis_key)
@@ -285,7 +285,7 @@ local function new_ann_profile(task, rule, set, version)
true, -- is write
add_cb, --callback
'ZADD', -- command
- {set.prefix, profile_serialized, tostring(rspamd_util.get_time())}
+ {set.prefix, tostring(rspamd_util.get_time()), new_ann_profile}
)
return profile
@@ -785,7 +785,7 @@ local function load_new_ann(rule, ev_base, set, profile, min_diff)
true, -- is write
rank_cb, --callback
'ZADD', -- command
- {set.prefix, profile_serialized, tostring(rspamd_util.get_time())}
+ {set.prefix, tostring(rspamd_util.get_time()), new_ann_profile}
)
rspamd_logger.infox(rspamd_config, 'loaded ANN for %s from %s; %s bytes compressed; version=%s',
rule.prefix .. ':' .. set.name, ann_key, #ann_data, profile.version)
@@ -1009,10 +1009,10 @@ local function ann_push_vector(task)
if not settings.allow_local and lua_util.is_rspamc_or_controller(task) then return end
local verdict,score = lua_util.get_task_verdict(task)
for _,rule in pairs(settings.rules) do
- local sid = task:get_settings_id() or -1
+ local set = get_rule_settings(task, rule)
- if rule.settings[sid] then
- ann_push_task_result(rule, task, verdict, score, rule.settings[sid])
+ if set then
+ ann_push_task_result(rule, task, verdict, score, set)
end
end
@@ -1085,12 +1085,15 @@ local function process_rules_settings()
process_settings_elt(rule, nelt)
for id,ex in pairs(rule.settings) do
- if lua_util.distance_sorted(ex.symbols, nelt.symbols) == 0 then
- -- Equal symbols, add reference
- lua_util.debugm(N, rspamd_config, 'added reference from settings id %s to %s; same symbols',
- nelt.name, ex.name)
- rule.settings[s] = id
- nelt = nil
+ if type(ex) == 'table' then
+ if lua_util.distance_sorted(ex.symbols, nelt.symbols) == 0 then
+ -- Equal symbols, add reference
+ lua_util.debugm(N, rspamd_config,
+ 'added reference from settings id %s to %s; same symbols',
+ nelt.name, ex.name)
+ rule.settings[s] = id
+ nelt = nil
+ end
end
end