aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrew Lewis <nerf@judo.za.org>2017-05-22 14:01:37 +0200
committerAndrew Lewis <nerf@judo.za.org>2017-05-22 14:03:02 +0200
commit8262af4eb83848ca81fb6f4c81abdea3bc6d8241 (patch)
treeb2ab82082b73a7685ff49f208b11484de9bc99e0
parent13bac0b96a129be5195b72a4100d6cd24a93d23e (diff)
downloadrspamd-8262af4eb83848ca81fb6f4c81abdea3bc6d8241.tar.gz
rspamd-8262af4eb83848ca81fb6f4c81abdea3bc6d8241.zip
[Feature] Rmilter_headers: approximate rmilter's extended_spam_headers
-rw-r--r--src/plugins/lua/rmilter_headers.lua74
1 files changed, 73 insertions, 1 deletions
diff --git a/src/plugins/lua/rmilter_headers.lua b/src/plugins/lua/rmilter_headers.lua
index ca5571636..76002b708 100644
--- a/src/plugins/lua/rmilter_headers.lua
+++ b/src/plugins/lua/rmilter_headers.lua
@@ -22,11 +22,26 @@ end
-- A plugin that provides common header manipulations
local logger = require "rspamd_logger"
+local util = require "rspamd_util"
local N = 'rmilter_headers'
local E = {}
+local HOSTNAME = util.get_hostname()
+
local settings = {
routines = {
+ ['x-spamd-result'] = {
+ header = 'X-Spamd-Result',
+ remove = 1,
+ },
+ ['x-rspamd-server'] = {
+ header = 'X-Rspamd-Server',
+ remove = 1,
+ },
+ ['x-rspamd-queue-id'] = {
+ header = 'X-Rspamd-Queue-Id',
+ remove = 1,
+ },
['spam-header'] = {
header = 'Deliver-To',
value = 'Junk',
@@ -92,6 +107,51 @@ local function rmilter_headers(task)
local routines, common, add, remove = {}, {}, {}, {}
+ routines['x-spamd-result'] = function()
+ if not common.symbols then
+ common.symbols = task:get_symbols_all()
+ common['metric_score'] = task:get_metric_score('default')
+ common['metric_action'] = task:get_metric_action('default')
+ end
+ if settings.routines['x-spamd-result'].remove then
+ remove[settings.routines['x-spamd-result'].header] = settings.routines['x-spamd-result'].remove
+ end
+ local buf = {}
+ table.insert(buf, table.concat({
+ 'default: ', (common['metric_action'] == 'reject') and 'True' or 'False', ' [',
+ common['metric_score'][1], ' / ', common['metric_score'][2], ']'
+ }))
+ for _, s in ipairs(common.symbols) do
+ if not s.options then s.options = {} end
+ table.insert(buf, table.concat({
+ ' ', s.name, ' (', s.score, ') [', table.concat(s.options, ','), ']',
+ }))
+ end
+ add[settings.routines['x-spamd-result'].header] = table.concat(buf, '\n')
+ end
+
+ routines['x-rspamd-queue-id'] = function()
+ if common.queue_id ~= false then
+ common.queue_id = task:get_queue_id()
+ if not common.queue_id then
+ common.queue_id = false
+ end
+ end
+ if settings.routines['x-rspamd-queue-id'].remove then
+ remove[settings.routines['x-rspamd-queue-id'].header] = settings.routines['x-rspamd-queue-id'].remove
+ end
+ if common.queue_id then
+ add[settings.routines['x-rspamd-queue-id'].header] = common.queue_id
+ end
+ end
+
+ routines['x-rspamd-server'] = function()
+ if settings.routines['x-rspamd-server'].remove then
+ remove[settings.routines['x-rspamd-server'].header] = settings.routines['x-rspamd-server'].remove
+ end
+ add[settings.routines['x-rspamd-server'].header] = HOSTNAME
+ end
+
routines['x-spamd-bar'] = function()
if not common['metric_score'] then
common['metric_score'] = task:get_metric_score('default')
@@ -272,8 +332,10 @@ if type(opts['custom']) == 'table' then
end
end
end
-for _, s in ipairs(opts['use']) do
+local have_routine = {}
+local function activate_routine(s)
if settings.routines[s] or custom_routines[s] then
+ have_routine[s] = true
table.insert(active_routines, s)
if (opts.routines and opts.routines[s]) then
for k, v in pairs(opts.routines[s]) do
@@ -284,6 +346,16 @@ for _, s in ipairs(opts['use']) do
logger.errx(rspamd_config, 'routine "%s" does not exist', s)
end
end
+if opts['extended_spam_headers'] then
+ activate_routine('x-spamd-result')
+ activate_routine('x-rspamd-server')
+ activate_routine('x-rspamd-queue-id')
+end
+for _, s in ipairs(opts['use']) do
+ if not have_routine[s] then
+ activate_routine(s)
+ end
+end
if (#active_routines < 1) then
logger.errx(rspamd_config, 'no active routines')
return