aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/lua/greylist.lua
diff options
context:
space:
mode:
authorMiecio Za <miecio@miecio.net>2019-03-18 20:53:02 +0100
committerMiecio Za <miecio@miecio.net>2019-03-18 20:53:02 +0100
commitcd50acbfc30ddba123ee85b7d9c2ee7ca9d0c20b (patch)
treea61807a7b85369201a47cdcfd04a6638776a4749 /src/plugins/lua/greylist.lua
parent925b1b072360e12f68a0992d3bdcb360c35f7663 (diff)
parent723e9e963380dfa12d5b9e0f7b999535e4917e48 (diff)
downloadrspamd-cd50acbfc30ddba123ee85b7d9c2ee7ca9d0c20b.tar.gz
rspamd-cd50acbfc30ddba123ee85b7d9c2ee7ca9d0c20b.zip
Merge branch 'master' into lua_string_utils
Diffstat (limited to 'src/plugins/lua/greylist.lua')
-rw-r--r--src/plugins/lua/greylist.lua23
1 files changed, 19 insertions, 4 deletions
diff --git a/src/plugins/lua/greylist.lua b/src/plugins/lua/greylist.lua
index 5a1f6c0f9..1ba80dd80 100644
--- a/src/plugins/lua/greylist.lua
+++ b/src/plugins/lua/greylist.lua
@@ -44,7 +44,7 @@ end
local redis_params
local whitelisted_ip
local whitelist_domains_map
-local toint =math.ifloor or math.floor
+local toint = math.ifloor or math.floor
local settings = {
expire = 86400, -- 1 day by default
timeout = 300, -- 5 minutes by default
@@ -53,6 +53,7 @@ local settings = {
message = 'Try again later', -- default greylisted message
symbol = 'GREYLIST',
action = 'soft reject', -- default greylisted action
+ whitelist_symbols = {}, -- whitelist when specific symbols have been found
ipv4_mask = 19, -- Mask bits for ipv4
ipv6_mask = 64, -- Mask bits for ipv6
report_time = false, -- Tell when greylisting is epired (appended to `message`)
@@ -65,6 +66,7 @@ local rspamd_util = require "rspamd_util"
local fun = require "fun"
local hash = require "rspamd_cryptobox_hash"
local rspamd_lua_utils = require "lua_util"
+local lua_map = require "lua_map"
local N = "greylist"
local function data_key(task)
@@ -276,6 +278,19 @@ local function greylist_set(task)
-- Don't do anything if pre-result has been already set
if task:has_pre_result() then return end
+ -- Check whitelist_symbols
+ for _,sym in ipairs(settings.whitelist_symbols) do
+ if task:has_symbol(sym) then
+ rspamd_logger.infox(task, 'skip greylisting as we have found symbol %s', sym)
+ if action == 'greylist' then
+ -- We are going to accept message
+ rspamd_logger.infox(task, 'downgrading metric action from "greylist" to "no action"')
+ task:disable_action('greylist')
+ end
+ return
+ end
+ end
+
if settings.greylist_min_score then
local score = task:get_metric_score('default')[1]
if score < settings.greylist_min_score then
@@ -438,12 +453,12 @@ if opts then
end
end
- whitelisted_ip = rspamd_map_add('greylist', 'whitelisted_ip', 'radix',
+ whitelisted_ip = lua_map.rspamd_map_add(N, 'whitelisted_ip', 'radix',
'Greylist whitelist ip map')
- whitelist_domains_map = rspamd_map_add('greylist', 'whitelist_domains_url',
+ whitelist_domains_map = lua_map.rspamd_map_add(N, 'whitelist_domains_url',
'map', 'Greylist whitelist domains map')
- redis_params = rspamd_parse_redis_server('greylist')
+ redis_params = rspamd_parse_redis_server(N)
if not redis_params then
rspamd_logger.infox(rspamd_config, 'no servers are specified, disabling module')
rspamd_lua_utils.disable_module(N, "redis")