aboutsummaryrefslogtreecommitdiffstats
path: root/src/lua
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-04-01 14:22:17 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-04-01 14:22:17 +0100
commit7dfecb9cc8f3ceffaf3a3077166807bfb8fff231 (patch)
treeadb6773e1f66e9dfc02a64d79d1e1fe5a66b7956 /src/lua
parent302da75c22217d0c8c0a6a868b85e81df8f63dd0 (diff)
downloadrspamd-7dfecb9cc8f3ceffaf3a3077166807bfb8fff231.tar.gz
rspamd-7dfecb9cc8f3ceffaf3a3077166807bfb8fff231.zip
[Fix] Another fix for Redis sentinel
Issue: #2796
Diffstat (limited to 'src/lua')
-rw-r--r--src/lua/lua_common.c14
1 files changed, 6 insertions, 8 deletions
diff --git a/src/lua/lua_common.c b/src/lua/lua_common.c
index 5f1be424d..81fac3640 100644
--- a/src/lua/lua_common.c
+++ b/src/lua/lua_common.c
@@ -2500,12 +2500,9 @@ gboolean
rspamd_lua_try_load_redis (lua_State *L, const ucl_object_t *obj,
struct rspamd_config *cfg, gint *ref_id)
{
- gint res_pos, err_idx;
+ gint err_idx;
struct rspamd_config **pcfg;
- /* Create results table */
- lua_createtable (L, 0, 0);
- res_pos = lua_gettop (L);
lua_pushcfunction (L, &rspamd_lua_traceback);
err_idx = lua_gettop (L);
@@ -2522,7 +2519,7 @@ rspamd_lua_try_load_redis (lua_State *L, const ucl_object_t *obj,
pcfg = lua_newuserdata (L, sizeof (*pcfg));
rspamd_lua_setclass (L, "rspamd{config}", -1);
*pcfg = cfg;
- lua_pushvalue (L, res_pos);
+ lua_pushboolean (L, false); /* no_fallback */
if (lua_pcall (L, 3, 1, err_idx) != 0) {
GString *tb;
@@ -2535,16 +2532,17 @@ rspamd_lua_try_load_redis (lua_State *L, const ucl_object_t *obj,
return FALSE;
}
- if (lua_toboolean (L, -1)) {
+ if (lua_istable (L, -1)) {
if (ref_id) {
/* Ref table */
- lua_pushvalue (L, res_pos);
+ lua_pushvalue (L, -1);
*ref_id = luaL_ref (L, LUA_REGISTRYINDEX);
lua_settop (L, 0);
}
else {
/* Leave it on the stack */
- lua_settop (L, res_pos);
+ lua_insert (L, err_idx);
+ lua_settop (L, err_idx);
}
return TRUE;