aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2018-11-04 11:00:12 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2018-11-04 11:00:12 +0000
commit997b81a6f13a49ccf39c8c7adee1c41e25ff382c (patch)
tree18ef450f178960cb1aa2ae4272cbae8fcd101470
parent1473bfa1efef8b4117bc48e4b0b24c10b8846619 (diff)
downloadrspamd-997b81a6f13a49ccf39c8c7adee1c41e25ff382c.tar.gz
rspamd-997b81a6f13a49ccf39c8c7adee1c41e25ff382c.zip
[Feature] Ignore cookies in the future and too old in the past
-rw-r--r--src/plugins/lua/replies.lua39
1 files changed, 32 insertions, 7 deletions
diff --git a/src/plugins/lua/replies.lua b/src/plugins/lua/replies.lua
index 7e9816fb8..234a41ca3 100644
--- a/src/plugins/lua/replies.lua
+++ b/src/plugins/lua/replies.lua
@@ -39,7 +39,8 @@ local settings = {
use_local = true,
cookie = nil,
cookie_key = nil,
- cookie_is_pattern = false
+ cookie_is_pattern = false,
+ cookie_valid_time = '2w', -- 2 weeks by default
}
local N = "replies"
@@ -132,12 +133,31 @@ local function replies_set(task)
end
local function replies_check_cookie(task)
- local function cookie_matched(extra)
+ local function cookie_matched(extra, ts)
+ local dt = task:get_date{format = 'connect', gmt = true}
+
+ if dt < ts then
+ rspamd_logger.infox(task, 'ignore cookie as its date is in future')
+
+ return
+ end
+
+ if settings.cookie_valid_time then
+ if dt - ts > settings.cookie_valid_time then
+ rspamd_logger.infox(task,
+ 'ignore cookie as its timestamp is too old: %s (%s current time)',
+ ts, dt)
+
+ return
+ end
+ end
if extra then
- task:insert_result(settings['symbol'], 1.0, string.format('cookie:%s', extra))
+ task:insert_result(settings['symbol'], 1.0,
+ string.format('cookie:%s:%s', extra, ts))
else
- task:insert_result(settings['symbol'], 1.0, 'cookie')
+ task:insert_result(settings['symbol'], 1.0,
+ string.format('cookie:%s', ts))
end
if settings['action'] ~= nil then
local ip_addr = task:get_ip()
@@ -165,7 +185,7 @@ local function replies_check_cookie(task)
extracted_cookie = irt
end
- local dec_cookie = cr.decrypt_cookie(settings.cookie_key, extracted_cookie)
+ local dec_cookie,ts = cr.decrypt_cookie(settings.cookie_key, extracted_cookie)
if dec_cookie then
-- We have something that looks like a cookie
@@ -173,12 +193,12 @@ local function replies_check_cookie(task)
local m = dec_cookie:match(settings.cookie)
if m then
- cookie_matched(m)
+ cookie_matched(m, ts)
end
else
-- Direct match
if dec_cookie == settings.cookie then
- cookie_matched()
+ cookie_matched(nil, ts)
end
end
end
@@ -209,6 +229,11 @@ if opts then
return
end
+
+ if settings.cookie_valid_time then
+ settings.cookie_valid_time = lua_util.parse_time_interval(settings.cookie_valid_time)
+ end
+
local id = rspamd_config:register_symbol({
name = 'REPLIES_CHECK',
type = 'prefilter,nostat',