aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/lua/gpt.lua
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2024-12-10 14:22:22 +0000
committerVsevolod Stakhov <vsevolod@rspamd.com>2024-12-10 14:22:22 +0000
commit7d3200169892d35ac3f9ec4234a71828041bf521 (patch)
tree7256d935cb69e278647015d8d937f2b142ec172c /src/plugins/lua/gpt.lua
parent3486649dd3d4555819a8299990e7f9476cbf175b (diff)
downloadrspamd-7d3200169892d35ac3f9ec4234a71828041bf521.tar.gz
rspamd-7d3200169892d35ac3f9ec4234a71828041bf521.zip
[Minor] GPT: add `allow_passthrough` and `allow_ham` settings
Diffstat (limited to 'src/plugins/lua/gpt.lua')
-rw-r--r--src/plugins/lua/gpt.lua10
1 files changed, 8 insertions, 2 deletions
diff --git a/src/plugins/lua/gpt.lua b/src/plugins/lua/gpt.lua
index 823dbd045..014f47d72 100644
--- a/src/plugins/lua/gpt.lua
+++ b/src/plugins/lua/gpt.lua
@@ -44,6 +44,10 @@ gpt {
reply_conversion = "xxx";
# URL for the API
url = "https://api.openai.com/v1/chat/completions";
+ # Check messages with passthrough result
+ allow_passthrough = false;
+ # Check messages that are apparent ham (no action and negative score)
+ allow_ham = false;
}
]])
return
@@ -78,6 +82,8 @@ local settings = {
autolearn = false,
url = 'https://api.openai.com/v1/chat/completions',
symbols_to_except = default_symbols_to_except,
+ allow_passthrough = false,
+ allow_ham = false,
}
local function default_condition(task)
@@ -87,7 +93,7 @@ local function default_condition(task)
-- 3) Skip already decided as ham
local result = task:get_metric_result()
if result then
- if result.passthrough then
+ if result.passthrough and not settings.allow_passthrough then
return false, 'passthrough'
end
local score = result.score
@@ -97,7 +103,7 @@ local function default_condition(task)
return false, 'already decided as spam'
end
- if action == 'no action' and score < 0 then
+ if (action == 'no action' and score < 0) and not settings.allow_ham then
return false, 'negative score, already decided as ham'
end
end