From b8132cfbab29d171ab3608161a6e64e881f205ec Mon Sep 17 00:00:00 2001 From: Vsevolod Stakhov Date: Mon, 8 Aug 2016 14:21:17 +0100 Subject: [Fix] Some more fixes for low contrast fonts detector --- rules/html.lua | 30 +++++++++++------------------- 1 file changed, 11 insertions(+), 19 deletions(-) (limited to 'rules') diff --git a/rules/html.lua b/rules/html.lua index 1c4c86cdc..68eca3010 100644 --- a/rules/html.lua +++ b/rules/html.lua @@ -171,7 +171,8 @@ rspamd_config.R_WHITE_ON_WHITE = { local ret = false local diff = 0.0 local normal_len = 0 - local transp_tags = {} + local transp_len = 0 + local arg for _,p in ipairs(tp) do -- iterate over text parts array using `ipairs` if p:is_html() then -- if the current part is html part @@ -191,7 +192,14 @@ rspamd_config.R_WHITE_ON_WHITE = { if diff < 0.2 then ret = true - table.insert(transp_tags, tag) + transp_len = (transp_len + tag:get_content_length()) * + (0.2 - diff) * 5.0 + if not arg then + arg = string.format('%s color #%x%x%x bgcolor #%x%x%x', + tostring(tag:get_type()), + color[1], color[2], color[3], + bgcolor[1], bgcolor[2], bgcolor[3]) + end else normal_len = normal_len + tag:get_content_length() end @@ -205,24 +213,8 @@ rspamd_config.R_WHITE_ON_WHITE = { end if ret then - local transp_len = 0 - local arg - - for _,t in ipairs(transp_tags) do - local bl = t:get_extra() - local color = bl['color'] - local bgcolor = bl['bgcolor'] - transp_len = transp_len + t:get_content_length() - - if not arg then - arg = string.format('%s color #%x%x%x bgcolor #%x%x%x', - tostring(t:get_type()), - color[1], color[2], color[3], - bgcolor[1], bgcolor[2], bgcolor[3]) - end - end - local transp_rate = transp_len / (normal_len + transp_len) + if transp_rate > 0.1 then return true,(transp_rate * 2.0),arg end -- cgit v1.2.3