aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lualib/lua_cfg_transform.lua32
-rw-r--r--test/lua/unit/ucl.lua6
2 files changed, 26 insertions, 12 deletions
diff --git a/lualib/lua_cfg_transform.lua b/lualib/lua_cfg_transform.lua
index 5b1ab2e1c..b928cd88a 100644
--- a/lualib/lua_cfg_transform.lua
+++ b/lualib/lua_cfg_transform.lua
@@ -99,10 +99,12 @@ local function convert_metric(cfg, metric)
end
if metric:at('actions') then
- cfg.actions = lua_util.override_defaults(cfg:at('actions'):unwrap(), metric:at('actions'):unwrap())
+ local existing_actions = cfg:at('actions') and cfg:at('actions'):unwrap() or {}
+ cfg.actions = lua_util.override_defaults(existing_actions, metric:at('actions'):unwrap())
logger.infox("overriding actions from the legacy metric settings")
end
if metric:at('unknown_weight') then
+ logger.infox("overriding unknown weight from the legacy metric settings")
cfg:at('actions').unknown_weight = metric:at('unknown_weight'):unwrap()
end
@@ -143,9 +145,19 @@ return function(cfg)
local ret = false
if cfg:at('metric') then
- for _, v in cfg:at('metric'):pairs() do
- if v:type() == 'object' then
- convert_metric(cfg, v)
+ local metric = cfg:at('metric')
+
+ -- There are two things that we can have (old `metric_pairs` logic)
+ -- 1. A metric is a single metric definition like: metric { name = "default", ... }
+ -- 2. A metric is a list of metrics like: metric { "default": ... }
+ if metric:at('actions') or metric:at('name') then
+ convert_metric(cfg, metric)
+ else
+ for _, v in cfg:at('metric'):pairs() do
+ if v:type() == 'object' then
+ logger.infox('converting metric element %s', v)
+ convert_metric(cfg, v)
+ end
end
end
ret = true
@@ -169,8 +181,8 @@ return function(cfg)
'reject', 'discard' }
local actions = cfg:at('actions')
- if actions and (not actions:at('no action') and not actions:at('no_action') and
- not actions:at('accept')) then
+ if not actions:at('no action') and not actions:at('no_action') and
+ not actions:at('accept') then
for _, d in ipairs(actions_defs) do
if actions:at(d) then
@@ -263,9 +275,11 @@ return function(cfg)
-- If neural network is enabled we MUST have `check_all_filters` flag
if cfg:at('neural') then
- if not cfg:at('options'):at('check_all_filters') then
- logger.infox(rspamd_config, 'enable `options.check_all_filters` for neural network')
- cfg:at('options')['check_all_filters'] = true
+ if cfg:at('options') then
+ if not cfg:at('options'):at('check_all_filters') then
+ logger.infox(rspamd_config, 'enable `options.check_all_filters` for neural network')
+ cfg:at('options')['check_all_filters'] = true
+ end
end
end
diff --git a/test/lua/unit/ucl.lua b/test/lua/unit/ucl.lua
index 991afc979..9bbf7225c 100644
--- a/test/lua/unit/ucl.lua
+++ b/test/lua/unit/ucl.lua
@@ -37,10 +37,10 @@ context("UCL manipulation", function()
ireply[1] = 1
ireply[1] = 1
ireply[1] = 1
- ireply[#ireply + 1] = 100500
- local iexpected = { 1, 1, 1, 1, 1, "e1", "e2", 100500 }
+ ireply[ireply:len() + 1] = 100500
+ local iexpected = { 1, "e2", 100500 }
for k, v in ireply:ipairs() do
- assert_equal(iexpected[k], v:unwrap())
+ assert_equal(v:unwrap(), iexpected[k])
end
reply.tbl = ireply