diff options
author | Andrew Lewis <nerf@judo.za.org> | 2016-09-29 08:57:26 +0200 |
---|---|---|
committer | Andrew Lewis <nerf@judo.za.org> | 2016-09-29 08:57:26 +0200 |
commit | 9f6094edab767b2a6760ec287b172f28227d3d1c (patch) | |
tree | 89b2da1475a87a02581755f11c31d1619d07801a | |
parent | c8f2ef32824fc404ad546838b10988ed527fa14d (diff) | |
download | rspamd-9f6094edab767b2a6760ec287b172f28227d3d1c.tar.gz rspamd-9f6094edab767b2a6760ec287b172f28227d3d1c.zip |
[Feature] Ratelimit: Support dynamic bucket size/leak rate
-rw-r--r-- | src/plugins/lua/ratelimit.lua | 27 |
1 files changed, 24 insertions, 3 deletions
diff --git a/src/plugins/lua/ratelimit.lua b/src/plugins/lua/ratelimit.lua index 83cbd5436..38ebcfa7e 100644 --- a/src/plugins/lua/ratelimit.lua +++ b/src/plugins/lua/ratelimit.lua @@ -427,10 +427,20 @@ local function rate_test_set(task, func) if rate_key then if type(rate_key) == 'table' then for _, rk in ipairs(rate_key) do - table.insert(args, {settings[k], rk}) + if type(settings[k]) == 'table' then + table.insert(args, {settings[k], rk}) + elseif type(settings[k]) == 'string' and + (custom_keywords[settings[k]] and type(custom_keywords[settings[k]]['get_limit']) == 'function') then + table.insert(args, {custom_keywords[settings[k]]['get_limit'](), rate_key}) + end end else - table.insert(args, {settings[k], rate_key}) + if type(settings[k]) == 'table' then + table.insert(args, {settings[k], rate_key}) + elseif type(settings[k]) == 'string' and + (custom_keywords[settings[k]] and type(custom_keywords[settings[k]]['get_limit']) == 'function') then + table.insert(args, {custom_keywords[settings[k]]['get_limit'](), rate_key}) + end end end end @@ -493,9 +503,20 @@ if opts then end, opts['rates']) end + if opts['dynamic_rates'] and type(opts['dynamic_rates']) == 'table' then + fun.each(function(t, lim) + if type(lim) == 'string' then + settings[t] = lim + end + end, opts['dynamic_rates']) + end + local enabled_limits = fun.totable(fun.map(function(t, lim) return t - end, fun.filter(function(t, lim) return lim[1] > 0 end, settings))) + end, fun.filter(function(t, lim) + return type(lim) == 'string' or + (type(lim) == 'table' and type(lim[1]) == 'number' and lim[1] > 0) + end, settings))) rspamd_logger.infox(rspamd_config, 'enabled rate buckets: %s', enabled_limits) if opts['whitelisted_rcpts'] and type(opts['whitelisted_rcpts']) == 'string' then |