diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-01-11 14:36:57 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-01-11 14:36:57 +0000 |
commit | f3e06973f09e495af2eebadbc1d18c893a69f029 (patch) | |
tree | d2b02a8637e917dba9ff82bf9265d8a52bc038ba | |
parent | 065ce9d2bb8a997c27dc9a109a35658966b0094f (diff) | |
download | rspamd-f3e06973f09e495af2eebadbc1d18c893a69f029.tar.gz rspamd-f3e06973f09e495af2eebadbc1d18c893a69f029.zip |
[Minor] Rbl: Fix resolve ip options insertion
-rw-r--r-- | src/plugins/lua/rbl.lua | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/src/plugins/lua/rbl.lua b/src/plugins/lua/rbl.lua index 521e63708..f1bd88047 100644 --- a/src/plugins/lua/rbl.lua +++ b/src/plugins/lua/rbl.lua @@ -324,16 +324,21 @@ local function gen_rbl_callback(rule) if requests_table[req] then -- Duplicate request - if forced and not requests_table[req].forced then - requests_table[req].forced = true + local nreq = requests_table[req] + if forced and not nreq.forced then + nreq.forced = true end + + return true,nreq -- Duplicate else + local nreq + local resolve_ip = rule.resolve_ip and not is_ip if rule.process_script then local processed = rule.process_script(req, rule.rbl, task, resolve_ip) if processed then - local nreq = { + nreq = { forced = forced, n = processed, orig = req_str, @@ -356,7 +361,7 @@ local function gen_rbl_callback(rule) to_resolve = orign end - local nreq = { + nreq = { forced = forced, n = to_resolve, orig = req_str, @@ -365,7 +370,7 @@ local function gen_rbl_callback(rule) } requests_table[req] = nreq end - + return false, nreq end end @@ -712,15 +717,19 @@ local function gen_rbl_callback(rule) local nresolved = 0 -- This is called when doing resolve_ip phase... - local function gen_rbl_ip_dns_callback(_) + local function gen_rbl_ip_dns_callback(orig_resolve_table_elt) return function(_, _, results, err) if not err then for _,dns_res in ipairs(results) do -- Check if we have rspamd{ip} userdata if type(dns_res) == 'userdata' then -- Add result as an actual RBL request - add_dns_request(task, dns_res, false, true, - resolved_req) + local dup,nreq = add_dns_request(task, dns_res, false, true, + resolved_req, orig_resolve_table_elt.what) + -- Add original name + if not dup then + nreq.orig = nreq.orig .. ':' .. orig_resolve_table_elt.n + end end end end @@ -759,7 +768,7 @@ local function gen_rbl_callback(rule) if r:resolve_a({ task = task, name = req.n, - callback = gen_rbl_ip_dns_callback(req.orig), + callback = gen_rbl_ip_dns_callback(req), forced = req.forced }) then nresolved = nresolved + 1 |