summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-11-30 17:22:38 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-11-30 17:22:38 +0000
commit20f93d0f627de4539d22dc046b0ab2b88930c2e0 (patch)
tree0a5939e505e8e19da8c3351129c0de4ce8e36776
parentc6b841099c02972d4fdd5a07fe1e1fed6728f10c (diff)
downloadrspamd-20f93d0f627de4539d22dc046b0ab2b88930c2e0.tar.gz
rspamd-20f93d0f627de4539d22dc046b0ab2b88930c2e0.zip
[Project] Move dns_tool to using of the rspamd_spf from FFI module
-rw-r--r--lualib/rspamadm/dns_tool.lua54
1 files changed, 36 insertions, 18 deletions
diff --git a/lualib/rspamadm/dns_tool.lua b/lualib/rspamadm/dns_tool.lua
index cd512ab9a..a747e8aa7 100644
--- a/lualib/rspamadm/dns_tool.lua
+++ b/lualib/rspamadm/dns_tool.lua
@@ -17,7 +17,6 @@ limitations under the License.
local argparse = require "argparse"
local rspamd_logger = require "rspamd_logger"
-local lua_util = require "lua_util"
local ansicolors = require "ansicolors"
local parser = argparse()
@@ -84,14 +83,16 @@ local function load_config(opts)
end
local function spf_handler(opts)
- local lua_spf = require("lua_ffi").spf
+ local rspamd_spf = require "rspamd_spf"
local rspamd_task = require "rspamd_task"
+ local rspamd_ip = require "rspamd_ip"
local task = rspamd_task:create(rspamd_config, rspamadm_ev_base)
task:set_session(rspamadm_session)
task:set_resolver(rspamadm_dns_resolver)
if opts.ip then
+ opts.ip = rspamd_ip.fromstring(opts.ip)
task:set_from_ip(opts.ip)
end
@@ -106,41 +107,58 @@ local function spf_handler(opts)
local function display_spf_results(elt, colored)
local dec = function(e) return e end
+ local policy_decode = function(e)
+ if e == rspamd_spf.policy.fail then
+ return 'reject'
+ elseif e == rspamd_spf.policy.pass then
+ return 'pass'
+ elseif e == rspamd_spf.policy.soft_fail then
+ return 'soft fail'
+ elseif e == rspamd_spf.policy.neutral then
+ return 'neutral'
+ end
+
+ return 'unknown'
+ end
if colored then
dec = function(e) return highlight(e) end
- if elt.res == 'pass' then
+ if elt.result == rspamd_spf.policy.pass then
dec = function(e) return green(e) end
- elseif elt.res == 'fail' then
+ elseif elt.result == rspamd_spf.policy.fail then
dec = function(e) return red(e) end
end
end
- printf('%s: %s', highlight('Result'), dec(elt.res))
- printf('%s: %s', highlight('Network'), dec(elt.ipnet))
+ printf('%s: %s', highlight('Policy'), dec(policy_decode(elt.result)))
+ printf('%s: %s', highlight('Network'), dec(elt.addr))
- if elt.spf_str then
- printf('%s: %s', highlight('Original'), elt.spf_str)
+ if elt.str then
+ printf('%s: %s', highlight('Original'), elt.str)
end
end
- local function cb(success, res, matched)
- if success then
+ local function cb(record, flags, err)
+ if record then
+ local result, flag_or_policy, error_or_addr
+ if opts.ip then
+ result, flag_or_policy, error_or_addr = record:check_ip(opts.ip)
+ end
if opts.ip and not opts.all then
- if matched then
- display_spf_results(matched, true)
+ if result then
+ display_spf_results(error_or_addr, true)
else
- printf('Not matched')
+ printf('Not matched: %s', error_or_addr)
end
os.exit(0)
end
printf('SPF record for %s; digest: %s',
- highlight(opts.domain or opts.from), highlight(res.digest))
- for _,elt in ipairs(res.addrs) do
- if lua_util.table_cmp(elt, matched) then
+ highlight(opts.domain or opts.from), highlight(record:get_digest()))
+ for _,elt in ipairs(record:get_elts()) do
+ if result and error_or_addr and elt.str and elt.str == error_or_addr.str then
printf("%s", highlight('*** Matched ***'))
display_spf_results(elt, true)
printf('------')
@@ -150,10 +168,10 @@ local function spf_handler(opts)
end
end
else
- printf('Cannot get SPF record: %s', res)
+ printf('Cannot get SPF record: %s', err)
end
end
- lua_spf.spf_resolve(task, cb)
+ rspamd_spf.resolve(task, cb)
end
local function handler(args)