diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-25 11:37:36 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-25 11:37:36 +0000 |
commit | 7ded13ccab5f69a11fbbe683cd199c787ba351e5 (patch) | |
tree | d1cd89659fd81a630585aec7359e3683f79de7ad /rules | |
parent | 550bc44b90f33e476d85e2df922d7b05ed1733ad (diff) | |
download | rspamd-7ded13ccab5f69a11fbbe683cd199c787ba351e5.tar.gz rspamd-7ded13ccab5f69a11fbbe683cd199c787ba351e5.zip |
Add parsing to MDN rules
Issue: #480
Diffstat (limited to 'rules')
-rw-r--r-- | rules/misc.lua | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/rules/misc.lua b/rules/misc.lua index e49603278..e71c9b957 100644 --- a/rules/misc.lua +++ b/rules/misc.lua @@ -150,10 +150,16 @@ rspamd_config.BROKEN_HEADERS = { rspamd_config.HEADER_RCONFIRM_MISMATCH = { callback = function (task) local header_from = task:get_from('mime')[1] - local header_cread = task:get_header('X-Confirm-Reading-To') + local cread = task:get_header('X-Confirm-Reading-To') + + local header_cread = nil + if cread then + local headers_cread = util.parse_mail_address(cread) + if headers_cread then header_cread = headers_cread[1] end + end if header_from and header_cread then - if not string.find(header_from, header_cread) then + if not string.find(header_from['addr'], header_cread['addr']) then return true end end @@ -168,13 +174,20 @@ rspamd_config.HEADER_RCONFIRM_MISMATCH = { rspamd_config.HEADER_FORGED_MDN = { callback = function (task) - local header_mdn = task:get_header('Disposition-Notification-To') + local mdn = task:get_header('Disposition-Notification-To') local header_rp = task:get_from('smtp')[1] + -- Parse mail addr + local header_mdn = nil + if mdn then + local headers_mdn = util.parse_mail_address(mdn) + if headers_mdn then header_mdn = headers_mdn[1] end + end + if header_mdn and not header_rp then return true end if header_rp and not header_mdn then return true end - if header_mdn ~= header_rp then + if header_mdn['addr'] ~= header_rp['addr'] then return true end |