diff options
-rw-r--r-- | src/plugins/lua/ip_score.lua | 47 |
1 files changed, 31 insertions, 16 deletions
diff --git a/src/plugins/lua/ip_score.lua b/src/plugins/lua/ip_score.lua index bb34003cb..1541038fe 100644 --- a/src/plugins/lua/ip_score.lua +++ b/src/plugins/lua/ip_score.lua @@ -23,7 +23,7 @@ local rspamd_util = require "rspamd_util" local _ = require "fun" -- Default settings -local upstreams = nil +local redis_params = nil local whitelist = nil local asn_cc_whitelist = nil @@ -167,20 +167,26 @@ local ip_score_set = function(task) score = score_mult * rspamd_util.tanh (2.718 * score) local hkey = ip_score_hash_key(asn, country, ipnet, ip) - local upstream = upstreams:get_upstream_by_hash(hkey) - local addr = upstream:get_addr() + local upstream,ret asn_score,total_asn = new_score_set(score, asn_score, total_asn) country_score,total_country = new_score_set(score, country_score, total_country) ipnet_score,total_ipnet = new_score_set(score, ipnet_score, total_ipnet) ip_score,total_ip = new_score_set(score, ip_score, total_ip) - - rspamd_redis.make_request(task, addr, score_set_cb, - 'HMSET', {options['hash'], + local redis_args = {options['hash'], options['asn_prefix'] .. asn, string.format('%f|%d', asn_score, total_asn), options['country_prefix'] .. country, string.format('%f|%d', country_score, total_country), options['ipnet_prefix'] .. ipnet, string.format('%f|%d', ipnet_score, total_ipnet), - ip:to_string(), string.format('%f|%d', ip_score, total_ip)}) + ip:to_string(), string.format('%f|%d', ip_score, total_ip)} + + ret,_,upstream = rspamd_redis_make_request(task, + redis_params, -- connect params + hkey, -- hash key + true, -- is write + score_set_cb, --callback + 'HMSET', -- command + redis_args -- arguments + ) end -- Check score for ip in keystorage @@ -259,8 +265,12 @@ local ip_score_check = function(task) table.insert(description_t, 'country: ' .. country .. '(' .. math.floor(country_score * 1000) / 100 .. ')') end - if options['max_score'] and (total_score*10) > options['max_score'] then total_score = options['max_score']/10 end - if options['min_score'] and (total_score*10) < options['min_score'] then total_score = options['min_score']/10 end + if options['max_score'] and (total_score*10) > options['max_score'] then + total_score = options['max_score']/10 + end + if options['min_score'] and (total_score*10) < options['min_score'] then + total_score = options['min_score']/10 + end if total_score ~= 0 then task:insert_result(options['symbol'], total_score, table.concat(description_t, ', ')) @@ -317,10 +327,15 @@ local ip_score_check = function(task) end local cmd, args = create_get_command(ip, asn, country, ipnet) - local upstream = upstreams:get_upstream_by_hash( - ip_score_hash_key(asn, country, ipnet, ip)) - local addr = upstream:get_addr() - rspamd_redis.make_request(task, addr, ip_score_redis_cb, cmd, args) + + local ret,_,upstream = rspamd_redis_make_request(task, + redis_params, -- connect params + ip_score_hash_key(asn, country, ipnet, ip), -- hash key + false, -- is write + ip_score_redis_cb, --callback + cmd, -- command + args -- arguments + ) end end @@ -332,8 +347,8 @@ local configure_ip_score_module = function() for k,v in pairs(opts) do options[k] = v end - upstreams = rspamd_parse_redis_server('ip_score') - if not upstreams then + redis_params = rspamd_parse_redis_server('ip_score') + if not redis_params then rspamd_logger.infox(rspamd_config, 'no servers are specified') end end @@ -347,7 +362,7 @@ end configure_ip_score_module() -if upstreams then +if redis_params then -- Register ip_score module if options['asn_provider'] then rspamd_config:register_pre_filter(asn_check) |