diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-13 17:14:45 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-13 17:14:45 +0000 |
commit | e99a2a605b28fb194e993b96977890237f0d5d39 (patch) | |
tree | e5aeb30487722449e937a50e1c5737140376e1b0 | |
parent | f1d528aafbd690b95a23b684ba0be69f3c5f781c (diff) | |
download | rspamd-e99a2a605b28fb194e993b96977890237f0d5d39.tar.gz rspamd-e99a2a605b28fb194e993b96977890237f0d5d39.zip |
Add support for check_for_shifted_date and check_for_missing_to_header eval rules to SA plugin
-rw-r--r-- | src/plugins/lua/spamassassin.lua | 60 |
1 files changed, 54 insertions, 6 deletions
diff --git a/src/plugins/lua/spamassassin.lua b/src/plugins/lua/spamassassin.lua index 53a1fc6cf..f766c8fb9 100644 --- a/src/plugins/lua/spamassassin.lua +++ b/src/plugins/lua/spamassassin.lua @@ -59,6 +59,9 @@ local replace = { post = {}, rules = {}, } +local internal_regexp = { + date_shift = rspamd_regexp.create_cached("^\\(\\s*'((?:-?\\d+)|(?:undef))'\\s*,\\s*'((?:-?\\d+)|(?:undef))'\\s*\\)$") +} local section = rspamd_config:get_all_opt("spamassassin") -- Minimum score to treat symbols as meta @@ -213,25 +216,70 @@ local function gen_eval_rule(arg) return 0 end end - + return hdr_freemail end end - - return 0 + + return 0 + end + }, + { + 'check_for_missing_to_header', + function (task, remain) + if not task:get_from(1) then + return 1 + end + + return 0 + end + }, + { + 'check_for_shifted_date', + function (task, remain) + -- Remain here contains two args: start and end hours shift + local matches = internal_regexp['date_shift']:search(remain, true, true) + if matches and matches[1] then + local min_diff = matches[1][2] + local max_diff = matches[1][3] + + if min_diff == 'undef' then + min_diff = 0 + else + min_diff = tonumber(min_diff) * 3600 + end + if max_diff == 'undef' then + max_diff = 0 + else + max_diff = tonumber(max_diff) * 3600 + end + + -- Now get the difference between Date and message received date + local dm = task:get_date { format = 'message', gmt = true} + local dt = task:get_date { format = 'connect', gmt = true} + local diff = dm - dt + + if (max_diff == 0 and diff >= min_diff) or + (min_diff == 0 and diff <= max_diff) or + (diff >= min_diff and diff <= max_diff) then + return 1 + end + end + + return 0 end }, } - + for k,f in ipairs(eval_funcs) do local pat = string.format('^%s', f[1]) local first,last = string.find(arg, pat) - + if first then local func_arg = string.sub(arg, last + 1) return function(task) return f[2](task, func_arg) - end + end end end end |