aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-03-11 14:35:22 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-03-11 14:35:22 +0000
commit355526a8d1ad68e5badcd76da3ec4f63c501d15d (patch)
treecfad18d3810282e64c88ab5c1b99b327410543f1
parent84b8e138d21852d3650a4cebc3c0178da47c1545 (diff)
downloadrspamd-355526a8d1ad68e5badcd76da3ec4f63c501d15d.tar.gz
rspamd-355526a8d1ad68e5badcd76da3ec4f63c501d15d.zip
[Fix] RCPT_COUNT fixes
-rw-r--r--rules/headers_checks.lua88
-rw-r--r--rules/misc.lua2
2 files changed, 85 insertions, 5 deletions
diff --git a/rules/headers_checks.lua b/rules/headers_checks.lua
index a50edeb73..da48a8a1f 100644
--- a/rules/headers_checks.lua
+++ b/rules/headers_checks.lua
@@ -16,7 +16,10 @@ limitations under the License.
local util = require "rspamd_util"
local ipairs = ipairs
+local pairs = pairs
local table = table
+local tostring = tostring
+local tonumber = tonumber
local fun = require "fun"
local E = {}
@@ -682,13 +685,25 @@ local check_to_cc_id = rspamd_config:register_symbol{
local rcpts = task:get_recipients(1)
local to = task:get_recipients(2)
local to_match_envrcpt = 0
+ local cnts = {
+ [1] = 'ONE',
+ [2] = 'TWO',
+ [3] = 'THREE',
+ [5] = 'FIVE',
+ [7] = 'SEVEN',
+ [12] = 'TWELVE',
+ [50] = 'GT_50'
+ }
+ local def = 'ZERO'
if (not to) then return false end
-- Add symbol for recipient count
- if (#to > 50) then
- task:insert_result('RCPT_COUNT_GT_50', 1.0)
- else
- task:insert_result('RCPT_COUNT_' .. #to, 1.0)
+ local nrcpt = #to
+ for k,v in pairs(cnts) do
+ if nrcpt >= tonumber(k) then
+ def = v
+ end
end
+ task:insert_result('RCPT_COUNT_' .. def, 1.0, tostring(nrcpt))
-- Check for display names
local to_dn_count = 0
local to_dn_eq_addr_count = 0
@@ -737,6 +752,71 @@ local check_to_cc_id = rspamd_config:register_symbol{
}
rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_ZERO',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = 'No recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_ONE',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = 'One recipient',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_TWO',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = 'Two recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_THREE',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = '3-5 recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_FIVE',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = '5-7 recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_SEVEN',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = '7-11 recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_TWELVE',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = '12-50 recipients',
+ group = 'header',
+}
+rspamd_config:register_symbol{
+ name = 'RCPT_COUNT_GT_50',
+ score = 0.0,
+ parent = check_to_cc_id,
+ type = 'virtual',
+ description = '50+ recipients',
+ group = 'header',
+}
+
+rspamd_config:register_symbol{
name = 'TO_DN_RECIPIENTS',
score = 2.0,
group = 'header',
diff --git a/rules/misc.lua b/rules/misc.lua
index a9382f8f4..2c6d8899b 100644
--- a/rules/misc.lua
+++ b/rules/misc.lua
@@ -235,7 +235,7 @@ rspamd_config.URI_COUNT_ODD = {
if (ct and ct:lower():find('^multipart/alternative')) then
local urls = task:get_urls()
if (urls and (#urls % 2 == 1)) then
- return true
+ return true, 1.0, tostring(#urls % 2)
end
end
end,