From b2cfa63b1fc61c666ee2539f070ac99c0961fcee Mon Sep 17 00:00:00 2001 From: Vsevolod Stakhov Date: Wed, 26 Oct 2016 12:18:49 +0200 Subject: [Fix] Fix applying of lua dynamic confg --- src/libserver/dynamic_cfg.c | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/libserver/dynamic_cfg.c b/src/libserver/dynamic_cfg.c index 56b7b17f0..ffb5963a5 100644 --- a/src/libserver/dynamic_cfg.c +++ b/src/libserver/dynamic_cfg.c @@ -394,13 +394,13 @@ new_dynamic_elt (ucl_object_t *arr, const gchar *name, gdouble value) return n; } -static gboolean +static gint rspamd_maybe_add_lua_dynsym (struct rspamd_config *cfg, const gchar *sym, gdouble score) { lua_State *L = cfg->lua_state; - gboolean ret = FALSE; + gint ret = -1; struct rspamd_config **pcfg; lua_getglobal (L, "rspamd_plugins"); @@ -442,13 +442,13 @@ rspamd_maybe_add_lua_dynsym (struct rspamd_config *cfg, return ret; } -static gboolean +static gint rspamd_maybe_add_lua_dynact (struct rspamd_config *cfg, const gchar *action, gdouble score) { lua_State *L = cfg->lua_state; - gboolean ret = FALSE; + gint ret = -1; struct rspamd_config **pcfg; lua_getglobal (L, "rspamd_plugins"); @@ -505,9 +505,10 @@ add_dynamic_symbol (struct rspamd_config *cfg, gdouble value) { ucl_object_t *metric, *syms; + gint ret; - if (rspamd_maybe_add_lua_dynsym (cfg, symbol, value)) { - return TRUE; + if ((ret = rspamd_maybe_add_lua_dynsym (cfg, symbol, value)) != -1) { + return ret == 0 ? FALSE : TRUE; } if (cfg->dynamic_conf == NULL) { @@ -597,9 +598,10 @@ add_dynamic_action (struct rspamd_config *cfg, { ucl_object_t *metric, *acts; const gchar *action_name = rspamd_action_to_str (action); + gint ret; - if (rspamd_maybe_add_lua_dynact (cfg, action_name, value)) { - return TRUE; + if ((ret = rspamd_maybe_add_lua_dynact (cfg, action_name, value)) != -1) { + return ret == 0 ? FALSE : TRUE; } if (cfg->dynamic_conf == NULL) { -- cgit v1.2.3