diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-09-16 09:02:21 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2020-09-16 09:02:21 +0100 |
commit | c8d46c64001910cae4e393a0fe3a79c2f1c8f64c (patch) | |
tree | 24a61d0d8b5e1d3f1f9f7a1e27a102d63f2566e9 /rules | |
parent | 60508a64e943d4c77d67d1739320bf47cbd69558 (diff) | |
download | rspamd-c8d46c64001910cae4e393a0fe3a79c2f1c8f64c.tar.gz rspamd-c8d46c64001910cae4e393a0fe3a79c2f1c8f64c.zip |
[Minor] Improve maps query API
Diffstat (limited to 'rules')
-rw-r--r-- | rules/controller/maps.lua | 88 |
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, _) |