diff options
author | Vsevolod Stakhov <vsevolod@rspamd.com> | 2022-07-31 20:03:46 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rspamd.com> | 2022-07-31 20:03:46 +0100 |
commit | f1459350db47bebedbaa314ef219dab1f553b1af (patch) | |
tree | 822fb0e655cd25f59545c4d712abb0586345a4e0 /src/lua/lua_config.c | |
parent | 50101aca1924f3d4ca4db4c34580e7fc560771b4 (diff) | |
download | rspamd-f1459350db47bebedbaa314ef219dab1f553b1af.tar.gz rspamd-f1459350db47bebedbaa314ef219dab1f553b1af.zip |
[Minor] Bail on unknown augmentations
Diffstat (limited to 'src/lua/lua_config.c')
-rw-r--r-- | src/lua/lua_config.c | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/src/lua/lua_config.c b/src/lua/lua_config.c index 0ab834054..333c8cdde 100644 --- a/src/lua/lua_config.c +++ b/src/lua/lua_config.c @@ -1995,6 +1995,7 @@ lua_config_register_symbol (lua_State * L) gint ret = -1, cbref = -1, type, flags = 0; gint64 parent = 0, priority = 0, nshots = 0; GError *err = NULL; + int prev_top = lua_gettop(L); if (cfg) { if (!rspamd_lua_parse_table_arguments (L, 2, &err, @@ -2008,6 +2009,7 @@ lua_config_register_symbol (lua_State * L) &allowed_ids, &forbidden_ids)) { msg_err_config ("bad arguments: %e", err); g_error_free (err); + lua_settop(L, prev_top); return luaL_error (L, "invalid arguments"); } @@ -2019,9 +2021,11 @@ lua_config_register_symbol (lua_State * L) type = lua_parse_symbol_type (type_str); if (!name && !(type & SYMBOL_TYPE_CALLBACK)) { + lua_settop(L, prev_top); return luaL_error (L, "no symbol name but type is not callback"); } else if (!(type & SYMBOL_TYPE_VIRTUAL) && cbref == -1) { + lua_settop(L, prev_top); return luaL_error (L, "no callback for symbol %s", name); } @@ -2067,6 +2071,7 @@ lua_config_register_symbol (lua_State * L) lua_tostring (L, -1)); } else { + lua_settop(L, prev_top); return luaL_error(L, "invalid groups element"); } } @@ -2081,18 +2086,26 @@ lua_config_register_symbol (lua_State * L) if (lua_type (L, -1) == LUA_TTABLE) { int tbl_idx = lua_gettop(L); for (lua_pushnil(L); lua_next(L, tbl_idx); lua_pop (L, 1)) { - rspamd_symcache_add_symbol_augmentation(cfg->cache, ret, - lua_tostring(L, -1)); + const char *augmentation = lua_tostring(L, -1); + + if (!rspamd_symcache_add_symbol_augmentation(cfg->cache, ret, + augmentation)) { + lua_settop(L, prev_top); + + return luaL_error (L, "unknown augmentation %s in symbol %s", + augmentation, name); + } } } - - lua_pop (L, 1); /* Table itself */ } } else { + lua_settop(L, prev_top); + return luaL_error (L, "invalid arguments"); } + lua_settop (L, prev_top); lua_pushinteger (L, ret); return 1; |