aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2023-08-07 12:19:03 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2023-08-07 12:19:03 +0100
commit460a82484915f5fcbf34f65194c3437fa2a4e0c7 (patch)
tree6ef6f49a1061c73ac0520594eeadcbc3a3ed593d
parent662145d0554de5e769b92dab2d41173a98adcee5 (diff)
downloadrspamd-460a82484915f5fcbf34f65194c3437fa2a4e0c7.tar.gz
rspamd-460a82484915f5fcbf34f65194c3437fa2a4e0c7.zip
[Minor] Allow to log configuration errors from plugins
-rw-r--r--lualib/lua_util.lua20
-rw-r--r--src/plugins/lua/antivirus.lua1
-rw-r--r--src/plugins/lua/bimi.lua4
-rw-r--r--src/plugins/lua/reputation.lua5
4 files changed, 28 insertions, 2 deletions
diff --git a/lualib/lua_util.lua b/lualib/lua_util.lua
index 16d009619..800d9fcb7 100644
--- a/lualib/lua_util.lua
+++ b/lualib/lua_util.lua
@@ -408,6 +408,26 @@ end
exports.disable_module = disable_module
--[[[
+-- @function lua_util.push_config_error(module, err)
+-- Pushes a configuration error to the state
+-- @param {string} module name of module
+-- @param {string} err error string
+--]]
+local function push_config_error(module, err)
+ if not rspamd_plugins_state.config_errors then
+ rspamd_plugins_state.config_errors = {}
+ end
+
+ if not rspamd_plugins_state.config_errors[module] then
+ rspamd_plugins_state.config_errors[module] = {}
+ end
+
+ table.insert(rspamd_plugins_state.config_errors[module], err)
+end
+
+exports.push_config_error = push_config_error
+
+--[[[
-- @function lua_util.disable_module(modname)
-- Checks experimental plugins state and disable if needed
-- @param {string} modname name of plugin to check
diff --git a/src/plugins/lua/antivirus.lua b/src/plugins/lua/antivirus.lua
index 26b8509b8..44fe10e98 100644
--- a/src/plugins/lua/antivirus.lua
+++ b/src/plugins/lua/antivirus.lua
@@ -204,6 +204,7 @@ if opts and type(opts) == 'table' then
if not cb then
rspamd_logger.errx(rspamd_config, 'cannot add rule: "' .. k .. '"')
+ lua_util.push_config_error(N, 'cannot add AV rule: "' .. k .. '"')
else
rspamd_logger.infox(rspamd_config, 'added antivirus engine %s -> %s', k, m.symbol)
local t = {
diff --git a/src/plugins/lua/bimi.lua b/src/plugins/lua/bimi.lua
index e3f555e48..5959f59e7 100644
--- a/src/plugins/lua/bimi.lua
+++ b/src/plugins/lua/bimi.lua
@@ -353,7 +353,9 @@ local res, err = settings_schema:transform(settings)
if not res then
rspamd_logger.warnx(rspamd_config, 'plugin is misconfigured: %s', err)
- lua_util.disable_module(N, "config")
+ local err_msg = string.format("schema error: %s", res)
+ lua_util.push_config_error(N, err_msg)
+ lua_util.disable_module(N, "failed", err_msg)
return
end
diff --git a/src/plugins/lua/reputation.lua b/src/plugins/lua/reputation.lua
index 2fc1c3ad5..d569e9070 100644
--- a/src/plugins/lua/reputation.lua
+++ b/src/plugins/lua/reputation.lua
@@ -1377,8 +1377,11 @@ if opts['rules'] then
for k, v in pairs(opts['rules']) do
if not ((v or E).selector) then
rspamd_logger.errx(rspamd_config, "no selector defined for rule %s", k)
+ lua_util.push_config_error(N, "no selector defined for rule: " .. k)
else
- parse_rule(k, v)
+ if not parse_rule(k, v) then
+ lua_util.push_config_error(N, "reputation rule is misconfigured: " .. k)
+ end
end
end
else