diff options
-rw-r--r-- | src/plugins/lua/multimap.lua | 173 | ||||
-rw-r--r-- | test/functional/cases/100_general.robot (renamed from test/functional/cases/general.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/101_lua.robot (renamed from test/functional/cases/lua.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/105_archives.robot (renamed from test/functional/cases/archives.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/compat-keyed.robot (renamed from test/functional/cases/statistics/compat-keyed.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/compat-plain.robot (renamed from test/functional/cases/statistics/compat-plain.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/lib.robot (renamed from test/functional/cases/statistics/lib.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/redis-keyed-siphash.robot (renamed from test/functional/cases/statistics/redis-keyed-siphash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/redis-keyed-xxhash.robot (renamed from test/functional/cases/statistics/redis-keyed-xxhash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/redis-plain-siphash.robot (renamed from test/functional/cases/statistics/redis-plain-siphash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/redis-plain-xxhash.robot (renamed from test/functional/cases/statistics/redis-plain-xxhash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/sqlite-broken-stats-dir.robot (renamed from test/functional/cases/statistics/sqlite-broken-stats-dir.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/sqlite-keyed-siphash.robot (renamed from test/functional/cases/statistics/sqlite-keyed-siphash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/sqlite-keyed-xxhash.robot (renamed from test/functional/cases/statistics/sqlite-keyed-xxhash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/sqlite-plain-siphash.robot (renamed from test/functional/cases/statistics/sqlite-plain-siphash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/110_statistics/sqlite-plain-xxhash.robot (renamed from test/functional/cases/statistics/sqlite-plain-xxhash.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/120_fuzzy/encrypted.robot (renamed from test/functional/cases/fuzzy/encrypted.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/120_fuzzy/lib.robot (renamed from test/functional/cases/fuzzy/lib.robot) | 0 | ||||
-rw-r--r-- | test/functional/cases/120_fuzzy/plain.robot (renamed from test/functional/cases/fuzzy/plain.robot) | 0 |
19 files changed, 61 insertions, 112 deletions
diff --git a/src/plugins/lua/multimap.lua b/src/plugins/lua/multimap.lua index 3851e26c4..d4fcee6e4 100644 --- a/src/plugins/lua/multimap.lua +++ b/src/plugins/lua/multimap.lua @@ -29,7 +29,9 @@ local function ip_to_rbl(ip, rbl) return table.concat(ip:inversed_str_octets(), ".") .. '.' .. rbl end -local function multimap_callback(task, pre_filter) +local function multimap_callback(task, rule) + local pre_filter = rule['prefilter'] + -- Applies specific filter for input local function apply_filter(filter, input, rule) if filter == 'email:addr' or filter == 'email' then @@ -345,97 +347,16 @@ local function multimap_callback(task, pre_filter) end end - -- IP rules - local ip = task:get_from_ip() - if ip:is_valid() then - each(function(r) match_rule(r, ip) end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'ip' - end, rules)) - end - - -- Header rules - each(function(r) - local hv = task:get_header_full(r['header']) - match_list(r, hv, {'decoded'}) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'header' - end, rules)) - - -- Rcpt rules - if task:has_recipients() then - local rcpts = task:get_recipients() - each(function(r) - match_addr(r, rcpts) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'rcpt' - end, rules)) - end - - -- From rules - if task:has_from() then - local from = task:get_from() - if from then - each(function(r) - match_addr(r, from) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'from' - end, rules)) - end - end - -- URL rules - if task:has_urls() then - local urls = task:get_urls() - for i,url in ipairs(urls) do - each(function(r) - match_url(r, url) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'url' - end, rules)) - end - end - -- Filename rules - local function check_file(fn) - each(function(r) - match_filename(r, fn) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'filename' - end, rules)) - end - -- Body rules - each(function(r) - match_content(r) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'content' - end, rules)) - - local parts = task:get_parts() - for i,p in ipairs(parts) do - if p:is_archive() then - local fnames = p:get_archive():get_files() - - for ii,fn in ipairs(fnames) do - check_file(fn) - end - end - - local fn = p:get_filename() - if fn then - check_file(fn) - end - end - -- RBL rules - if ip:is_valid() then - each(function(r) + local rt = rule['type'] + if rt == 'ip' or rt == 'dnsbl' then + local ip = task:get_from_ip() + if ip:is_valid() then + if rt == 'ip' then + match_rule(rule, ip) + else local cb = function (resolver, to_resolve, results, err, rbl) if results then - task:insert_result(r['symbol'], 1, r['map']) + task:insert_result(rule['symbol'], 1, r['map']) if pre_filter then task:set_pre_result(r['action'], 'Matched map: ' .. r['symbol']) @@ -444,22 +365,56 @@ local function multimap_callback(task, pre_filter) end task:get_resolver():resolve_a({task = task, - name = ip_to_rbl(ip, r['map']), + name = ip_to_rbl(ip, rule['map']), callback = cb, - }) - end, - filter(function(r) - return pre_filter == r['prefilter'] and r['type'] == 'dnsbl' - end, rules)) - end -end + }) + end + end + elseif rt == 'header' then + local hv = task:get_header_full(r['header']) + match_list(rule, hv, {'decoded'}) + elseif rt == 'rcpt' then + if task:has_recipients('smtp') then + local rcpts = task:get_recipients('smtp') + match_addr(rule, rcpts) + end + elseif rt == 'from' then + if task:has_from('smtp') then + local from = task:get_from('smtp') + match_addr(rule, from) + end + elseif rt == 'url' then + if task:has_urls() then + local urls = task:get_urls() + for i,url in ipairs(urls) do + match_url(rule, url) + end + end + elseif rt == 'filename' then + local parts = task:get_parts() + for i,p in ipairs(parts) do + if p:is_archive() then + local fnames = p:get_archive():get_files() + + for ii,fn in ipairs(fnames) do + match_filename(rule, fn) + end + end -local function multimap_filter_callback(task) - multimap_callback(task, false) + local fn = p:get_filename() + if fn then + match_filename(rule, fn) + end + end + elseif rt == 'content' then + match_content(rule) + end end -local function multimap_prefilter_callback(task) - multimap_callback(task, true) +local function gen_multimap_callback(rule) + return function(task) + multimap_callback(task, rule) + end end local function add_multimap_rule(key, newrule) @@ -587,17 +542,11 @@ if opts and type(opts) == 'table' then end -- add fake symbol to check all maps inside a single callback if any(function(r) return not r['prefilter'] end, rules) then - local id = rspamd_config:register_symbol({ - type = 'callback', - priority = -1, - callback = multimap_filter_callback, - flags = 'empty' - }) for i,rule in ipairs(rules) do rspamd_config:register_symbol({ - type = 'virtual', + type = 'normal', name = rule['symbol'], - parent = id, + callback = gen_multimap_callback(rule), }) end end @@ -605,8 +554,8 @@ if opts and type(opts) == 'table' then if any(function(r) return r['prefilter'] end, rules) then rspamd_config:register_symbol({ type = 'prefilter', - name = 'MULTIMAP_PREFILTERS', - callback = multimap_prefilter_callback + name = rule['symbol'], + callback = gen_multimap_callback(rule), }) end end diff --git a/test/functional/cases/general.robot b/test/functional/cases/100_general.robot index 8876ef980..8876ef980 100644 --- a/test/functional/cases/general.robot +++ b/test/functional/cases/100_general.robot diff --git a/test/functional/cases/lua.robot b/test/functional/cases/101_lua.robot index 5e5dff6c8..5e5dff6c8 100644 --- a/test/functional/cases/lua.robot +++ b/test/functional/cases/101_lua.robot diff --git a/test/functional/cases/archives.robot b/test/functional/cases/105_archives.robot index 16a14bfda..16a14bfda 100644 --- a/test/functional/cases/archives.robot +++ b/test/functional/cases/105_archives.robot diff --git a/test/functional/cases/statistics/compat-keyed.robot b/test/functional/cases/110_statistics/compat-keyed.robot index 1242df12c..1242df12c 100644 --- a/test/functional/cases/statistics/compat-keyed.robot +++ b/test/functional/cases/110_statistics/compat-keyed.robot diff --git a/test/functional/cases/statistics/compat-plain.robot b/test/functional/cases/110_statistics/compat-plain.robot index 12bbaedcd..12bbaedcd 100644 --- a/test/functional/cases/statistics/compat-plain.robot +++ b/test/functional/cases/110_statistics/compat-plain.robot diff --git a/test/functional/cases/statistics/lib.robot b/test/functional/cases/110_statistics/lib.robot index 5f9e96038..5f9e96038 100644 --- a/test/functional/cases/statistics/lib.robot +++ b/test/functional/cases/110_statistics/lib.robot diff --git a/test/functional/cases/statistics/redis-keyed-siphash.robot b/test/functional/cases/110_statistics/redis-keyed-siphash.robot index ec95efcd1..ec95efcd1 100644 --- a/test/functional/cases/statistics/redis-keyed-siphash.robot +++ b/test/functional/cases/110_statistics/redis-keyed-siphash.robot diff --git a/test/functional/cases/statistics/redis-keyed-xxhash.robot b/test/functional/cases/110_statistics/redis-keyed-xxhash.robot index 5a7b2daf3..5a7b2daf3 100644 --- a/test/functional/cases/statistics/redis-keyed-xxhash.robot +++ b/test/functional/cases/110_statistics/redis-keyed-xxhash.robot diff --git a/test/functional/cases/statistics/redis-plain-siphash.robot b/test/functional/cases/110_statistics/redis-plain-siphash.robot index d436b1a68..d436b1a68 100644 --- a/test/functional/cases/statistics/redis-plain-siphash.robot +++ b/test/functional/cases/110_statistics/redis-plain-siphash.robot diff --git a/test/functional/cases/statistics/redis-plain-xxhash.robot b/test/functional/cases/110_statistics/redis-plain-xxhash.robot index 0c45ac16b..0c45ac16b 100644 --- a/test/functional/cases/statistics/redis-plain-xxhash.robot +++ b/test/functional/cases/110_statistics/redis-plain-xxhash.robot diff --git a/test/functional/cases/statistics/sqlite-broken-stats-dir.robot b/test/functional/cases/110_statistics/sqlite-broken-stats-dir.robot index 57d75c294..57d75c294 100644 --- a/test/functional/cases/statistics/sqlite-broken-stats-dir.robot +++ b/test/functional/cases/110_statistics/sqlite-broken-stats-dir.robot diff --git a/test/functional/cases/statistics/sqlite-keyed-siphash.robot b/test/functional/cases/110_statistics/sqlite-keyed-siphash.robot index 8b9661a9a..8b9661a9a 100644 --- a/test/functional/cases/statistics/sqlite-keyed-siphash.robot +++ b/test/functional/cases/110_statistics/sqlite-keyed-siphash.robot diff --git a/test/functional/cases/statistics/sqlite-keyed-xxhash.robot b/test/functional/cases/110_statistics/sqlite-keyed-xxhash.robot index 7a51e93ae..7a51e93ae 100644 --- a/test/functional/cases/statistics/sqlite-keyed-xxhash.robot +++ b/test/functional/cases/110_statistics/sqlite-keyed-xxhash.robot diff --git a/test/functional/cases/statistics/sqlite-plain-siphash.robot b/test/functional/cases/110_statistics/sqlite-plain-siphash.robot index 2f88e0a95..2f88e0a95 100644 --- a/test/functional/cases/statistics/sqlite-plain-siphash.robot +++ b/test/functional/cases/110_statistics/sqlite-plain-siphash.robot diff --git a/test/functional/cases/statistics/sqlite-plain-xxhash.robot b/test/functional/cases/110_statistics/sqlite-plain-xxhash.robot index dd8198222..dd8198222 100644 --- a/test/functional/cases/statistics/sqlite-plain-xxhash.robot +++ b/test/functional/cases/110_statistics/sqlite-plain-xxhash.robot diff --git a/test/functional/cases/fuzzy/encrypted.robot b/test/functional/cases/120_fuzzy/encrypted.robot index 45408d7f8..45408d7f8 100644 --- a/test/functional/cases/fuzzy/encrypted.robot +++ b/test/functional/cases/120_fuzzy/encrypted.robot diff --git a/test/functional/cases/fuzzy/lib.robot b/test/functional/cases/120_fuzzy/lib.robot index e5e9cbcb7..e5e9cbcb7 100644 --- a/test/functional/cases/fuzzy/lib.robot +++ b/test/functional/cases/120_fuzzy/lib.robot diff --git a/test/functional/cases/fuzzy/plain.robot b/test/functional/cases/120_fuzzy/plain.robot index 2fc2fd5ef..2fc2fd5ef 100644 --- a/test/functional/cases/fuzzy/plain.robot +++ b/test/functional/cases/120_fuzzy/plain.robot |