aboutsummaryrefslogtreecommitdiffstats
path: root/rules
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-09-16 09:02:21 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-09-16 09:02:21 +0100
commitc8d46c64001910cae4e393a0fe3a79c2f1c8f64c (patch)
tree24a61d0d8b5e1d3f1f9f7a1e27a102d63f2566e9 /rules
parent60508a64e943d4c77d67d1739320bf47cbd69558 (diff)
downloadrspamd-c8d46c64001910cae4e393a0fe3a79c2f1c8f64c.tar.gz
rspamd-c8d46c64001910cae4e393a0fe3a79c2f1c8f64c.zip
[Minor] Improve maps query API
Diffstat (limited to 'rules')
-rw-r--r--rules/controller/maps.lua88
1 files changed, 56 insertions, 32 deletions
diff --git a/rules/controller/maps.lua b/rules/controller/maps.lua
index f21b34c24..71bf4beef 100644
--- a/rules/controller/maps.lua
+++ b/rules/controller/maps.lua
@@ -45,14 +45,24 @@ local function maybe_fill_maps_cache()
end
end
-local function check_specific_map(input, uri, m, results)
+local function check_specific_map(input, uri, m, results, report_misses)
local value = m:get_key(input)
if value then
local result = {
map = uri,
alias = uri:match('/([^/]+)$'),
- value = value
+ value = value,
+ key = input,
+ hit = true,
+ }
+ table.insert(results, result)
+ elseif report_misses then
+ local result = {
+ map = uri,
+ alias = uri:match('/([^/]+)$'),
+ key = input,
+ hit = false,
}
table.insert(results, result)
end
@@ -60,52 +70,66 @@ end
local function handle_query_map(_, conn, req_params)
maybe_fill_maps_cache()
+ local keys_to_check = {}
+
if req_params.value and req_params.value ~= '' then
- local results = {}
+ keys_to_check[1] = req_params.value
+ elseif req_params.values then
+ keys_to_check = lua_util.str_split(req_params.values, ',')
+ end
+
+ local results = {}
+ for _,key in ipairs(keys_to_check) do
for uri,m in pairs(maps_cache) do
- check_specific_map(req_params.value, uri, m, results)
+ check_specific_map(key, uri, m, results, req_params.report_misses)
end
- conn:send_ucl{
- success = (#results > 0),
- results = results
- }
- else
- conn:send_error(404, 'missing value')
end
+ conn:send_ucl{
+ success = (#results > 0),
+ results = results
+ }
end
local function handle_query_specific_map(_, conn, req_params)
maybe_fill_maps_cache()
+ -- Fill keys to check
+ local keys_to_check = {}
if req_params.value and req_params.value ~= '' then
- local maps_to_check = maps_cache
- if req_params.maps then
- local map_names = lua_util.str_split(req_params.maps, ',')
- maps_to_check = {}
- for _,mn in ipairs(map_names) do
- if maps_cache[mn] then
- maps_to_check[mn] = maps_cache[mn]
- else
- local alias = maps_aliases[mn]
+ keys_to_check[1] = req_params.value
+ elseif req_params.values then
+ keys_to_check = lua_util.str_split(req_params.values, ',')
+ end
+ local maps_to_check = maps_cache
+ -- Fill maps to check
+ if req_params.maps then
+ local map_names = lua_util.str_split(req_params.maps, ',')
+ maps_to_check = {}
+ for _,mn in ipairs(map_names) do
+ if maps_cache[mn] then
+ maps_to_check[mn] = maps_cache[mn]
+ else
+ local alias = maps_aliases[mn]
- if alias then
- maps_to_check[alias] = maps_cache[alias]
- else
- conn:send_error(404, 'no such map: ' .. mn)
- end
+ if alias then
+ maps_to_check[alias] = maps_cache[alias]
+ else
+ conn:send_error(404, 'no such map: ' .. mn)
end
end
end
- local results = {}
+ end
+
+ local results = {}
+ for _,key in ipairs(keys_to_check) do
for uri,m in pairs(maps_to_check) do
- check_specific_map(req_params.value, uri, m, results)
+ check_specific_map(key, uri, m, results, req_params.report_misses)
end
- conn:send_ucl{
- success = (#results > 0),
- results = results
- }
- else
- conn:send_error(404, 'missing value')
end
+
+ conn:send_ucl{
+ success = (#results > 0),
+ results = results
+ }
end
local function handle_list_maps(_, conn, _)