summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-03-31 13:28:34 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-03-31 13:28:34 +0100
commitd3969bfefd8939047d0863af99301737d92e090a (patch)
treea9f8c42c77bc983147367f6c76b3faa246ecffda
parent69afd99f549e49252c36f6d3d08d992b1a8a8e56 (diff)
downloadrspamd-d3969bfefd8939047d0863af99301737d92e090a.tar.gz
rspamd-d3969bfefd8939047d0863af99301737d92e090a.zip
[Fix] Remove slow and unused rules `INVALID_EXIM_RECEIVED*`
-rw-r--r--conf/metrics.conf10
-rw-r--r--rules/regexp/headers.lua64
2 files changed, 1 insertions, 73 deletions
diff --git a/conf/metrics.conf b/conf/metrics.conf
index fc5eeb8f5..69f378a12 100644
--- a/conf/metrics.conf
+++ b/conf/metrics.conf
@@ -348,16 +348,6 @@ metric {
description = "Invalid Postfix Received";
name = "INVALID_POSTFIX_RECEIVED";
}
- symbol {
- weight = 5.0;
- description = "Invalid Exim Received";
- name = "INVALID_EXIM_RECEIVED";
- }
- symbol {
- weight = 3.0;
- description = "Invalid Exim Received";
- name = "INVALID_EXIM_RECEIVED2";
- }
}
group {
diff --git a/rules/regexp/headers.lua b/rules/regexp/headers.lua
index 437710163..4717b785f 100644
--- a/rules/regexp/headers.lua
+++ b/rules/regexp/headers.lua
@@ -432,68 +432,6 @@ reconf['FORGED_GENERIC_RECEIVED3'] = 'Received=/^\\s*(.+\\n)*by \\d{1,3}\\.\\d{1
reconf['FORGED_GENERIC_RECEIVED4'] = 'Received=/^\\s*(.+\\n)*from localhost by \\S+;\\s+\\w{3}, \\d+ \\w{3} 20\\d\\d \\d\\d\\:\\d\\d\\:\\d\\d [+-]\\d\\d\\d0[\\s\\r\\n]*$/X'
-rspamd_config.FORGED_GENERIC_RECEIVED5 = function (task)
- local regexp_text = '^\\s*from \\[(\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3})\\].*\\n(.+\\n)*\\s*from \\1 by \\S+;\\s+\\w{3}, \\d+ \\w{3} 20\\d\\d \\d\\d\\:\\d\\d\\:\\d\\d [+-]\\d\\d\\d0$'
- local re = rspamd_regexp.create_cached(regexp_text, 'i')
- local headers_recv = task:get_header_full('Received')
- if headers_recv then
- for _,header_r in ipairs(headers_recv) do
- if re:match(header_r['value']) then
- return true
- end
- end
- end
- return false
-end
+reconf['FORGED_GENERIC_RECEIVED5'] = 'Received=\\s*from \\[(\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3})\\].*\\n(.+\\n)*\\s*from \\1 by \\S+;\\s+\\w{3}, \\d+ \\w{3} 20\\d\\d \\d\\d\\:\\d\\d\\:\\d\\d [+-]\\d\\d\\d0$/X'
reconf['INVALID_POSTFIX_RECEIVED'] = 'Received=/ \\(Postfix\\) with ESMTP id [A-Z\\d]+([\\s\\r\\n]+for <\\S+?>)?;[\\s\\r\\n]*[A-Z][a-z]{2}, \\d{1,2} [A-Z][a-z]{2} \\d\\d\\d\\d \\d\\d:\\d\\d:\\d\\d [\\+\\-]\\d\\d\\d\\d$/X'
-
-rspamd_config.INVALID_EXIM_RECEIVED = function (task)
- local checked = 0
- local headers_to = task:get_header_full('To')
- if headers_to then
- local headers_recv = task:get_header_full('Received')
- local regexp_text = '^[^\\n]*?<?\\S+?\\@(\\S+)>?\\|.*from \\d+\\.\\d+\\.\\d+\\.\\d+ \\(HELO \\S+\\)[\\s\\r\\n]*by \\1 with esmtp \\(\\S*?[\\?\\@\\(\\)\\s\\.\\+\\*\'\'\\/\\\\,]\\S*\\)[\\s\\r\\n]+id \\S*?[\\)\\(<>\\/\\\\,\\-:=]'
- local re = rspamd_regexp.create_cached(regexp_text, 's')
- if headers_recv then
- for _,header_to in ipairs(headers_to) do
- for _,header_r in ipairs(headers_recv) do
- if re:match(header_to['value'].."|"..header_r['value']) then
- return true
- end
- end
- checked = checked + 1
- if checked > 5 then
- -- Stop on 5 rcpt
- return false
- end
- end
- end
- end
- return false
-end
-
-rspamd_config.INVALID_EXIM_RECEIVED2 = function (task)
- local checked = 0
- local headers_to = task:get_header_full('To')
- if headers_to then
- local headers_recv = task:get_header_full('Received')
- local regexp_text = '^[^\\n]*?<?\\S+?\\@(\\S+)>?\\|.*from \\d+\\.\\d+\\.\\d+\\.\\d+ \\(HELO \\S+\\)[\\s\\r\\n]*by \\1 with esmtp \\([A-Z]{9,12} [A-Z]{5,6}\\)[\\s\\r\\n]+id [a-zA-Z\\d]{6}-[a-zA-Z\\d]{6}-[a-zA-Z\\d]{2}[\\s\\r\\n]+'
- local re = rspamd_regexp.create_cached(regexp_text, 's')
- if headers_recv then
- for _,header_to in ipairs(headers_to) do
- for _,header_r in ipairs(headers_recv) do
- if re:match(header_to['value'].."|"..header_r['value']) then
- return true
- end
- end
- checked = checked + 1
- if checked > 5 then
- -- Stop on 5 rcpt
- return false
- end
- end
- end
- end
- return false
-end