aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/plugins/lua/maillist.lua340
1 files changed, 170 insertions, 170 deletions
diff --git a/src/plugins/lua/maillist.lua b/src/plugins/lua/maillist.lua
index 243a04319..b5adacc79 100644
--- a/src/plugins/lua/maillist.lua
+++ b/src/plugins/lua/maillist.lua
@@ -36,36 +36,36 @@ local rspamd_logger = require "rspamd_logger"
-- List-Unsubscribe: <mailto:[a-zA-Z\.-]+-unsubscribe@
-- List-Subscribe: <mailto:[a-zA-Z\.-]+-subscribe@
local function check_ml_ezmlm(task)
- -- Mailing-List
- local header = task:get_header('mailing-list')
- if not header or not string.find(header, 'ezmlm$') then
- return false
- end
- -- Precedence
- header = task:get_header('precedence')
- if not header or not string.match(header, '^bulk$') then
- return false
- end
- -- Other headers
- header = task:get_header('list-post')
- if not header or not string.find(header, '^<mailto:') then
- return false
- end
- header = task:get_header('list-help')
- if not header or not string.find(header, '^<mailto:') then
- return false
- end
- -- Subscribe and unsubscribe
- header = task:get_header('list-subscribe')
- if not header or not string.find(header, '<mailto:[a-zA-Z.-]+-subscribe@') then
- return false
- end
- header = task:get_header('list-unsubscribe')
- if not header or not string.find(header, '<mailto:[a-zA-Z.-]+-unsubscribe@') then
- return false
- end
+ -- Mailing-List
+ local header = task:get_header('mailing-list')
+ if not header or not string.find(header, 'ezmlm$') then
+ return false
+ end
+ -- Precedence
+ header = task:get_header('precedence')
+ if not header or not string.match(header, '^bulk$') then
+ return false
+ end
+ -- Other headers
+ header = task:get_header('list-post')
+ if not header or not string.find(header, '^<mailto:') then
+ return false
+ end
+ header = task:get_header('list-help')
+ if not header or not string.find(header, '^<mailto:') then
+ return false
+ end
+ -- Subscribe and unsubscribe
+ header = task:get_header('list-subscribe')
+ if not header or not string.find(header, '<mailto:[a-zA-Z.-]+-subscribe@') then
+ return false
+ end
+ header = task:get_header('list-unsubscribe')
+ if not header or not string.find(header, '<mailto:[a-zA-Z.-]+-unsubscribe@') then
+ return false
+ end
- return true
+ return true
end
-- MailMan (the gnu mailing list manager)
@@ -78,54 +78,54 @@ end
-- List-Archive:
-- X-Mailman-Version: \d
local function check_ml_mailman(task)
- -- Mailing-List
- local header = task:get_header('x-mailman-version')
- if not header or not string.find(header, '^%d') then
- return false
- end
- -- Precedence
- header = task:get_header('precedence')
- if not header or (not string.match(header, '^bulk$') and not string.match(header, '^list$')) then
- return false
- end
- -- For reminders we have other headers than for normal messages
- header = task:get_header('x-list-administrivia')
- local subject = task:get_header('subject')
- if (header and string.find(header, 'yes')) or (subject and string.find(subject, 'mailing list memberships reminder$')) then
- if not task:get_header('errors-to') or not task:get_header('x-beenthere') then
- return false
- end
- header = task:get_header('x-no-archive')
- if not header or not string.find(header, 'yes') then
- return false
- end
- return true
- end
+ -- Mailing-List
+ local header = task:get_header('x-mailman-version')
+ if not header or not string.find(header, '^%d') then
+ return false
+ end
+ -- Precedence
+ header = task:get_header('precedence')
+ if not header or (not string.match(header, '^bulk$') and not string.match(header, '^list$')) then
+ return false
+ end
+ -- For reminders we have other headers than for normal messages
+ header = task:get_header('x-list-administrivia')
+ local subject = task:get_header('subject')
+ if (header and string.find(header, 'yes')) or (subject and string.find(subject, 'mailing list memberships reminder$')) then
+ if not task:get_header('errors-to') or not task:get_header('x-beenthere') then
+ return false
+ end
+ header = task:get_header('x-no-archive')
+ if not header or not string.find(header, 'yes') then
+ return false
+ end
+ return true
+ end
- -- Other headers
- header = task:get_header('list-id')
- if not header then
- return false
- end
- header = task:get_header('list-post')
- if not header or not string.find(header, '^<mailto:') then
- return false
- end
- header = task:get_header('list-help')
- if not header or not string.find(header, '^<mailto:') then
- return false
- end
- -- Subscribe and unsubscribe
- header = task:get_header('list-subscribe')
- if not header or not string.find(header, '<mailto:.*=subscribe>') then
- return false
- end
- header = task:get_header('list-unsubscribe')
- if not header or not string.find(header, '<mailto:.*=unsubscribe>') then
- return false
- end
+ -- Other headers
+ header = task:get_header('list-id')
+ if not header then
+ return false
+ end
+ header = task:get_header('list-post')
+ if not header or not string.find(header, '^<mailto:') then
+ return false
+ end
+ header = task:get_header('list-help')
+ if not header or not string.find(header, '^<mailto:') then
+ return false
+ end
+ -- Subscribe and unsubscribe
+ header = task:get_header('list-subscribe')
+ if not header or not string.find(header, '<mailto:.*=subscribe>') then
+ return false
+ end
+ header = task:get_header('list-unsubscribe')
+ if not header or not string.find(header, '<mailto:.*=unsubscribe>') then
+ return false
+ end
- return true
+ return true
end
@@ -139,69 +139,69 @@ end
-- List-Owner: <mailto:.*-owner@subscribe.ru>
-- List-Post: NO
local function check_ml_subscriberu(task)
- -- List-Id
- local header = task:get_header('list-id')
- if not header or not string.find(header, '^<.*%.subscribe%.ru>$') then
- return false
- end
- -- Precedence
- header = task:get_header('precedence')
- if not header or not string.match(header, '^normal$') then
- return false
- end
- -- Other headers
- header = task:get_header('list-archive')
- if not header or not string.find(header, '^<http://subscribe.ru/archive/.*>$') then
- return false
- end
- header = task:get_header('list-owner')
- if not header or not string.find(header, '^<mailto:.*-owner@subscribe.ru>$') then
- return false
- end
- header = task:get_header('list-help')
- if not header or not string.find(header, '^<http://subscribe.ru/catalog/.*>$') then
- return false
- end
- -- Subscribe and unsubscribe
- header = task:get_header('list-subscribe')
- if not header or not string.find(header, '^<mailto:.*-sub@subscribe.ru>$') then
- return false
- end
- header = task:get_header('list-unsubscribe')
- if not header or not string.find(header, '^<mailto:.*-unsub@subscribe.ru>$') then
- return false
- end
+ -- List-Id
+ local header = task:get_header('list-id')
+ if not header or not string.find(header, '^<.*%.subscribe%.ru>$') then
+ return false
+ end
+ -- Precedence
+ header = task:get_header('precedence')
+ if not header or not string.match(header, '^normal$') then
+ return false
+ end
+ -- Other headers
+ header = task:get_header('list-archive')
+ if not header or not string.find(header, '^<http://subscribe.ru/archive/.*>$') then
+ return false
+ end
+ header = task:get_header('list-owner')
+ if not header or not string.find(header, '^<mailto:.*-owner@subscribe.ru>$') then
+ return false
+ end
+ header = task:get_header('list-help')
+ if not header or not string.find(header, '^<http://subscribe.ru/catalog/.*>$') then
+ return false
+ end
+ -- Subscribe and unsubscribe
+ header = task:get_header('list-subscribe')
+ if not header or not string.find(header, '^<mailto:.*-sub@subscribe.ru>$') then
+ return false
+ end
+ header = task:get_header('list-unsubscribe')
+ if not header or not string.find(header, '^<mailto:.*-unsub@subscribe.ru>$') then
+ return false
+ end
- return true
+ return true
end
-- RFC 2369 headers
local function check_rfc2369(task)
- local header = task:get_header('List-Id')
- if not header then
- return false
- end
- header = task:get_header('List-Unsubscribe')
- if not header or not string.find(header, '^^<.+>$') then
- return false
- end
- header = task:get_header('List-Subscribe')
- if not header or not string.find(header, '^^<.+>$') then
- return false
- end
-
- return true
+ local header = task:get_header('List-Id')
+ if not header then
+ return false
+ end
+ header = task:get_header('List-Unsubscribe')
+ if not header or not string.find(header, '^^<.+>$') then
+ return false
+ end
+ header = task:get_header('List-Subscribe')
+ if not header or not string.find(header, '^^<.+>$') then
+ return false
+ end
+
+ return true
end
-- RFC 2919 headers
local function check_rfc2919(task)
- local header = task:get_header('List-Id')
- if not header or not string.find(header, '^<.+>$') then
- return false
- end
-
- return check_rfc2369(task)
+ local header = task:get_header('List-Id')
+ if not header or not string.find(header, '^<.+>$') then
+ return false
+ end
+
+ return check_rfc2369(task)
end
-- Google groups detector
@@ -209,13 +209,13 @@ end
-- RFC 2919 headers exist
--
local function check_ml_googlegroup(task)
- local header = task:get_header('X-Google-Loop')
-
- if not header then
- return false
- end
+ local header = task:get_header('X-Google-Loop')
+
+ if not header then
+ return false
+ end
- return check_rfc2919(task)
+ return check_rfc2919(task)
end
-- Majordomo detector
@@ -224,17 +224,17 @@ end
--
-- And nothing more can be extracted :(
local function check_ml_majordomo(task)
- local header = task:get_header('Sender')
- if not header or (not string.find(header, '^owner-.*$') and not string.find(header, '^.*-owner$')) then
- return false
- end
-
- local header = task:get_header('Precedence')
- if not header or (header ~= 'list' and header ~= 'bulk') then
- return false
- end
+ local header = task:get_header('Sender')
+ if not header or (not string.find(header, '^owner-.*$') and not string.find(header, '^.*-owner$')) then
+ return false
+ end
- return true
+ local header = task:get_header('Precedence')
+ if not header or (header ~= 'list' and header ~= 'bulk') then
+ return false
+ end
+
+ return true
end
-- CGP detector
@@ -242,40 +242,40 @@ end
-- RFC 2919 headers exist
--
local function check_ml_cgp(task)
- local header = task:get_header('X-Listserver')
-
- if not header or header ~= 'CommuniGate Pro LIST' then
- return false
- end
+ local header = task:get_header('X-Listserver')
+
+ if not header or header ~= 'CommuniGate Pro LIST' then
+ return false
+ end
- return check_rfc2919(task)
+ return check_rfc2919(task)
end
local function check_maillist(task)
- if check_ml_ezmlm(task) then
- task:insert_result(symbol, 1, 'ezmlm')
- elseif check_ml_mailman(task) then
- task:insert_result(symbol, 1, 'mailman')
- elseif check_ml_subscriberu(task) then
- task:insert_result(symbol, 1, 'subscribe.ru')
- elseif check_ml_googlegroup(task) then
- task:insert_result(symbol, 1, 'googlegroups')
- elseif check_ml_majordomo(task) then
- task:insert_result(symbol, 1, 'majordomo')
- elseif check_ml_cgp(task) then
- task:insert_result(symbol, 1, 'cgp')
- end
+ if check_ml_ezmlm(task) then
+ task:insert_result(symbol, 1, 'ezmlm')
+ elseif check_ml_mailman(task) then
+ task:insert_result(symbol, 1, 'mailman')
+ elseif check_ml_subscriberu(task) then
+ task:insert_result(symbol, 1, 'subscribe.ru')
+ elseif check_ml_googlegroup(task) then
+ task:insert_result(symbol, 1, 'googlegroups')
+ elseif check_ml_majordomo(task) then
+ task:insert_result(symbol, 1, 'majordomo')
+ elseif check_ml_cgp(task) then
+ task:insert_result(symbol, 1, 'cgp')
+ end
end
-- Registration
if type(rspamd_config.get_api_version) ~= 'nil' then
- if rspamd_config:get_api_version() >= 1 then
- rspamd_config:register_module_option('maillist', 'symbol', 'string')
- end
+ if rspamd_config:get_api_version() >= 1 then
+ rspamd_config:register_module_option('maillist', 'symbol', 'string')
+ end
end
-- Configuration
local opts = rspamd_config:get_all_opt('maillist')if opts then
- if opts['symbol'] then
- symbol = opts['symbol']
- rspamd_config:register_symbol(symbol, 1.0, check_maillist)
- end
+ if opts['symbol'] then
+ symbol = opts['symbol']
+ rspamd_config:register_symbol(symbol, 1.0, check_maillist)
+ end
end