summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-02-27 15:33:04 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-02-27 15:33:04 +0000
commit2623065a8f9441f78c33466f847df77807a31230 (patch)
tree3c00698f7f1f5746881b9494c7a4d879051ed895 /src
parent67baaadfa3556aa4bd257a7c52e5cd5eedfbade1 (diff)
downloadrspamd-2623065a8f9441f78c33466f847df77807a31230.tar.gz
rspamd-2623065a8f9441f78c33466f847df77807a31230.zip
[Fix] Fix opaque maps logic
Diffstat (limited to 'src')
-rw-r--r--src/lua/lua_map.c3
-rw-r--r--src/plugins/lua/phishing.lua8
2 files changed, 7 insertions, 4 deletions
diff --git a/src/lua/lua_map.c b/src/lua/lua_map.c
index b279bacbd..a5defd011 100644
--- a/src/lua/lua_map.c
+++ b/src/lua/lua_map.c
@@ -444,13 +444,14 @@ lua_map_fin (struct map_cb_data *data, void **target)
else if (cbdata->data != NULL && cbdata->data->len != 0) {
lua_rawgeti (cbdata->L, LUA_REGISTRYINDEX, cbdata->ref);
- if (cbdata->opaque) {
+ if (!cbdata->opaque) {
lua_pushlstring (cbdata->L, cbdata->data->str, cbdata->data->len);
}
else {
struct rspamd_lua_text *t;
t = lua_newuserdata (cbdata->L, sizeof (*t));
+ rspamd_lua_setclass (cbdata->L, "rspamd{text}", -1);
t->flags = 0;
t->len = cbdata->data->len;
t->start = cbdata->data->str;
diff --git a/src/plugins/lua/phishing.lua b/src/plugins/lua/phishing.lua
index e07cd8858..89d69cb5e 100644
--- a/src/plugins/lua/phishing.lua
+++ b/src/plugins/lua/phishing.lua
@@ -423,7 +423,7 @@ local function openphish_json_cb(string)
pool:destroy()
end
-local function openphish_plain_cb(string)
+local function openphish_plain_cb(s)
local nelts = 0
local new_data = {}
local rspamd_mempool = require "rspamd_mempool"
@@ -435,7 +435,7 @@ local function openphish_plain_cb(string)
end
end
- rspamd_str_split_fun(string, '\n', openphish_elt_parser)
+ rspamd_str_split_fun(s, '\n', openphish_elt_parser)
openphish_data = new_data
rspamd_logger.infox(openphish_hash, "parsed %s elements from openphish feed",
@@ -492,13 +492,15 @@ if opts then
type = 'callback',
url = openphish_map,
callback = openphish_plain_cb,
- description = 'Open phishing feed map (see https://www.openphish.com for details)'
+ description = 'Open phishing feed map (see https://www.openphish.com for details)',
+ opaque_data = true,
})
else
openphish_hash = rspamd_config:add_map({
type = 'callback',
url = openphish_map,
callback = openphish_json_cb,
+ opaque_data = true,
description = 'Open phishing premium feed map (see https://www.openphish.com for details)'
})
end