diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-05-15 14:37:24 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-05-15 14:37:24 +0100 |
commit | 1674846653fd33d9478bfcf9ff391ac6c6164c74 (patch) | |
tree | 9097714ebdd3dbc3341fc5214f71d008bacba9e5 | |
parent | a591c2f0cdc879ad2a1c5c98584a7f28a442a054 (diff) | |
download | rspamd-1674846653fd33d9478bfcf9ff391ac6c6164c74.tar.gz rspamd-1674846653fd33d9478bfcf9ff391ac6c6164c74.zip |
[Feature] Allow to disable lua squeezing logic
-rw-r--r-- | src/libserver/cfg_file.h | 3 | ||||
-rw-r--r-- | src/libserver/cfg_rcl.c | 8 | ||||
-rw-r--r-- | src/lua/lua_config.c | 27 |
3 files changed, 28 insertions, 10 deletions
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h index 5a846a1f5..520c847f3 100644 --- a/src/libserver/cfg_file.h +++ b/src/libserver/cfg_file.h @@ -311,7 +311,8 @@ struct rspamd_config { gboolean ignore_received; /**< Ignore data from the first received header */ gboolean enable_sessions_cache; /**< Enable session cache for debug */ gboolean enable_experimental; /**< Enable experimental plugins */ - gboolean disable_pcre_jit; /**< Disable pcre JIT */ + gboolean disable_pcre_jit; /**< Disable pcre JIT */ + gboolean disable_lua_squeeze; /**< Disable lua rules squeezing */ gsize max_diff; /**< maximum diff size for text parts */ gsize max_cores_size; /**< maximum size occupied by rspamd core files */ diff --git a/src/libserver/cfg_rcl.c b/src/libserver/cfg_rcl.c index d4aa5314b..e47be0afe 100644 --- a/src/libserver/cfg_rcl.c +++ b/src/libserver/cfg_rcl.c @@ -2059,12 +2059,18 @@ rspamd_rcl_config_init (struct rspamd_config *cfg) 0, "Enable experimental plugins"); rspamd_rcl_add_default_handler (sub, - "enable_experimental", + "disable_pcre_jit", rspamd_rcl_parse_struct_boolean, G_STRUCT_OFFSET (struct rspamd_config, disable_pcre_jit), 0, "Disable PCRE JIT"); rspamd_rcl_add_default_handler (sub, + "disable_lua_squeeze", + rspamd_rcl_parse_struct_boolean, + G_STRUCT_OFFSET (struct rspamd_config, disable_lua_squeeze), + 0, + "Disable Lua rules squeezing"); + rspamd_rcl_add_default_handler (sub, "all_filters", rspamd_rcl_parse_struct_boolean, G_STRUCT_OFFSET (struct rspamd_config, check_all_filters), diff --git a/src/lua/lua_config.c b/src/lua/lua_config.c index 6e502d6e7..2802ab6a4 100644 --- a/src/lua/lua_config.c +++ b/src/lua/lua_config.c @@ -1595,6 +1595,10 @@ lua_config_register_symbol (lua_State * L) return luaL_error (L, "invalid arguments"); } + if (!no_squeeze) { + no_squeeze = cfg->disable_lua_squeeze; + } + if (nshots == 0) { nshots = cfg->default_max_shots; } @@ -1894,18 +1898,20 @@ lua_config_register_dependency (lua_State * L) struct rspamd_config *cfg = lua_check_config (L, 1); const gchar *parent = NULL, *child = NULL; gint child_id; - gboolean skip_squeeze = FALSE; + gboolean skip_squeeze; if (cfg == NULL) { lua_error (L); return 0; } + skip_squeeze = cfg->disable_lua_squeeze; + if (lua_type (L, 2) == LUA_TNUMBER) { child_id = luaL_checknumber (L, 2); parent = luaL_checkstring (L, 3); - if (lua_isboolean (L, 4)) { + if (!skip_squeeze && lua_isboolean (L, 4)) { skip_squeeze = lua_toboolean (L, 4); } @@ -1925,7 +1931,7 @@ lua_config_register_dependency (lua_State * L) child = luaL_checkstring (L,2); parent = luaL_checkstring (L, 3); - if (lua_isboolean (L, 4)) { + if (!skip_squeeze && lua_isboolean (L, 4)) { skip_squeeze = lua_toboolean (L, 4); } @@ -2246,6 +2252,8 @@ lua_config_newindex (lua_State *L) name = luaL_checkstring (L, 2); if (cfg != NULL && name != NULL && lua_gettop (L) == 3) { + no_squeeze = cfg->disable_lua_squeeze; + if (lua_type (L, 3) == LUA_TFUNCTION) { /* Normal symbol from just a function */ lua_pushvalue (L, 3); @@ -2266,6 +2274,7 @@ lua_config_newindex (lua_State *L) const char *type_str, *group = NULL, *description = NULL; guint flags = 0; + no_squeeze = cfg->disable_lua_squeeze; /* * Table can have the following attributes: * "callback" - should be a callback function @@ -2332,13 +2341,15 @@ lua_config_newindex (lua_State *L) } lua_pop (L, 1); - lua_pushstring (L, "no_squeeze"); - lua_gettable (L, -2); + if (!no_squeeze) { + lua_pushstring (L, "no_squeeze"); + lua_gettable (L, -2); - if (lua_toboolean (L, -1)) { - no_squeeze = TRUE; + if (lua_toboolean (L, -1)) { + no_squeeze = TRUE; + } + lua_pop (L, 1); } - lua_pop (L, 1); id = rspamd_register_symbol_fromlua (L, cfg, |