aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2021-03-06 23:30:21 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2021-03-06 23:30:21 +0000
commit291131f98a0b80195202278a35f1eaace104af81 (patch)
tree79c40c8edf9f7b54ddbf2dd1f937d967ec80fb7e /src
parentfdb004b9ce1a64552421ce5dcf1a0da4796f08c5 (diff)
downloadrspamd-291131f98a0b80195202278a35f1eaace104af81.tar.gz
rspamd-291131f98a0b80195202278a35f1eaace104af81.zip
[Fix] Phishing: Rework urls processing
Diffstat (limited to 'src')
-rw-r--r--src/plugins/lua/phishing.lua27
1 files changed, 17 insertions, 10 deletions
diff --git a/src/plugins/lua/phishing.lua b/src/plugins/lua/phishing.lua
index d7384b4ff..805a65e20 100644
--- a/src/plugins/lua/phishing.lua
+++ b/src/plugins/lua/phishing.lua
@@ -181,10 +181,10 @@ local function phishing_cb(task)
end
end
- local urls = task:get_urls()
-
- if urls then
- for _,url in ipairs(urls) do
+ -- Process all urls
+ local urls = task:get_urls() or {}
+ for _,url in ipairs(urls) do
+ local function do_loop_iter() -- to emulate continue
if generic_service_hash then
check_phishing_map(generic_service_data, url, generic_service_symbol)
end
@@ -199,6 +199,11 @@ local function phishing_cb(task)
if url:is_phished() and not url:is_redirected() then
local purl = url:get_phished()
+
+ if not purl then
+ return
+ end
+
local tld = url:get_tld()
local ptld = purl:get_tld()
@@ -243,7 +248,7 @@ local function phishing_cb(task)
if a1 ~= a2 then
weight = 1
lua_util.debugm(N, task, "confusable: %1 -> %2: different characters",
- tld, ptld, why)
+ tld, ptld, why)
else
-- We have totally different strings in tld, so penalize it significantly
if dist > 2 then dist = 2 end
@@ -259,12 +264,12 @@ local function phishing_cb(task)
if not sweight then sweight = weight end
if #map > 0 then
for _,rule in ipairs(map) do
- for _,dn in ipairs({furl:get_tld(), furl:get_host()}) do
- if rule['map']:get_key(dn) then
- task:insert_result(rule['symbol'], sweight, ptld .. '->' .. dn)
- return true
- end
+ for _,dn in ipairs({furl:get_tld(), furl:get_host()}) do
+ if rule['map']:get_key(dn) then
+ task:insert_result(rule['symbol'], sweight, ptld .. '->' .. dn)
+ return true
end
+ end
end
end
end
@@ -282,6 +287,8 @@ local function phishing_cb(task)
end
end
end
+
+ do_loop_iter()
end
end