aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/plugins/lua/spamassassin.lua28
1 files changed, 16 insertions, 12 deletions
diff --git a/src/plugins/lua/spamassassin.lua b/src/plugins/lua/spamassassin.lua
index 911661ed9..b19ad9a0d 100644
--- a/src/plugins/lua/spamassassin.lua
+++ b/src/plugins/lua/spamassassin.lua
@@ -130,6 +130,10 @@ local meta_score_alpha = 0.5
-- Maximum size of regexp checked
local match_limit = 0
+-- Default priority of the scores registered in the metric
+-- Historically this is set to 2 allowing SA scores to override Rspamd scores
+local scores_priority = 2
+
local function split(str, delim)
local result = {}
@@ -1547,7 +1551,7 @@ local function post_process()
rspamd_config:set_metric_symbol{
name = k, score = r['score'],
description = r['description'],
- priority = 2,
+ priority = scores_priority,
one_shot = true
}
scores_added[k] = 1
@@ -1670,18 +1674,19 @@ end
local has_rules = false
if type(section) == "table" then
- if type(section.pcre_only) == 'table' then
- pcre_only_regexps = lua_util.list_to_hash(section.pcre_only)
- end
- if type(section.alpha) == 'number' then
- meta_score_alpha = section.alpha
- end
- if type(section.match_limit) == 'number' then
- match_limit = section.match_limit
- end
+ local keywords = {
+ pcre_only = {'table', function(v) pcre_only_regexps = lua_util.list_to_hash(v) end},
+ alpha = {'number', function(v) meta_score_alpha = tonumber(v) end},
+ match_limit = {'number', function(v) match_limit = tonumber(v) end},
+ scores_priority = {'number', function(v) scores_priority = tonumber(v) end},
+ }
for k, fn in pairs(section) do
- if k ~= 'pcre_only' and k ~= 'alpha' and k ~= 'match_limit' then
+ local kw = keywords[k]
+ if kw and type(fn) == kw[1] then
+ kw[2](fn)
+ else
+ -- SA rule file
if type(fn) == 'table' then
for _, elt in ipairs(fn) do
local files = util.glob(elt)
@@ -1718,7 +1723,6 @@ if type(section) == "table" then
rspamd_logger.errx(rspamd_config, "cannot open %1", matched)
end
end
-
end
end
end