diff options
author | Vsevolod Stakhov <vsevolod@rspamd.com> | 2024-03-05 21:41:46 +0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-05 21:41:46 +0600 |
commit | 5c8a7059412bead76bb0fb464856fca28fd2ec33 (patch) | |
tree | df0ac1b47cfb5812efe68428d0365470d6feef31 | |
parent | 4ddfbe0a6e705550412f6499ecaf67c035fe191d (diff) | |
parent | bcd36f79596a8666217d29088f6b0040c6cf092b (diff) | |
download | rspamd-5c8a7059412bead76bb0fb464856fca28fd2ec33.tar.gz rspamd-5c8a7059412bead76bb0fb464856fca28fd2ec33.zip |
Merge pull request #4857 from rspamd/vstakhov-lua-udata-opt
[Project] Optimization of userdata hashing
55 files changed, 658 insertions, 404 deletions
diff --git a/src/controller.c b/src/controller.c index f05105e91..c9cda1d62 100644 --- a/src/controller.c +++ b/src/controller.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -34,6 +34,7 @@ #include "utlist.h" #include "libmime/lang_detection.h" #include "mempool_vars_internal.h" +#include "lua/lua_classnames.h" #include <math.h> /* 60 seconds for worker's IO */ @@ -1555,10 +1556,10 @@ rspamd_controller_handle_lua_history(lua_State *L, ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); pconn_ent = lua_newuserdata(L, sizeof(*pconn_ent)); *pconn_ent = conn_ent; - rspamd_lua_setclass(L, "rspamd{csession}", -1); + rspamd_lua_setclass(L, rspamd_csession_classname, -1); lua_pushinteger(L, from); lua_pushinteger(L, to); lua_pushboolean(L, reset); @@ -1916,11 +1917,11 @@ rspamd_controller_handle_lua(struct rspamd_http_connection_entry *conn_ent, } ptask = lua_newuserdata(L, sizeof(*ptask)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; pconn = lua_newuserdata(L, sizeof(*pconn)); - rspamd_lua_setclass(L, "rspamd{csession}", -1); + rspamd_lua_setclass(L, rspamd_csession_classname, -1); *pconn = conn_ent; if (lua_pcall(L, 2, 0, 0) != 0) { @@ -3541,12 +3542,12 @@ rspamd_controller_handle_lua_plugin(struct rspamd_http_connection_entry *conn_en /* Task */ ptask = lua_newuserdata(L, sizeof(*ptask)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; /* Connection */ pconn = lua_newuserdata(L, sizeof(*pconn)); - rspamd_lua_setclass(L, "rspamd{csession}", -1); + rspamd_lua_setclass(L, rspamd_csession_classname, -1); *pconn = conn_ent; /* Query arguments */ @@ -3820,14 +3821,14 @@ static const struct luaL_reg lua_csessionlib_m[] = { static void luaopen_controller(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{csession}", lua_csessionlib_m); + rspamd_lua_new_class(L, rspamd_csession_classname, lua_csessionlib_m); lua_pop(L, 1); } struct rspamd_http_connection_entry * lua_check_controller_entry(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{csession}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_csession_classname); luaL_argcheck(L, ud != NULL, pos, "'csession' expected"); return ud ? *((struct rspamd_http_connection_entry **) ud) : NULL; } @@ -3842,7 +3843,7 @@ lua_csession_get_ev_base(lua_State *L) if (c) { s = c->ud; pbase = lua_newuserdata(L, sizeof(struct ev_loop *)); - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); *pbase = s->ctx->event_loop; } else { @@ -3862,7 +3863,7 @@ lua_csession_get_cfg(lua_State *L) if (c) { s = c->ud; pcfg = lua_newuserdata(L, sizeof(gpointer)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = s->ctx->cfg; } else { diff --git a/src/fuzzy_storage.c b/src/fuzzy_storage.c index b4d2b802b..59a4b815b 100644 --- a/src/fuzzy_storage.c +++ b/src/fuzzy_storage.c @@ -2551,7 +2551,7 @@ static int lua_fuzzy_add_pre_handler(lua_State *L) { struct rspamd_worker *wrk, **pwrk = (struct rspamd_worker **) - rspamd_lua_check_udata(L, 1, "rspamd{worker}"); + rspamd_lua_check_udata(L, 1, rspamd_worker_classname); struct rspamd_fuzzy_storage_ctx *ctx; if (!pwrk) { @@ -2582,7 +2582,7 @@ static int lua_fuzzy_add_post_handler(lua_State *L) { struct rspamd_worker *wrk, **pwrk = (struct rspamd_worker **) - rspamd_lua_check_udata(L, 1, "rspamd{worker}"); + rspamd_lua_check_udata(L, 1, rspamd_worker_classname); struct rspamd_fuzzy_storage_ctx *ctx; if (!pwrk) { @@ -2613,7 +2613,7 @@ static int lua_fuzzy_add_blacklist_handler(lua_State *L) { struct rspamd_worker *wrk, **pwrk = (struct rspamd_worker **) - rspamd_lua_check_udata(L, 1, "rspamd{worker}"); + rspamd_lua_check_udata(L, 1, rspamd_worker_classname); struct rspamd_fuzzy_storage_ctx *ctx; if (!pwrk) { @@ -3458,17 +3458,17 @@ start_fuzzy(struct rspamd_worker *worker) .name = "add_fuzzy_pre_handler", .func = lua_fuzzy_add_pre_handler, }; - rspamd_lua_add_metamethod(ctx->cfg->lua_state, "rspamd{worker}", &fuzzy_lua_reg); + rspamd_lua_add_metamethod(ctx->cfg->lua_state, rspamd_worker_classname, &fuzzy_lua_reg); fuzzy_lua_reg = (luaL_Reg){ .name = "add_fuzzy_post_handler", .func = lua_fuzzy_add_post_handler, }; - rspamd_lua_add_metamethod(ctx->cfg->lua_state, "rspamd{worker}", &fuzzy_lua_reg); + rspamd_lua_add_metamethod(ctx->cfg->lua_state, rspamd_worker_classname, &fuzzy_lua_reg); fuzzy_lua_reg = (luaL_Reg){ .name = "add_fuzzy_blacklist_handler", .func = lua_fuzzy_add_blacklist_handler, }; - rspamd_lua_add_metamethod(ctx->cfg->lua_state, "rspamd{worker}", &fuzzy_lua_reg); + rspamd_lua_add_metamethod(ctx->cfg->lua_state, rspamd_worker_classname, &fuzzy_lua_reg); rspamd_lua_run_postloads(ctx->cfg->lua_state, ctx->cfg, ctx->event_loop, worker); diff --git a/src/libmime/message.c b/src/libmime/message.c index 3acc935e6..4fb118e60 100644 --- a/src/libmime/message.c +++ b/src/libmime/message.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -991,10 +991,10 @@ rspamd_message_from_data(struct rspamd_task *task, const guchar *start, struct rspamd_task **ptask; pmime = lua_newuserdata(L, sizeof(struct rspamd_mime_part *)); - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); *pmime = part; ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; if (lua_pcall(L, 2, 2, 0) != 0) { @@ -1444,10 +1444,10 @@ void rspamd_message_process(struct rspamd_task *task) gint err_idx = lua_gettop(L); lua_pushvalue(L, magic_func_pos); pmime = lua_newuserdata(L, sizeof(struct rspamd_mime_part *)); - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); *pmime = part; ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; if (lua_pcall(L, 2, 2, err_idx) != 0) { @@ -1516,10 +1516,10 @@ void rspamd_message_process(struct rspamd_task *task) gint err_idx = lua_gettop(L); lua_pushvalue(L, content_func_pos); pmime = lua_newuserdata(L, sizeof(struct rspamd_mime_part *)); - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); *pmime = part; ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; if (lua_pcall(L, 2, 0, err_idx) != 0) { diff --git a/src/libmime/scan_result.c b/src/libmime/scan_result.c index a6bc0cb8b..5c89b6560 100644 --- a/src/libmime/scan_result.c +++ b/src/libmime/scan_result.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -566,7 +566,7 @@ rspamd_task_insert_result_full(struct rspamd_task *task, if (!rspamd_lua_universal_pcall(L, mres->symbol_cbref, G_STRLOC, 1, "uss", &err, - "rspamd{task}", task, symbol, mres->name ? mres->name : "default")) { + rspamd_task_classname, task, symbol, mres->name ? mres->name : "default")) { msg_warn_task("cannot call for symbol_cbref for result %s: %e", mres->name ? mres->name : "default", err); g_error_free(err); diff --git a/src/libserver/cfg_rcl.cxx b/src/libserver/cfg_rcl.cxx index 3ac7560a8..39360110f 100644 --- a/src/libserver/cfg_rcl.cxx +++ b/src/libserver/cfg_rcl.cxx @@ -3762,7 +3762,7 @@ rspamd_config_read(struct rspamd_config *cfg, void *pcfg = lua_newuserdata(RSPAMD_LUA_CFG_STATE(cfg), sizeof(void *)); memcpy(pcfg, &cfg, sizeof(void *)); - rspamd_lua_setclass(RSPAMD_LUA_CFG_STATE(cfg), "rspamd{config}", -1); + rspamd_lua_setclass(RSPAMD_LUA_CFG_STATE(cfg), rspamd_config_classname, -1); if (lua_pcall(RSPAMD_LUA_CFG_STATE(cfg), 1, 0, err_idx) != 0) { msg_err_config("cannot call lua init_debug_logging script: %s", diff --git a/src/libserver/dynamic_cfg.c b/src/libserver/dynamic_cfg.c index cd5cc4e30..80121c9cd 100644 --- a/src/libserver/dynamic_cfg.c +++ b/src/libserver/dynamic_cfg.c @@ -482,7 +482,7 @@ rspamd_maybe_add_lua_dynsym(struct rspamd_config *cfg, if (lua_type(L, -1) == LUA_TFUNCTION) { pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); lua_pushstring(L, sym); lua_pushnumber(L, score); @@ -530,7 +530,7 @@ rspamd_maybe_add_lua_dynact(struct rspamd_config *cfg, if (lua_type(L, -1) == LUA_TFUNCTION) { pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); lua_pushstring(L, action); lua_pushnumber(L, score); diff --git a/src/libserver/protocol.c b/src/libserver/protocol.c index 867455754..37a41c111 100644 --- a/src/libserver/protocol.c +++ b/src/libserver/protocol.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -27,6 +27,7 @@ #include "libserver/mempool_vars_internal.h" #include "contrib/fastutf8/fastutf8.h" #include "task.h" +#include "lua/lua_classnames.h" #include <math.h> #ifdef SYS_ZSTD @@ -1923,7 +1924,7 @@ void rspamd_protocol_write_log_pipe(struct rspamd_task *task) if (lua_isfunction(L, -1)) { ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); /* stack: * -1: task * -2: func diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c index d51dba647..15a52228b 100644 --- a/src/libserver/re_cache.c +++ b/src/libserver/re_cache.c @@ -25,6 +25,7 @@ #include "lua/lua_common.h" #include "libstat/stat_api.h" #include "contrib/uthash/utlist.h" +#include "lua/lua_classnames.h" #include "khash.h" @@ -562,7 +563,7 @@ rspamd_re_cache_check_lua_condition(struct rspamd_task *task, if (!rspamd_lua_universal_pcall(L, lua_cbref, G_STRLOC, 1, "utii", &err, - "rspamd{task}", task, + rspamd_task_classname, task, text_pos, start, end)) { msg_warn_task("cannot call for re_cache_check_lua_condition for re %s: %e", rspamd_regexp_get_pattern(re), err); @@ -908,7 +909,7 @@ rspamd_re_cache_process_selector(struct rspamd_task *task, lua_rawgeti(L, LUA_REGISTRYINDEX, ref); ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if ((ret = lua_pcall(L, 1, 1, err_idx)) != 0) { msg_err_task("call to selector %s " diff --git a/src/libserver/symcache/symcache_impl.cxx b/src/libserver/symcache/symcache_impl.cxx index 93675ac16..63ac4a58e 100644 --- a/src/libserver/symcache/symcache_impl.cxx +++ b/src/libserver/symcache/symcache_impl.cxx @@ -1052,7 +1052,7 @@ auto symcache::periodic_resort(struct ev_loop *ev_loop, double cur_time, double lua_rawgeti(L, LUA_REGISTRYINDEX, peak_cb); pbase = (struct ev_loop **) lua_newuserdata(L, sizeof(*pbase)); *pbase = ev_loop; - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); lua_pushlstring(L, item->symbol.c_str(), item->symbol.size()); lua_pushnumber(L, item->st->avg_frequency); lua_pushnumber(L, ::sqrt(item->st->stddev_frequency)); diff --git a/src/libserver/task.c b/src/libserver/task.c index 9763d1eb4..4518477fc 100644 --- a/src/libserver/task.c +++ b/src/libserver/task.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -29,6 +29,7 @@ #include "libserver/cfg_file_private.h" #include "libmime/lang_detection.h" #include "libmime/scan_result_private.h" +#include "lua/lua_classnames.h" #ifdef WITH_JEMALLOC #include <jemalloc/jemalloc.h> @@ -1616,7 +1617,7 @@ void rspamd_task_write_log(struct rspamd_task *task) L = task->cfg->lua_state; lua_rawgeti(L, LUA_REGISTRYINDEX, GPOINTER_TO_INT(lf->data)); ptask = lua_newuserdata(L, sizeof(*ptask)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; if (lua_pcall(L, 1, 1, 0) != 0) { diff --git a/src/libstat/backends/redis_backend.cxx b/src/libstat/backends/redis_backend.cxx index 14e821029..630c895a2 100644 --- a/src/libstat/backends/redis_backend.cxx +++ b/src/libstat/backends/redis_backend.cxx @@ -218,7 +218,7 @@ gsize rspamd_redis_expand_object(const gchar *pattern, lua_rawgeti(L, LUA_REGISTRYINDEX, ctx->cbref_user); ptask = (struct rspamd_task **) lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_pcall(L, 1, 1, err_idx) != 0) { msg_err_task("call to user extraction script failed: %s", @@ -547,7 +547,7 @@ rspamd_redis_init(struct rspamd_stat_ctx *ctx, if (ctx->event_loop) { auto **pev_base = (struct ev_loop **) lua_newuserdata(L, sizeof(struct ev_loop *)); *pev_base = ctx->event_loop; - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); } else { lua_pushnil(L); diff --git a/src/libstat/backends/sqlite3_backend.c b/src/libstat/backends/sqlite3_backend.c index 2fd34d83f..68b52128f 100644 --- a/src/libstat/backends/sqlite3_backend.c +++ b/src/libstat/backends/sqlite3_backend.c @@ -1,11 +1,11 @@ -/*- - * Copyright 2016 Vsevolod Stakhov +/* + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, @@ -177,7 +177,7 @@ rspamd_sqlite3_get_user(struct rspamd_stat_sqlite3_db *db, lua_rawgeti(L, LUA_REGISTRYINDEX, db->cbref_user); ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_pcall(L, 1, 1, err_idx) != 0) { msg_err_task("call to user extraction script failed: %s", @@ -246,7 +246,7 @@ rspamd_sqlite3_get_language(struct rspamd_stat_sqlite3_db *db, lua_rawgeti(L, LUA_REGISTRYINDEX, db->cbref_language); ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_pcall(L, 1, 1, err_idx) != 0) { msg_err_task("call to language extraction script failed: %s", diff --git a/src/libstat/classifiers/lua_classifier.c b/src/libstat/classifiers/lua_classifier.c index b74330dca..30b2a0abd 100644 --- a/src/libstat/classifiers/lua_classifier.c +++ b/src/libstat/classifiers/lua_classifier.c @@ -1,11 +1,11 @@ -/*- - * Copyright 2016 Vsevolod Stakhov +/* + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, @@ -145,10 +145,10 @@ lua_classifier_classify(struct rspamd_classifier *cl, lua_rawgeti(L, LUA_REGISTRYINDEX, ctx->classify_ref); ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cl->cfg; - rspamd_lua_setclass(L, "rspamd{classifier}", -1); + rspamd_lua_setclass(L, rspamd_classifier_classname, -1); lua_createtable(L, tokens->len, 0); @@ -200,10 +200,10 @@ lua_classifier_learn_spam(struct rspamd_classifier *cl, lua_rawgeti(L, LUA_REGISTRYINDEX, ctx->learn_ref); ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cl->cfg; - rspamd_lua_setclass(L, "rspamd{classifier}", -1); + rspamd_lua_setclass(L, rspamd_classifier_classname, -1); lua_createtable(L, tokens->len, 0); diff --git a/src/libstat/stat_config.c b/src/libstat/stat_config.c index 274804461..0e1ae5432 100644 --- a/src/libstat/stat_config.c +++ b/src/libstat/stat_config.c @@ -214,7 +214,7 @@ void rspamd_stat_init(struct rspamd_config *cfg, struct ev_loop *ev_base) pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); if ((ret = lua_pcall(L, 1, 1, err_idx)) != 0) { msg_err_config("call to gen_stat_tokens lua " diff --git a/src/libstat/stat_process.c b/src/libstat/stat_process.c index 8c1d8ff19..c1d194694 100644 --- a/src/libstat/stat_process.c +++ b/src/libstat/stat_process.c @@ -1,11 +1,11 @@ -/*- - * Copyright 2016 Vsevolod Stakhov +/* + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, @@ -21,6 +21,7 @@ #include "libmime/images.h" #include "libserver/html/html.h" #include "lua/lua_common.h" +#include "lua/lua_classnames.h" #include "libserver/mempool_vars_internal.h" #include "utlist.h" #include <math.h> @@ -54,7 +55,7 @@ rspamd_stat_tokenize_parts_metadata(struct rspamd_stat_ctx *st_ctx, ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if ((ret = lua_pcall(L, 1, 1, err_idx)) != 0) { msg_err_task("call to stat_tokens lua " @@ -210,7 +211,7 @@ rspamd_stat_classifier_is_skipped(struct rspamd_task *task, /* Push task and two booleans: is_spam and is_unlearn */ struct rspamd_task **ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (is_learn) { lua_pushboolean(L, is_spam); @@ -1063,7 +1064,7 @@ rspamd_stat_check_autolearn(struct rspamd_task *task) ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_pcall(L, 1, 1, err_idx) != 0) { msg_err_task("call to autolearn script failed: " @@ -1118,7 +1119,7 @@ rspamd_stat_check_autolearn(struct rspamd_task *task) ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); /* Push the whole object as well */ ucl_object_push_lua(L, obj, true); diff --git a/src/lua/CMakeLists.txt b/src/lua/CMakeLists.txt index a504f99f8..46de053ba 100644 --- a/src/lua/CMakeLists.txt +++ b/src/lua/CMakeLists.txt @@ -34,6 +34,7 @@ SET(LUASRC ${CMAKE_CURRENT_SOURCE_DIR}/lua_common.c ${CMAKE_CURRENT_SOURCE_DIR}/lua_spf.c ${CMAKE_CURRENT_SOURCE_DIR}/lua_tensor.c ${CMAKE_CURRENT_SOURCE_DIR}/lua_parsers.c - ${CMAKE_CURRENT_SOURCE_DIR}/lua_compress.c) + ${CMAKE_CURRENT_SOURCE_DIR}/lua_compress.c + ${CMAKE_CURRENT_SOURCE_DIR}/lua_classnames.c) SET(RSPAMD_LUA ${LUASRC} PARENT_SCOPE)
\ No newline at end of file diff --git a/src/lua/lua_cdb.c b/src/lua/lua_cdb.c index 76a5795bb..6831cdabe 100644 --- a/src/lua/lua_cdb.c +++ b/src/lua/lua_cdb.c @@ -104,7 +104,7 @@ static const struct luaL_reg cdblib_f[] = { static struct cdb * lua_check_cdb(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cdb}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cdb_classname); luaL_argcheck(L, ud != NULL, pos, "'cdb' expected"); return ud ? *((struct cdb **) ud) : NULL; @@ -113,7 +113,7 @@ lua_check_cdb(lua_State *L, int pos) static struct cdb_make * lua_check_cdb_builder(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cdb_builder}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cdb_builder_classname); luaL_argcheck(L, ud != NULL, pos, "'cdb_builder' expected"); return ud ? ((struct cdb_make *) ud) : NULL; @@ -135,14 +135,14 @@ lua_cdb_get_input(lua_State *L, int pos, gsize *olen) return numbuf; } case LUA_TUSERDATA: { - void *p = rspamd_lua_check_udata_maybe(L, pos, "rspamd{text}"); + void *p = rspamd_lua_check_udata_maybe(L, pos, rspamd_text_classname); if (p) { struct rspamd_lua_text *t = (struct rspamd_lua_text *) p; *olen = t->len; return t->start; } - p = rspamd_lua_check_udata_maybe(L, pos, "rspamd{int64}"); + p = rspamd_lua_check_udata_maybe(L, pos, rspamd_int64_classname); if (p) { static char numbuf[sizeof(gint64)]; @@ -210,7 +210,7 @@ lua_cdb_create(lua_State *L) cdb_add_timer(cdb, ev_base, CDB_REFRESH_TIME); } pcdb = lua_newuserdata(L, sizeof(struct cdb *)); - rspamd_lua_setclass(L, "rspamd{cdb}", -1); + rspamd_lua_setclass(L, rspamd_cdb_classname, -1); *pcdb = cdb; } } @@ -301,7 +301,7 @@ lua_cdb_build(lua_State *L) struct cdb_make *cdbm = lua_newuserdata(L, sizeof(struct cdb_make)); g_assert(cdb_make_start(cdbm, fd) == 0); - rspamd_lua_setclass(L, "rspamd{cdb_builder}", -1); + rspamd_lua_setclass(L, rspamd_cdb_builder_classname, -1); return 1; } @@ -383,9 +383,9 @@ lua_load_cdb(lua_State *L) void luaopen_cdb(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{cdb}", cdblib_m); + rspamd_lua_new_class(L, rspamd_cdb_classname, cdblib_m); lua_pop(L, 1); - rspamd_lua_new_class(L, "rspamd{cdb_builder}", cdbbuilderlib_m); + rspamd_lua_new_class(L, rspamd_cdb_builder_classname, cdbbuilderlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cdb", lua_load_cdb); } diff --git a/src/lua/lua_classifier.c b/src/lua/lua_classifier.c index 39580a60d..eb50f1950 100644 --- a/src/lua/lua_classifier.c +++ b/src/lua/lua_classifier.c @@ -48,7 +48,7 @@ static struct rspamd_statfile_config *lua_check_statfile(lua_State *L); static struct rspamd_classifier_config * lua_check_classifier(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{classifier}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_classifier_classname); luaL_argcheck(L, ud != NULL, 1, "'classifier' expected"); return ud ? *((struct rspamd_classifier_config **) ud) : NULL; } @@ -69,7 +69,7 @@ lua_classifier_get_statfiles(lua_State *L) while (cur) { st = cur->data; pst = lua_newuserdata(L, sizeof(struct rspamd_statfile_config *)); - rspamd_lua_setclass(L, "rspamd{statfile}", -1); + rspamd_lua_setclass(L, rspamd_statfile_classname, -1); *pst = st; lua_rawseti(L, -2, i++); @@ -127,7 +127,7 @@ lua_classifier_get_statfile_by_label(lua_State *L) pst = lua_newuserdata(L, sizeof(struct rspamd_statfile_config *)); - rspamd_lua_setclass(L, "rspamd{statfile}", -1); + rspamd_lua_setclass(L, rspamd_statfile_classname, -1); *pst = st; lua_rawseti(L, -2, i++); cur = g_list_next(cur); @@ -209,7 +209,7 @@ lua_statfile_get_param(lua_State *L) static struct rspamd_statfile_config * lua_check_statfile(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{statfile}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_statfile_classname); luaL_argcheck(L, ud != NULL, 1, "'statfile' expected"); return ud ? *((struct rspamd_statfile_config **) ud) : NULL; } @@ -219,12 +219,12 @@ lua_check_statfile(lua_State *L) void luaopen_classifier(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{classifier}", classifierlib_m); + rspamd_lua_new_class(L, rspamd_classifier_classname, classifierlib_m); lua_pop(L, 1); /* remove metatable from stack */ } void luaopen_statfile(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{statfile}", statfilelib_m); + rspamd_lua_new_class(L, rspamd_statfile_classname, statfilelib_m); lua_pop(L, 1); /* remove metatable from stack */ } diff --git a/src/lua/lua_classnames.c b/src/lua/lua_classnames.c new file mode 100644 index 000000000..7041a8ca1 --- /dev/null +++ b/src/lua/lua_classnames.c @@ -0,0 +1,166 @@ +/* + * Copyright 2024 Vsevolod Stakhov + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "config.h" +#include "libutil/str_util.h" +#include "khash.h" +#include "lua_classnames.h" + +const char *rspamd_archive_classname = "rspamd{archive}"; +const char *rspamd_cdb_builder_classname = "rspamd{cdb_builder}"; +const char *rspamd_cdb_classname = "rspamd{cdb}"; +const char *rspamd_classifier_classname = "rspamd{classifier}"; +const char *rspamd_config_classname = "rspamd{config}"; +const char *rspamd_cryptobox_hash_classname = "rspamd{cryptobox_hash}"; +const char *rspamd_cryptobox_keypair_classname = "rspamd{cryptobox_keypair}"; +const char *rspamd_cryptobox_pubkey_classname = "rspamd{cryptobox_pubkey}"; +const char *rspamd_cryptobox_secretbox_classname = "rspamd{cryptobox_secretbox}"; +const char *rspamd_cryptobox_signature_classname = "rspamd{cryptobox_signature}"; +const char *rspamd_csession_classname = "rspamd{csession}"; +const char *rspamd_ev_base_classname = "rspamd{ev_base}"; +const char *rspamd_expr_classname = "rspamd{expr}"; +const char *rspamd_html_tag_classname = "rspamd{html_tag}"; +const char *rspamd_html_classname = "rspamd{html}"; +const char *rspamd_image_classname = "rspamd{image}"; +const char *rspamd_int64_classname = "rspamd{int64}"; +const char *rspamd_ip_classname = "rspamd{ip}"; +const char *rspamd_kann_node_classname = "rspamd{kann_node}"; +const char *rspamd_kann_classname = "rspamd{kann}"; +const char *rspamd_map_classname = "rspamd{map}"; +const char *rspamd_mempool_classname = "rspamd{mempool}"; +const char *rspamd_mimepart_classname = "rspamd{mimepart}"; +const char *rspamd_monitored_classname = "rspamd{monitored}"; +const char *rspamd_redis_classname = "rspamd{redis}"; +const char *rspamd_regexp_classname = "rspamd{regexp}"; +const char *rspamd_resolver_classname = "rspamd{resolver}"; +const char *rspamd_rsa_privkey_classname = "rspamd{rsa_privkey}"; +const char *rspamd_rsa_pubkey_classname = "rspamd{rsa_pubkey}"; +const char *rspamd_rsa_signature_classname = "rspamd{rsa_signature}"; +const char *rspamd_session_classname = "rspamd{session}"; +const char *rspamd_spf_record_classname = "rspamd{spf_record}"; +const char *rspamd_sqlite3_stmt_classname = "rspamd{sqlite3_stmt}"; +const char *rspamd_sqlite3_classname = "rspamd{sqlite3}"; +const char *rspamd_statfile_classname = "rspamd{statfile}"; +const char *rspamd_task_classname = "rspamd{task}"; +const char *rspamd_tcp_sync_classname = "rspamd{tcp_sync}"; +const char *rspamd_tcp_classname = "rspamd{tcp}"; +const char *rspamd_tensor_classname = "rspamd{tensor}"; +const char *rspamd_textpart_classname = "rspamd{textpart}"; +const char *rspamd_text_classname = "rspamd{text}"; +const char *rspamd_trie_classname = "rspamd{trie}"; +const char *rspamd_upstream_list_classname = "rspamd{upstream_list}"; +const char *rspamd_upstream_classname = "rspamd{upstream}"; +const char *rspamd_url_classname = "rspamd{url}"; +const char *rspamd_worker_classname = "rspamd{worker}"; +const char *rspamd_zstd_compress_classname = "rspamd{zstd_compress}"; +const char *rspamd_zstd_decompress_classname = "rspamd{zstd_decompress}"; + +KHASH_INIT(rspamd_lua_static_classes, const char *, const char *, 1, rspamd_str_hash, rspamd_str_equal); + +static khash_t(rspamd_lua_static_classes) *lua_static_classes = NULL; + +#define CLASS_PUT_STR(s) \ + do { \ + int _r = 0; \ + khiter_t it = kh_put(rspamd_lua_static_classes, lua_static_classes, #s, &_r); \ + g_assert(_r > 0); \ + kh_value(lua_static_classes, it) = rspamd_##s##_classname; \ + } while (0) + +RSPAMD_CONSTRUCTOR(rspamd_lua_init_classnames) +{ + lua_static_classes = kh_init(rspamd_lua_static_classes); + kh_resize(rspamd_lua_static_classes, lua_static_classes, RSPAMD_MAX_LUA_CLASSES); + + CLASS_PUT_STR(archive); + CLASS_PUT_STR(cdb_builder); + CLASS_PUT_STR(cdb); + CLASS_PUT_STR(classifier); + CLASS_PUT_STR(config); + CLASS_PUT_STR(cryptobox_hash); + CLASS_PUT_STR(cryptobox_keypair); + CLASS_PUT_STR(cryptobox_pubkey); + CLASS_PUT_STR(cryptobox_secretbox); + CLASS_PUT_STR(cryptobox_signature); + CLASS_PUT_STR(csession); + CLASS_PUT_STR(ev_base); + CLASS_PUT_STR(expr); + CLASS_PUT_STR(html_tag); + CLASS_PUT_STR(html); + CLASS_PUT_STR(image); + CLASS_PUT_STR(int64); + CLASS_PUT_STR(ip); + CLASS_PUT_STR(kann_node); + CLASS_PUT_STR(kann); + CLASS_PUT_STR(map); + CLASS_PUT_STR(mempool); + CLASS_PUT_STR(mimepart); + CLASS_PUT_STR(monitored); + CLASS_PUT_STR(redis); + CLASS_PUT_STR(regexp); + CLASS_PUT_STR(resolver); + CLASS_PUT_STR(rsa_privkey); + CLASS_PUT_STR(rsa_pubkey); + CLASS_PUT_STR(rsa_signature); + CLASS_PUT_STR(session); + CLASS_PUT_STR(spf_record); + CLASS_PUT_STR(sqlite3_stmt); + CLASS_PUT_STR(sqlite3); + CLASS_PUT_STR(statfile); + CLASS_PUT_STR(task); + CLASS_PUT_STR(tcp_sync); + CLASS_PUT_STR(tcp); + CLASS_PUT_STR(tensor); + CLASS_PUT_STR(textpart); + CLASS_PUT_STR(text); + CLASS_PUT_STR(trie); + CLASS_PUT_STR(upstream_list); + CLASS_PUT_STR(upstream); + CLASS_PUT_STR(url); + CLASS_PUT_STR(worker); + CLASS_PUT_STR(zstd_compress); + CLASS_PUT_STR(zstd_decompress); + + /* Check consistency */ + g_assert(kh_size(lua_static_classes) == RSPAMD_MAX_LUA_CLASSES); +} + +const char * +rspamd_lua_static_classname(const char *name, guint len) +{ + khiter_t k; + + g_assert(lua_static_classes != NULL); + char classbuf[128]; + + rspamd_strlcpy(classbuf, name, MIN(sizeof(classbuf), len + 1)); + name = classbuf; + + k = kh_get(rspamd_lua_static_classes, lua_static_classes, name); + + if (k != kh_end(lua_static_classes)) { + return kh_value(lua_static_classes, k); + } + + return NULL; +} + +RSPAMD_DESTRUCTOR(rspamd_lua_deinit_classnames) +{ + if (lua_static_classes != NULL) { + kh_destroy(rspamd_lua_static_classes, lua_static_classes); + } +}
\ No newline at end of file diff --git a/src/lua/lua_classnames.h b/src/lua/lua_classnames.h new file mode 100644 index 000000000..2563249b5 --- /dev/null +++ b/src/lua/lua_classnames.h @@ -0,0 +1,82 @@ +/* + * Copyright 2024 Vsevolod Stakhov + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + + +#ifndef RSPAMD_LUA_CLASSNAMES_H +#define RSPAMD_LUA_CLASSNAMES_H + +/* + * Here are static definitions of all classes used in Rspamd Lua API + */ + +extern const char *rspamd_archive_classname; +extern const char *rspamd_cdb_builder_classname; +extern const char *rspamd_cdb_classname; +extern const char *rspamd_classifier_classname; +extern const char *rspamd_config_classname; +extern const char *rspamd_cryptobox_hash_classname; +extern const char *rspamd_cryptobox_keypair_classname; +extern const char *rspamd_cryptobox_pubkey_classname; +extern const char *rspamd_cryptobox_secretbox_classname; +extern const char *rspamd_cryptobox_signature_classname; +extern const char *rspamd_csession_classname; +extern const char *rspamd_ev_base_classname; +extern const char *rspamd_expr_classname; +extern const char *rspamd_html_tag_classname; +extern const char *rspamd_html_classname; +extern const char *rspamd_image_classname; +extern const char *rspamd_int64_classname; +extern const char *rspamd_ip_classname; +extern const char *rspamd_kann_node_classname; +extern const char *rspamd_kann_classname; +extern const char *rspamd_map_classname; +extern const char *rspamd_mempool_classname; +extern const char *rspamd_mimepart_classname; +extern const char *rspamd_monitored_classname; +extern const char *rspamd_redis_classname; +extern const char *rspamd_regexp_classname; +extern const char *rspamd_resolver_classname; +extern const char *rspamd_rsa_privkey_classname; +extern const char *rspamd_rsa_pubkey_classname; +extern const char *rspamd_rsa_signature_classname; +extern const char *rspamd_session_classname; +extern const char *rspamd_spf_record_classname; +extern const char *rspamd_sqlite3_stmt_classname; +extern const char *rspamd_sqlite3_classname; +extern const char *rspamd_statfile_classname; +extern const char *rspamd_task_classname; +extern const char *rspamd_tcp_sync_classname; +extern const char *rspamd_tcp_classname; +extern const char *rspamd_tensor_classname; +extern const char *rspamd_textpart_classname; +extern const char *rspamd_text_classname; +extern const char *rspamd_trie_classname; +extern const char *rspamd_upstream_list_classname; +extern const char *rspamd_upstream_classname; +extern const char *rspamd_url_classname; +extern const char *rspamd_worker_classname; +extern const char *rspamd_zstd_compress_classname; +extern const char *rspamd_zstd_decompress_classname; + +/* Keep it consistent when adding new classes */ +#define RSPAMD_MAX_LUA_CLASSES 48 + +/* + * Return a static class name for a given name (only for known classes) or NULL + */ +const char *rspamd_lua_static_classname(const char *name, guint len); + +#endif//RSPAMD_LUA_CLASSNAMES_H diff --git a/src/lua/lua_common.c b/src/lua/lua_common.c index 9bf9514f6..8474ff790 100644 --- a/src/lua/lua_common.c +++ b/src/lua/lua_common.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -48,7 +48,7 @@ lua_error_quark(void) /* * Used to map string to a pointer */ -KHASH_INIT(lua_class_set, const char *, int, 1, rspamd_str_hash, rspamd_str_equal); +KHASH_INIT(lua_class_set, int, int, 1, kh_int_hash_func, kh_int_hash_equal); struct rspamd_lua_context { lua_State *L; khash_t(lua_class_set) * classes; @@ -76,7 +76,7 @@ rspamd_lua_ctx_by_state(lua_State *L) /** * Create new class and store metatable on top of the stack (must be popped if not needed) * @param L - * @param classname name of class + * @param classname name of class, **MUST** be a static string * @param func table of class methods */ void rspamd_lua_new_class(lua_State *L, @@ -120,7 +120,7 @@ void rspamd_lua_new_class(lua_State *L, lua_pushvalue(L, -1); /* Preserves metatable */ int offset = luaL_ref(L, LUA_REGISTRYINDEX); - k = kh_put(lua_class_set, ctx->classes, classname, &r); + k = kh_put(lua_class_set, ctx->classes, GPOINTER_TO_INT(classname), &r); kh_value(ctx->classes, k) = offset; /* MT is left on stack ! */ } @@ -183,7 +183,7 @@ void rspamd_lua_setclass(lua_State *L, const gchar *classname, gint objidx) khiter_t k; struct rspamd_lua_context *ctx = rspamd_lua_ctx_by_state(L); - k = kh_get(lua_class_set, ctx->classes, classname); + k = kh_get(lua_class_set, ctx->classes, GPOINTER_TO_INT(classname)); g_assert(k != kh_end(ctx->classes)); lua_rawgeti(L, LUA_REGISTRYINDEX, kh_value(ctx->classes, k)); @@ -199,7 +199,7 @@ void rspamd_lua_class_metatable(lua_State *L, const gchar *classname) khiter_t k; struct rspamd_lua_context *ctx = rspamd_lua_ctx_by_state(L); - k = kh_get(lua_class_set, ctx->classes, classname); + k = kh_get(lua_class_set, ctx->classes, GPOINTER_TO_INT(classname)); g_assert(k != kh_end(ctx->classes)); lua_rawgeti(L, LUA_REGISTRYINDEX, kh_value(ctx->classes, k)); @@ -211,7 +211,7 @@ void rspamd_lua_add_metamethod(lua_State *L, const gchar *classname, khiter_t k; struct rspamd_lua_context *ctx = rspamd_lua_ctx_by_state(L); - k = kh_get(lua_class_set, ctx->classes, classname); + k = kh_get(lua_class_set, ctx->classes, GPOINTER_TO_INT(classname)); g_assert(k != kh_end(ctx->classes)); lua_rawgeti(L, LUA_REGISTRYINDEX, kh_value(ctx->classes, k)); @@ -855,7 +855,7 @@ void rspamd_lua_set_globals(struct rspamd_config *cfg, lua_State *L) if (cfg != NULL) { pcfg = lua_newuserdata(L, sizeof(struct rspamd_config *)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; lua_setglobal(L, "rspamd_config"); } @@ -987,7 +987,7 @@ rspamd_lua_init(bool wipe_mem) lua_settop(L, 0); #endif - rspamd_lua_new_class(L, "rspamd{session}", NULL); + rspamd_lua_new_class(L, rspamd_session_classname, NULL); lua_pop(L, 1); rspamd_lua_add_preload(L, "lpeg", luaopen_lpeg); @@ -1122,7 +1122,7 @@ rspamd_init_lua_filters(struct rspamd_config *cfg, bool force_load, bool strict) gint err_idx, i; pcfg = lua_newuserdata(L, sizeof(struct rspamd_config *)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; lua_setglobal(L, "rspamd_config"); @@ -1277,7 +1277,7 @@ rspamd_lua_check_class(lua_State *L, gint index, const gchar *name) if (lua_getmetatable(L, index)) { struct rspamd_lua_context *ctx = rspamd_lua_ctx_by_state(L); - k = kh_get(lua_class_set, ctx->classes, name); + k = kh_get(lua_class_set, ctx->classes, GPOINTER_TO_INT(name)); if (k == kh_end(ctx->classes)) { lua_pop(L, 1); @@ -1326,7 +1326,6 @@ rspamd_lua_parse_table_arguments(lua_State *L, gint pos, const gchar *p, *key = NULL, *end, *cls; va_list ap; gboolean required = FALSE, failed = FALSE, is_table; - gchar classbuf[128]; enum { read_key = 0, read_arg, @@ -1818,15 +1817,14 @@ rspamd_lua_parse_table_arguments(lua_State *L, gint pos, return FALSE; } - rspamd_snprintf(classbuf, sizeof(classbuf), "rspamd{%*s}", - (gint) clslen, cls); - + const char *static_cls = rspamd_lua_static_classname(cls, clslen); /* * We skip class check here for speed in non-table mode */ if (!failed && (!is_table || - rspamd_lua_check_class(L, idx, classbuf))) { + static_cls == NULL || + rspamd_lua_check_class(L, idx, static_cls))) { if (direct_userdata) { void **arg_p = (va_arg(ap, void **)); *arg_p = lua_touserdata(L, idx); @@ -1844,7 +1842,7 @@ rspamd_lua_parse_table_arguments(lua_State *L, gint pos, "invalid class for key %.*s, expected %s, got %s", (gint) keylen, key, - classbuf, + static_cls, rspamd_lua_class_tostring_buf(L, FALSE, idx)); va_end(ap); @@ -1984,7 +1982,7 @@ rspamd_lua_check_udata_common(lua_State *L, gint pos, const gchar *classname, if (lua_getmetatable(L, pos)) { struct rspamd_lua_context *ctx = rspamd_lua_ctx_by_state(L); - k = kh_get(lua_class_set, ctx->classes, classname); + k = kh_get(lua_class_set, ctx->classes, GPOINTER_TO_INT(classname)); if (k == kh_end(ctx->classes)) { goto err; @@ -2084,7 +2082,7 @@ rspamd_lua_check_udata_maybe(lua_State *L, gint pos, const gchar *classname) struct rspamd_async_session * lua_check_session(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{session}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_session_classname); luaL_argcheck(L, ud != NULL, pos, "'session' expected"); return ud ? *((struct rspamd_async_session **) ud) : NULL; } @@ -2092,7 +2090,7 @@ lua_check_session(lua_State *L, gint pos) struct ev_loop * lua_check_ev_base(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{ev_base}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_ev_base_classname); luaL_argcheck(L, ud != NULL, pos, "'event_base' expected"); return ud ? *((struct ev_loop **) ud) : NULL; } @@ -2117,15 +2115,15 @@ void rspamd_lua_run_postloads(lua_State *L, struct rspamd_config *cfg, lua_rawgeti(L, LUA_REGISTRYINDEX, sc->cbref); pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); pev_base = lua_newuserdata(L, sizeof(*pev_base)); *pev_base = ev_base; - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); pw = lua_newuserdata(L, sizeof(*pw)); *pw = w; - rspamd_lua_setclass(L, "rspamd{worker}", -1); + rspamd_lua_setclass(L, rspamd_worker_classname, -1); lua_thread_call(thread, 3); } @@ -2145,7 +2143,7 @@ void rspamd_lua_run_config_post_init(lua_State *L, struct rspamd_config *cfg) lua_rawgeti(L, LUA_REGISTRYINDEX, sc->cbref); pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); if (lua_pcall(L, 1, 0, err_idx) != 0) { msg_err_config("cannot run config post init script: %s; priority = %d", @@ -2170,7 +2168,7 @@ void rspamd_lua_run_config_unload(lua_State *L, struct rspamd_config *cfg) lua_rawgeti(L, LUA_REGISTRYINDEX, sc->cbref); pcfg = lua_newuserdata(L, sizeof(*pcfg)); *pcfg = cfg; - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); if (lua_pcall(L, 1, 0, err_idx) != 0) { msg_err_config("cannot run config post init script: %s", @@ -2365,7 +2363,7 @@ rspamd_lua_try_load_redis(lua_State *L, const ucl_object_t *obj, /* Function arguments */ ucl_object_push_lua(L, obj, false); pcfg = lua_newuserdata(L, sizeof(*pcfg)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; lua_pushboolean(L, false); /* no_fallback */ diff --git a/src/lua/lua_common.h b/src/lua/lua_common.h index cc2b94390..31a8c2fac 100644 --- a/src/lua/lua_common.h +++ b/src/lua/lua_common.h @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -19,6 +19,7 @@ #include "config.h" + /* Lua headers do not have __cplusplus guards... */ #ifdef __cplusplus extern "C" { @@ -40,6 +41,7 @@ extern "C" { #include "rspamd.h" #include "ucl.h" #include "lua_ucl.h" +#include "lua_classnames.h" #ifdef __cplusplus extern "C" { @@ -174,6 +176,8 @@ void rspamd_lua_new_class(lua_State *L, /** * Set class name for object at @param objidx position +* @param L + * @param classname **MUST BE STATIC**, direct address is used for comparisons! */ void rspamd_lua_setclass(lua_State *L, const gchar *classname, gint objidx); @@ -535,7 +539,7 @@ gsize lua_logger_out_type(lua_State *L, gint pos, gchar *outbuf, * Safely checks userdata to match specified class * @param L * @param pos -* @param classname +* @param classname **MUST BE STATIC**, direct address is used for comparisons! */ void *rspamd_lua_check_udata(lua_State *L, gint pos, const gchar *classname); @@ -552,7 +556,7 @@ void *rspamd_lua_check_udata(lua_State *L, gint pos, const gchar *classname); * Safely checks userdata to match specified class * @param L * @param pos -* @param classname +* @param classname **MUST BE STATIC**, direct address is used for comparisons! */ void *rspamd_lua_check_udata_maybe(lua_State *L, gint pos, const gchar *classname); diff --git a/src/lua/lua_compress.c b/src/lua/lua_compress.c index 77c82c557..39776ccf6 100644 --- a/src/lua/lua_compress.c +++ b/src/lua/lua_compress.c @@ -69,7 +69,7 @@ static const struct luaL_reg zstd_decompress_lib_m[] = { static ZSTD_CStream * lua_check_zstd_compress_ctx(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{zstd_compress}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_zstd_compress_classname); luaL_argcheck(L, ud != NULL, pos, "'zstd_compress' expected"); return ud ? *(ZSTD_CStream **) ud : NULL; } @@ -77,7 +77,7 @@ lua_check_zstd_compress_ctx(lua_State *L, gint pos) static ZSTD_DStream * lua_check_zstd_decompress_ctx(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{zstd_decompress}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_zstd_decompress_classname); luaL_argcheck(L, ud != NULL, pos, "'zstd_decompress' expected"); return ud ? *(ZSTD_DStream **) ud : NULL; } @@ -119,7 +119,7 @@ gint lua_compress_zstd_compress(lua_State *L) res = lua_newuserdata(L, sizeof(*res)); res->start = g_malloc(sz); res->flags = RSPAMD_TEXT_FLAG_OWN; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); r = ZSTD_compress((void *) res->start, sz, t->start, t->len, comp_level); if (ZSTD_isError(r)) { @@ -194,7 +194,7 @@ gint lua_compress_zstd_decompress(lua_State *L) res = lua_newuserdata(L, sizeof(*res)); res->start = out; res->flags = RSPAMD_TEXT_FLAG_OWN; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); res->len = zout.pos; return 2; @@ -254,7 +254,7 @@ gint lua_compress_zlib_decompress(lua_State *L, bool is_gzip) res = lua_newuserdata(L, sizeof(*res)); res->start = g_malloc(sz); res->flags = RSPAMD_TEXT_FLAG_OWN; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); p = (guchar *) res->start; remain = sz; @@ -351,7 +351,7 @@ gint lua_compress_zlib_compress(lua_State *L) res = lua_newuserdata(L, sizeof(*res)); res->start = g_malloc(sz); res->flags = RSPAMD_TEXT_FLAG_OWN; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); p = (guchar *) res->start; remain = sz; @@ -417,7 +417,7 @@ lua_zstd_compress_ctx(lua_State *L) } *pctx = ctx; - rspamd_lua_setclass(L, "rspamd{zstd_compress}", -1); + rspamd_lua_setclass(L, rspamd_zstd_compress_classname, -1); return 1; } @@ -535,7 +535,7 @@ lua_zstd_decompress_ctx(lua_State *L) } *pctx = ctx; - rspamd_lua_setclass(L, "rspamd{zstd_decompress}", -1); + rspamd_lua_setclass(L, rspamd_zstd_decompress_classname, -1); return 1; } @@ -614,8 +614,8 @@ lua_load_zstd(lua_State *L) void luaopen_compress(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{zstd_compress}", zstd_compress_lib_m); - rspamd_lua_new_class(L, "rspamd{zstd_decompress}", zstd_decompress_lib_m); + rspamd_lua_new_class(L, rspamd_zstd_compress_classname, zstd_compress_lib_m); + rspamd_lua_new_class(L, rspamd_zstd_decompress_classname, zstd_decompress_lib_m); lua_pop(L, 2); rspamd_lua_add_preload(L, "rspamd_zstd", lua_load_zstd); diff --git a/src/lua/lua_config.c b/src/lua/lua_config.c index a044827a7..ad8a6d0bf 100644 --- a/src/lua/lua_config.c +++ b/src/lua/lua_config.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -947,7 +947,7 @@ static const guint64 rspamd_lua_callback_magic = 0x32c118af1e3263c7ULL; struct rspamd_config * lua_check_config(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{config}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_config_classname); luaL_argcheck(L, ud != NULL, pos, "'config' expected"); return ud ? *((struct rspamd_config **) ud) : NULL; } @@ -955,7 +955,7 @@ lua_check_config(lua_State *L, gint pos) static struct rspamd_monitored * lua_check_monitored(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{monitored}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_monitored_classname); luaL_argcheck(L, ud != NULL, pos, "'monitored' expected"); return ud ? *((struct rspamd_monitored **) ud) : NULL; } @@ -1002,7 +1002,7 @@ lua_config_get_mempool(lua_State *L) if (cfg != NULL) { ppool = lua_newuserdata(L, sizeof(rspamd_mempool_t *)); - rspamd_lua_setclass(L, "rspamd{mempool}", -1); + rspamd_lua_setclass(L, rspamd_mempool_classname, -1); *ppool = cfg->cfg_pool; } else { @@ -1020,7 +1020,7 @@ lua_config_get_resolver(lua_State *L) if (cfg != NULL && cfg->dns_resolver) { pres = lua_newuserdata(L, sizeof(*pres)); - rspamd_lua_setclass(L, "rspamd{resolver}", -1); + rspamd_lua_setclass(L, rspamd_resolver_classname, -1); *pres = cfg->dns_resolver; } else { @@ -1160,7 +1160,7 @@ lua_config_get_classifier(lua_State *L) if (pclc) { pclc = lua_newuserdata(L, sizeof(struct rspamd_classifier_config *)); - rspamd_lua_setclass(L, "rspamd{classifier}", -1); + rspamd_lua_setclass(L, rspamd_classifier_classname, -1); *pclc = clc; return 1; } @@ -1242,7 +1242,7 @@ lua_metric_symbol_callback(struct rspamd_task *task, } ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; if ((ret = lua_pcall(L, 1, LUA_MULTRET, err_idx)) != 0) { @@ -1382,7 +1382,7 @@ lua_metric_symbol_callback_coro(struct rspamd_task *task, } ptask = lua_newuserdata(thread, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(thread, "rspamd{task}", -1); + rspamd_lua_setclass(thread, rspamd_task_classname, -1); *ptask = task; thread_entry->finish_callback = lua_metric_symbol_callback_return; @@ -3361,11 +3361,11 @@ lua_periodic_callback(struct ev_loop *loop, ev_timer *w, int revents) lua_rawgeti(L, LUA_REGISTRYINDEX, periodic->cbref); pcfg = lua_newuserdata(L, sizeof(*pcfg)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); cfg = periodic->cfg; *pcfg = cfg; pev_base = lua_newuserdata(L, sizeof(*pev_base)); - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); *pev_base = periodic->event_loop; lua_pushnumber(L, ev_now(periodic->event_loop)); @@ -3532,7 +3532,7 @@ lua_config_get_symbols_cksum(lua_State *L) pres = lua_newuserdata(L, sizeof(res)); *pres = res; - rspamd_lua_setclass(L, "rspamd{int64}", -1); + rspamd_lua_setclass(L, rspamd_int64_classname, -1); return 1; } @@ -4094,7 +4094,7 @@ lua_config_register_monitored(lua_State *L) if (m) { pm = lua_newuserdata(L, sizeof(*pm)); *pm = m; - rspamd_lua_setclass(L, "rspamd{monitored}", -1); + rspamd_lua_setclass(L, rspamd_monitored_classname, -1); } else { lua_pushnil(L); @@ -4591,7 +4591,7 @@ lua_config_register_re_selector(lua_State *L) lua_pushvalue(L, -2); pcfg = lua_newuserdata(L, sizeof(*pcfg)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; lua_pushstring(L, selector_str); lua_pushstring(L, delimiter); @@ -4749,11 +4749,11 @@ lua_monitored_latency(lua_State *L) void luaopen_config(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{config}", configlib_m); + rspamd_lua_new_class(L, rspamd_config_classname, configlib_m); lua_pop(L, 1); - rspamd_lua_new_class(L, "rspamd{monitored}", monitoredlib_m); + rspamd_lua_new_class(L, rspamd_monitored_classname, monitoredlib_m); lua_pop(L, 1); } @@ -4773,7 +4773,7 @@ void lua_call_finish_script(struct rspamd_config_cfg_lua_script *sc, lua_rawgeti(L, LUA_REGISTRYINDEX, sc->cbref); ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; lua_thread_call(thread, 1); diff --git a/src/lua/lua_cryptobox.c b/src/lua/lua_cryptobox.c index 70c6f0ad4..5e81229ac 100644 --- a/src/lua/lua_cryptobox.c +++ b/src/lua/lua_cryptobox.c @@ -210,7 +210,7 @@ struct rspamd_lua_cryptobox_secretbox { static struct rspamd_cryptobox_pubkey * lua_check_cryptobox_pubkey(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cryptobox_pubkey}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cryptobox_pubkey_classname); luaL_argcheck(L, ud != NULL, 1, "'cryptobox_pubkey' expected"); return ud ? *((struct rspamd_cryptobox_pubkey **) ud) : NULL; @@ -219,7 +219,7 @@ lua_check_cryptobox_pubkey(lua_State *L, int pos) static struct rspamd_cryptobox_keypair * lua_check_cryptobox_keypair(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cryptobox_keypair}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cryptobox_keypair_classname); luaL_argcheck(L, ud != NULL, 1, "'cryptobox_keypair' expected"); return ud ? *((struct rspamd_cryptobox_keypair **) ud) : NULL; @@ -228,7 +228,7 @@ lua_check_cryptobox_keypair(lua_State *L, int pos) static rspamd_fstring_t * lua_check_cryptobox_sign(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cryptobox_signature}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cryptobox_signature_classname); luaL_argcheck(L, ud != NULL, 1, "'cryptobox_signature' expected"); return ud ? *((rspamd_fstring_t **) ud) : NULL; @@ -237,7 +237,7 @@ lua_check_cryptobox_sign(lua_State *L, int pos) struct rspamd_lua_cryptobox_hash * lua_check_cryptobox_hash(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cryptobox_hash}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cryptobox_hash_classname); luaL_argcheck(L, ud != NULL, 1, "'cryptobox_hash' expected"); return ud ? *((struct rspamd_lua_cryptobox_hash **) ud) : NULL; @@ -246,7 +246,7 @@ lua_check_cryptobox_hash(lua_State *L, int pos) static struct rspamd_lua_cryptobox_secretbox * lua_check_cryptobox_secretbox(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{cryptobox_secretbox}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_cryptobox_secretbox_classname); luaL_argcheck(L, ud != NULL, 1, "'cryptobox_secretbox' expected"); return ud ? *((struct rspamd_lua_cryptobox_secretbox **) ud) : NULL; @@ -315,7 +315,7 @@ lua_cryptobox_pubkey_load(lua_State *L) else { munmap(map, len); ppkey = lua_newuserdata(L, sizeof(void *)); - rspamd_lua_setclass(L, "rspamd{cryptobox_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_pubkey_classname, -1); *ppkey = pkey; } } @@ -379,7 +379,7 @@ lua_cryptobox_pubkey_create(lua_State *L) } else { ppkey = lua_newuserdata(L, sizeof(void *)); - rspamd_lua_setclass(L, "rspamd{cryptobox_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_pubkey_classname, -1); *ppkey = pkey; } } @@ -443,7 +443,7 @@ lua_cryptobox_keypair_load(lua_State *L) else { pkp = lua_newuserdata(L, sizeof(gpointer)); *pkp = kp; - rspamd_lua_setclass(L, "rspamd{cryptobox_keypair}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_keypair_classname, -1); ucl_object_unref(obj); } } @@ -465,7 +465,7 @@ lua_cryptobox_keypair_load(lua_State *L) else { pkp = lua_newuserdata(L, sizeof(gpointer)); *pkp = kp; - rspamd_lua_setclass(L, "rspamd{cryptobox_keypair}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_keypair_classname, -1); ucl_object_unref(obj); } } @@ -520,7 +520,7 @@ lua_cryptobox_keypair_create(lua_State *L) pkp = lua_newuserdata(L, sizeof(gpointer)); *pkp = kp; - rspamd_lua_setclass(L, "rspamd{cryptobox_keypair}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_keypair_classname, -1); return 1; } @@ -644,7 +644,7 @@ lua_cryptobox_keypair_get_pk(lua_State *L) ppk = lua_newuserdata(L, sizeof(*ppk)); *ppk = pk; - rspamd_lua_setclass(L, "rspamd{cryptobox_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_pubkey_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -705,7 +705,7 @@ lua_cryptobox_signature_load(lua_State *L) if (st.st_size > 0) { sig = rspamd_fstring_new_init(data, st.st_size); psig = lua_newuserdata(L, sizeof(rspamd_fstring_t *)); - rspamd_lua_setclass(L, "rspamd{cryptobox_signature}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_signature_classname, -1); *psig = sig; } else { @@ -824,7 +824,7 @@ lua_cryptobox_signature_create(lua_State *L) if (dlen == rspamd_cryptobox_signature_bytes(RSPAMD_CRYPTOBOX_MODE_25519)) { sig = rspamd_fstring_new_init(data, dlen); psig = lua_newuserdata(L, sizeof(rspamd_fstring_t *)); - rspamd_lua_setclass(L, "rspamd{cryptobox_signature}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_signature_classname, -1); *psig = sig; } } @@ -1209,7 +1209,7 @@ lua_cryptobox_hash_create(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); return 1; } @@ -1261,7 +1261,7 @@ lua_cryptobox_hash_create_specific(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); return 1; } @@ -1308,7 +1308,7 @@ lua_cryptobox_hash_create_keyed(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -1364,7 +1364,7 @@ lua_cryptobox_hash_create_specific_keyed(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -1427,7 +1427,7 @@ lua_cryptobox_hash_update(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; REF_RETAIN(h); - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); return 1; } @@ -1492,7 +1492,7 @@ lua_cryptobox_hash_reset(lua_State *L) ph = lua_newuserdata(L, sizeof(void *)); *ph = h; REF_RETAIN(h); - rspamd_lua_setclass(L, "rspamd{cryptobox_hash}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_hash_classname, -1); return 1; } @@ -1906,7 +1906,7 @@ lua_cryptobox_sign_memory(lua_State *L) sig->len = siglen; psig = lua_newuserdata(L, sizeof(void *)); *psig = sig; - rspamd_lua_setclass(L, "rspamd{cryptobox_signature}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_signature_classname, -1); return 1; } @@ -1953,7 +1953,7 @@ lua_cryptobox_sign_file(lua_State *L) sig->len = siglen; psig = lua_newuserdata(L, sizeof(void *)); *psig = sig; - rspamd_lua_setclass(L, "rspamd{cryptobox_signature}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_signature_classname, -1); munmap(data, len); } @@ -1981,10 +1981,10 @@ lua_cryptobox_encrypt_memory(lua_State *L) bool owned_pk = false; if (lua_type(L, 1) == LUA_TUSERDATA) { - if (rspamd_lua_check_udata_maybe(L, 1, "rspamd{cryptobox_keypair}")) { + if (rspamd_lua_check_udata_maybe(L, 1, rspamd_cryptobox_keypair_classname)) { kp = lua_check_cryptobox_keypair(L, 1); } - else if (rspamd_lua_check_udata_maybe(L, 1, "rspamd{cryptobox_pubkey}")) { + else if (rspamd_lua_check_udata_maybe(L, 1, rspamd_cryptobox_pubkey_classname)) { pk = lua_check_cryptobox_pubkey(L, 1); } } @@ -2046,7 +2046,7 @@ lua_cryptobox_encrypt_memory(lua_State *L) res->flags = RSPAMD_TEXT_FLAG_OWN; res->start = out; res->len = outlen; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); if (owned_pk) { rspamd_pubkey_unref(pk); @@ -2084,10 +2084,10 @@ lua_cryptobox_encrypt_file(lua_State *L) bool own_pk = false; if (lua_type(L, 1) == LUA_TUSERDATA) { - if (rspamd_lua_check_udata_maybe(L, 1, "rspamd{cryptobox_keypair}")) { + if (rspamd_lua_check_udata_maybe(L, 1, rspamd_cryptobox_keypair_classname)) { kp = lua_check_cryptobox_keypair(L, 1); } - else if (rspamd_lua_check_udata_maybe(L, 1, "rspamd{cryptobox_pubkey}")) { + else if (rspamd_lua_check_udata_maybe(L, 1, rspamd_cryptobox_pubkey_classname)) { pk = lua_check_cryptobox_pubkey(L, 1); } } @@ -2140,7 +2140,7 @@ lua_cryptobox_encrypt_file(lua_State *L) res->flags = RSPAMD_TEXT_FLAG_OWN; res->start = out; res->len = outlen; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); munmap(data, len); if (own_pk) { rspamd_pubkey_unref(pk); @@ -2208,7 +2208,7 @@ lua_cryptobox_decrypt_memory(lua_State *L) res->flags = RSPAMD_TEXT_FLAG_OWN; res->start = out; res->len = outlen; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); } return 2; @@ -2256,7 +2256,7 @@ lua_cryptobox_decrypt_file(lua_State *L) res->flags = RSPAMD_TEXT_FLAG_OWN; res->start = out; res->len = outlen; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); } munmap(data, len); @@ -2619,7 +2619,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) b64_data = rspamd_encode_base64(data, len, -1, &b64_len); priv_out = lua_newuserdata(L, sizeof(*priv_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); priv_out->start = b64_data; priv_out->len = b64_len; priv_out->flags = RSPAMD_TEXT_FLAG_OWN | RSPAMD_TEXT_FLAG_WIPE; @@ -2642,7 +2642,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) b64_data = rspamd_encode_base64(data, len, -1, &b64_len); pub_out = lua_newuserdata(L, sizeof(*pub_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); pub_out->start = b64_data; pub_out->len = b64_len; pub_out->flags = RSPAMD_TEXT_FLAG_OWN; @@ -2666,7 +2666,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) -1, &b64_len); priv_out = lua_newuserdata(L, sizeof(*priv_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); priv_out->start = b64_data; priv_out->len = b64_len; priv_out->flags = RSPAMD_TEXT_FLAG_OWN | RSPAMD_TEXT_FLAG_WIPE; @@ -2677,7 +2677,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) -1, &b64_len); pub_out = lua_newuserdata(L, sizeof(*pub_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); pub_out->start = b64_data; pub_out->len = b64_len; pub_out->flags = RSPAMD_TEXT_FLAG_OWN; @@ -2699,7 +2699,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) -1, &b64_len); priv_out = lua_newuserdata(L, sizeof(*priv_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); priv_out->start = b64_data; priv_out->len = b64_len; priv_out->flags = RSPAMD_TEXT_FLAG_OWN | RSPAMD_TEXT_FLAG_WIPE; @@ -2710,7 +2710,7 @@ lua_cryptobox_gen_dkim_keypair(lua_State *L) -1, &b64_len); pub_out = lua_newuserdata(L, sizeof(*pub_out)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); pub_out->start = b64_data; pub_out->len = b64_len; pub_out->flags = RSPAMD_TEXT_FLAG_OWN; @@ -2774,7 +2774,7 @@ lua_cryptobox_secretbox_create(lua_State *L) crypto_generichash(sbox->sk, sizeof(sbox->sk), in, inlen, NULL, 0); psbox = lua_newuserdata(L, sizeof(*psbox)); *psbox = sbox; - rspamd_lua_setclass(L, "rspamd{cryptobox_secretbox}", -1); + rspamd_lua_setclass(L, rspamd_cryptobox_secretbox_classname, -1); return 1; } @@ -3037,23 +3037,23 @@ lua_load_cryptobox(lua_State *L) void luaopen_cryptobox(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{cryptobox_pubkey}", cryptoboxpubkeylib_m); + rspamd_lua_new_class(L, rspamd_cryptobox_pubkey_classname, cryptoboxpubkeylib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cryptobox_pubkey", lua_load_pubkey); - rspamd_lua_new_class(L, "rspamd{cryptobox_keypair}", cryptoboxkeypairlib_m); + rspamd_lua_new_class(L, rspamd_cryptobox_keypair_classname, cryptoboxkeypairlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cryptobox_keypair", lua_load_keypair); - rspamd_lua_new_class(L, "rspamd{cryptobox_signature}", cryptoboxsignlib_m); + rspamd_lua_new_class(L, rspamd_cryptobox_signature_classname, cryptoboxsignlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cryptobox_signature", lua_load_signature); - rspamd_lua_new_class(L, "rspamd{cryptobox_hash}", cryptoboxhashlib_m); + rspamd_lua_new_class(L, rspamd_cryptobox_hash_classname, cryptoboxhashlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cryptobox_hash", lua_load_hash); - rspamd_lua_new_class(L, "rspamd{cryptobox_secretbox}", + rspamd_lua_new_class(L, rspamd_cryptobox_secretbox_classname, cryptoboxsecretboxlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_cryptobox_secretbox", diff --git a/src/lua/lua_dns_resolver.c b/src/lua/lua_dns_resolver.c index b022e1370..6c2d4f672 100644 --- a/src/lua/lua_dns_resolver.c +++ b/src/lua/lua_dns_resolver.c @@ -73,7 +73,7 @@ static const struct luaL_reg dns_resolverlib_m[] = { struct rspamd_dns_resolver * lua_check_dns_resolver(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{resolver}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_resolver_classname); luaL_argcheck(L, ud != NULL, pos, "'resolver' expected"); return ud ? *((struct rspamd_dns_resolver **) ud) : NULL; } @@ -133,7 +133,7 @@ lua_dns_resolver_callback(struct rdns_reply *reply, gpointer arg) lua_rawgeti(L, LUA_REGISTRYINDEX, cd->cbref); presolver = lua_newuserdata(L, sizeof(gpointer)); - rspamd_lua_setclass(L, "rspamd{resolver}", -1); + rspamd_lua_setclass(L, rspamd_resolver_classname, -1); *presolver = cd->resolver; lua_pushstring(L, cd->to_resolve); @@ -304,10 +304,10 @@ lua_dns_resolver_init(lua_State *L) struct ev_loop *base, **pbase; /* Check args */ - pbase = rspamd_lua_check_udata(L, 1, "rspamd{ev_base}"); + pbase = rspamd_lua_check_udata(L, 1, rspamd_ev_base_classname); luaL_argcheck(L, pbase != NULL, 1, "'ev_base' expected"); base = pbase ? *(pbase) : NULL; - pcfg = rspamd_lua_check_udata(L, 2, "rspamd{config}"); + pcfg = rspamd_lua_check_udata(L, 2, rspamd_config_classname); luaL_argcheck(L, pcfg != NULL, 2, "'config' expected"); cfg = pcfg ? *(pcfg) : NULL; @@ -315,7 +315,7 @@ lua_dns_resolver_init(lua_State *L) resolver = rspamd_dns_resolver_init(NULL, base, cfg); if (resolver) { presolver = lua_newuserdata(L, sizeof(gpointer)); - rspamd_lua_setclass(L, "rspamd{resolver}", -1); + rspamd_lua_setclass(L, rspamd_resolver_classname, -1); *presolver = resolver; } else { @@ -692,7 +692,7 @@ lua_dns_resolver_idna_convert_utf8(lua_State *L) guint conv_len = 0; const gchar *hname = luaL_checklstring(L, 2, &hlen); gchar *converted; - rspamd_mempool_t *pool = rspamd_lua_check_udata_maybe(L, 3, "rspamd{mempool}"); + rspamd_mempool_t *pool = rspamd_lua_check_udata_maybe(L, 3, rspamd_mempool_classname); if (dns_resolver && hname) { @@ -735,7 +735,7 @@ lua_load_dns_resolver(lua_State *L) void luaopen_dns_resolver(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{resolver}", dns_resolverlib_m); + rspamd_lua_new_class(L, rspamd_resolver_classname, dns_resolverlib_m); { LUA_ENUM(L, DNS_A, RDNS_REQUEST_A); LUA_ENUM(L, DNS_PTR, RDNS_REQUEST_PTR); diff --git a/src/lua/lua_expression.c b/src/lua/lua_expression.c index 1ac6f864c..b3c725376 100644 --- a/src/lua/lua_expression.c +++ b/src/lua/lua_expression.c @@ -123,7 +123,7 @@ lua_expr_quark(void) struct lua_expression * rspamd_lua_expression(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{expr}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_expr_classname); luaL_argcheck(L, ud != NULL, pos, "'expr' expected"); return ud ? *((struct lua_expression **) ud) : NULL; } @@ -429,7 +429,7 @@ lua_expr_create(lua_State *L) rspamd_mempool_add_destructor(pool, lua_expr_dtor, e); pe = lua_newuserdata(L, sizeof(struct lua_expression *)); - rspamd_lua_setclass(L, "rspamd{expr}", -1); + rspamd_lua_setclass(L, rspamd_expr_classname, -1); *pe = e; lua_pushnil(L); } @@ -506,7 +506,7 @@ lua_load_expression(lua_State *L) void luaopen_expression(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{expr}", exprlib_m); + rspamd_lua_new_class(L, rspamd_expr_classname, exprlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_expression", lua_load_expression); } diff --git a/src/lua/lua_html.cxx b/src/lua/lua_html.cxx index 661333700..67dbe9738 100644 --- a/src/lua/lua_html.cxx +++ b/src/lua/lua_html.cxx @@ -194,7 +194,7 @@ static const struct luaL_reg taglib_m[] = { static struct rspamd::html::html_content * lua_check_html(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{html}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_html_classname); luaL_argcheck(L, ud != NULL, pos, "'html' expected"); return ud ? *((struct rspamd::html::html_content **) ud) : NULL; } @@ -207,7 +207,7 @@ struct lua_html_tag { static struct lua_html_tag * lua_check_html_tag(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{html_tag}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_html_tag_classname); luaL_argcheck(L, ud != NULL, pos, "'html_tag' expected"); return ud ? ((struct lua_html_tag *) ud) : NULL; } @@ -286,7 +286,7 @@ lua_html_push_image(lua_State *L, const struct html_image *img) t->len = strlen(img->src); t->flags = 0; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); } else { lua_pushstring(L, img->src); @@ -299,7 +299,7 @@ lua_html_push_image(lua_State *L, const struct html_image *img) lua_pushstring(L, "url"); purl = static_cast<rspamd_url **>(lua_newuserdata(L, sizeof(gpointer))); *purl = img->url; - rspamd_lua_setclass(L, "rspamd{url}", -1); + rspamd_lua_setclass(L, rspamd_url_classname, -1); lua_settable(L, -3); } @@ -308,7 +308,7 @@ lua_html_push_image(lua_State *L, const struct html_image *img) ltag = static_cast<lua_html_tag *>(lua_newuserdata(L, sizeof(struct lua_html_tag))); ltag->tag = static_cast<rspamd::html::html_tag *>(img->tag); ltag->html = NULL; - rspamd_lua_setclass(L, "rspamd{html_tag}", -1); + rspamd_lua_setclass(L, rspamd_html_tag_classname, -1); lua_settable(L, -3); } @@ -456,7 +456,7 @@ lua_html_foreach_tag(lua_State *L) ltag->tag = tag; ltag->html = hc; auto ct = ltag->tag->get_content(hc); - rspamd_lua_setclass(L, "rspamd{html_tag}", -1); + rspamd_lua_setclass(L, rspamd_html_tag_classname, -1); lua_pushinteger(L, ct.size()); /* Leaf flag */ @@ -544,7 +544,7 @@ lua_html_tag_get_parent(lua_State *L) ptag = static_cast<lua_html_tag *>(lua_newuserdata(L, sizeof(*ptag))); ptag->tag = static_cast<rspamd::html::html_tag *>(parent); ptag->html = ltag->html; - rspamd_lua_setclass(L, "rspamd{html_tag}", -1); + rspamd_lua_setclass(L, rspamd_html_tag_classname, -1); } else { lua_pushnil(L); @@ -608,7 +608,7 @@ lua_html_tag_get_content(lua_State *L) auto ct = ltag->tag->get_content(ltag->html); if (ct.size() > 0) { t = static_cast<rspamd_lua_text *>(lua_newuserdata(L, sizeof(*t))); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = ct.data(); t->len = ct.size(); t->flags = 0; @@ -667,7 +667,7 @@ lua_html_tag_get_extra(lua_State *L) /* For A that's URL */ auto *lua_url = static_cast<rspamd_lua_url *>(lua_newuserdata(L, sizeof(rspamd_lua_url))); lua_url->url = std::get<struct rspamd_url *>(ltag->tag->extra); - rspamd_lua_setclass(L, "rspamd{url}", -1); + rspamd_lua_setclass(L, rspamd_url_classname, -1); } else { /* Unknown extra ? */ @@ -731,8 +731,8 @@ lua_html_tag_get_attribute(lua_State *L) void luaopen_html(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{html}", htmllib_m); + rspamd_lua_new_class(L, rspamd_html_classname, htmllib_m); lua_pop(L, 1); - rspamd_lua_new_class(L, "rspamd{html_tag}", taglib_m); + rspamd_lua_new_class(L, rspamd_html_tag_classname, taglib_m); lua_pop(L, 1); } diff --git a/src/lua/lua_http.c b/src/lua/lua_http.c index 713082ac5..4c0596885 100644 --- a/src/lua/lua_http.c +++ b/src/lua/lua_http.c @@ -278,7 +278,7 @@ lua_http_finish_handler(struct rspamd_http_connection *conn, struct rspamd_lua_text *t; t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = body; t->len = body_len; t->flags = 0; @@ -363,7 +363,7 @@ lua_http_resume_handler(struct rspamd_http_connection *conn, struct rspamd_lua_text *t; t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = body; t->len = body_len; t->flags = 0; @@ -653,21 +653,21 @@ lua_http_request(lua_State *L) lua_pushvalue(L, 2); cbref = luaL_ref(L, LUA_REGISTRYINDEX); - if (lua_gettop(L) >= 3 && rspamd_lua_check_udata_maybe(L, 3, "rspamd{ev_base}")) { + if (lua_gettop(L) >= 3 && rspamd_lua_check_udata_maybe(L, 3, rspamd_ev_base_classname)) { ev_base = *(struct ev_loop **) lua_touserdata(L, 3); } else { ev_base = NULL; } - if (lua_gettop(L) >= 4 && rspamd_lua_check_udata_maybe(L, 4, "rspamd{resolver}")) { + if (lua_gettop(L) >= 4 && rspamd_lua_check_udata_maybe(L, 4, rspamd_resolver_classname)) { resolver = *(struct rspamd_dns_resolver **) lua_touserdata(L, 4); } else { resolver = lua_http_global_resolver(ev_base); } - if (lua_gettop(L) >= 5 && rspamd_lua_check_udata_maybe(L, 5, "rspamd{session}")) { + if (lua_gettop(L) >= 5 && rspamd_lua_check_udata_maybe(L, 5, rspamd_session_classname)) { session = *(struct rspamd_async_session **) lua_touserdata(L, 5); } else { @@ -722,7 +722,7 @@ lua_http_request(lua_State *L) if (task == NULL) { lua_pushstring(L, "ev_base"); lua_gettable(L, 1); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{ev_base}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_ev_base_classname)) { ev_base = *(struct ev_loop **) lua_touserdata(L, -1); } else { @@ -733,7 +733,7 @@ lua_http_request(lua_State *L) lua_pushstring(L, "session"); lua_gettable(L, 1); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{session}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_session_classname)) { session = *(struct rspamd_async_session **) lua_touserdata(L, -1); } else { @@ -743,7 +743,7 @@ lua_http_request(lua_State *L) lua_pushstring(L, "config"); lua_gettable(L, 1); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{config}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_config_classname)) { cfg = *(struct rspamd_config **) lua_touserdata(L, -1); } else { @@ -755,7 +755,7 @@ lua_http_request(lua_State *L) lua_pushstring(L, "resolver"); lua_gettable(L, 1); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{resolver}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_resolver_classname)) { resolver = *(struct rspamd_dns_resolver **) lua_touserdata(L, -1); } else { diff --git a/src/lua/lua_ip.c b/src/lua/lua_ip.c index ac24dc52b..6c0dcb069 100644 --- a/src/lua/lua_ip.c +++ b/src/lua/lua_ip.c @@ -212,7 +212,7 @@ lua_ip_new(lua_State *L, struct rspamd_lua_ip *old) } pip = lua_newuserdata(L, sizeof(struct rspamd_lua_ip *)); - rspamd_lua_setclass(L, "rspamd{ip}", -1); + rspamd_lua_setclass(L, rspamd_ip_classname, -1); *pip = ip; @@ -222,7 +222,7 @@ lua_ip_new(lua_State *L, struct rspamd_lua_ip *old) struct rspamd_lua_ip * lua_check_ip(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{ip}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_ip_classname); luaL_argcheck(L, ud != NULL, pos, "'ip' expected"); return ud ? *((struct rspamd_lua_ip **) ud) : NULL; @@ -588,7 +588,7 @@ void rspamd_lua_ip_push(lua_State *L, rspamd_inet_addr_t *addr) ip = g_malloc0(sizeof(struct rspamd_lua_ip)); ip->addr = rspamd_inet_address_copy(addr, NULL); pip = lua_newuserdata(L, sizeof(struct rspamd_lua_ip *)); - rspamd_lua_setclass(L, "rspamd{ip}", -1); + rspamd_lua_setclass(L, rspamd_ip_classname, -1); *pip = ip; } else { @@ -610,7 +610,7 @@ void rspamd_lua_ip_push_fromstring(lua_State *L, const gchar *ip_str) ip_str, strlen(ip_str), RSPAMD_INET_ADDRESS_PARSE_DEFAULT)) { pip = lua_newuserdata(L, sizeof(struct rspamd_lua_ip *)); - rspamd_lua_setclass(L, "rspamd{ip}", -1); + rspamd_lua_setclass(L, rspamd_ip_classname, -1); *pip = ip; } else { @@ -631,7 +631,7 @@ lua_load_ip(lua_State *L) void luaopen_ip(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{ip}", iplib_m); + rspamd_lua_new_class(L, rspamd_ip_classname, iplib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_ip", lua_load_ip); } diff --git a/src/lua/lua_kann.c b/src/lua/lua_kann.c index e42fbfbc5..9e033b40e 100644 --- a/src/lua/lua_kann.c +++ b/src/lua/lua_kann.c @@ -23,8 +23,8 @@ * `rspamd_kann` is a Lua interface to kann library */ -#define KANN_NODE_CLASS "rspamd{kann_node}" -#define KANN_NETWORK_CLASS "rspamd{kann}" +#define KANN_NODE_CLASS rspamd_kann_node_classname +#define KANN_NETWORK_CLASS rspamd_kann_classname /* Simple macros to define behaviour */ #define KANN_LAYER_DEF(name) static int lua_kann_layer_##name(lua_State *L) @@ -928,7 +928,7 @@ lua_kann_save(lua_State *L) fclose(f); t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->flags = RSPAMD_TEXT_FLAG_OWN; t->start = (const gchar *) buf; t->len = buflen; diff --git a/src/lua/lua_logger.c b/src/lua/lua_logger.c index f4f8f3dbf..9a0dacf46 100644 --- a/src/lua/lua_logger.c +++ b/src/lua/lua_logger.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -653,7 +653,7 @@ lua_logger_get_id(lua_State *L, gint pos, GError **err) clsname = lua_tostring(L, -1); - if (strcmp(clsname, "rspamd{task}") == 0) { + if (strcmp(clsname, rspamd_task_classname) == 0) { struct rspamd_task *task = lua_check_task(L, pos); if (task) { @@ -664,7 +664,7 @@ lua_logger_get_id(lua_State *L, gint pos, GError **err) EINVAL, "invalid rspamd{task}"); } } - else if (strcmp(clsname, "rspamd{mempool}") == 0) { + else if (strcmp(clsname, rspamd_mempool_classname) == 0) { rspamd_mempool_t *pool; pool = rspamd_lua_check_mempool(L, pos); @@ -677,7 +677,7 @@ lua_logger_get_id(lua_State *L, gint pos, GError **err) EINVAL, "invalid rspamd{mempool}"); } } - else if (strcmp(clsname, "rspamd{config}") == 0) { + else if (strcmp(clsname, rspamd_config_classname) == 0) { struct rspamd_config *cfg; cfg = lua_check_config(L, pos); @@ -692,7 +692,7 @@ lua_logger_get_id(lua_State *L, gint pos, GError **err) EINVAL, "invalid rspamd{config}"); } } - else if (strcmp(clsname, "rspamd{map}") == 0) { + else if (strcmp(clsname, rspamd_map_classname) == 0) { struct rspamd_lua_map *map; map = lua_check_map(L, pos); diff --git a/src/lua/lua_map.c b/src/lua/lua_map.c index 54cfb4b00..cf4275038 100644 --- a/src/lua/lua_map.c +++ b/src/lua/lua_map.c @@ -183,7 +183,7 @@ struct lua_map_callback_data { struct rspamd_lua_map * lua_check_map(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{map}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_map_classname); luaL_argcheck(L, ud != NULL, pos, "'map' expected"); return ud ? *((struct rspamd_lua_map **) ud) : NULL; } @@ -219,7 +219,7 @@ gint lua_config_add_radix_map(lua_State *L) m->lua_map = map; pmap = lua_newuserdata(L, sizeof(void *)); *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -277,7 +277,7 @@ gint lua_config_radix_from_config(lua_State *L) map->map = m; m->lua_map = map; *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { msg_warn_config("Couldnt find config option [%s][%s]", mname, @@ -339,7 +339,7 @@ gint lua_config_radix_from_ucl(lua_State *L) map->map = m; m->lua_map = map; *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -378,7 +378,7 @@ gint lua_config_add_hash_map(lua_State *L) m->lua_map = map; pmap = lua_newuserdata(L, sizeof(void *)); *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -418,7 +418,7 @@ gint lua_config_add_kv_map(lua_State *L) m->lua_map = map; pmap = lua_newuserdata(L, sizeof(void *)); *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -507,7 +507,7 @@ lua_map_fin(struct map_cb_data *data, void **target) struct rspamd_lua_text *t; t = lua_newuserdata(cbdata->L, sizeof(*t)); - rspamd_lua_setclass(cbdata->L, "rspamd{text}", -1); + rspamd_lua_setclass(cbdata->L, rspamd_text_classname, -1); t->flags = 0; t->len = cbdata->data->len; t->start = cbdata->data->str; @@ -515,7 +515,7 @@ lua_map_fin(struct map_cb_data *data, void **target) pmap = lua_newuserdata(cbdata->L, sizeof(void *)); *pmap = cbdata->lua_map; - rspamd_lua_setclass(cbdata->L, "rspamd{map}", -1); + rspamd_lua_setclass(cbdata->L, rspamd_map_classname, -1); gint ret = lua_pcall(cbdata->L, 2, 0, err_idx); @@ -781,7 +781,7 @@ gint lua_config_add_map(lua_State *L) map->map = m; pmap = lua_newuserdata(L, sizeof(void *)); *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -833,7 +833,7 @@ gint lua_config_get_maps(lua_State *L) pmap = lua_newuserdata(L, sizeof(*pmap)); *pmap = map; - rspamd_lua_setclass(L, "rspamd{map}", -1); + rspamd_lua_setclass(L, rspamd_map_classname, -1); lua_rawseti(L, -2, i); cur = g_list_next(cur); @@ -897,7 +897,7 @@ lua_map_get_key(lua_State *L) } } else if (lua_type(L, 2) == LUA_TUSERDATA) { - ud = rspamd_lua_check_udata(L, 2, "rspamd{ip}"); + ud = rspamd_lua_check_udata(L, 2, rspamd_ip_classname); if (ud != NULL) { addr = *((struct rspamd_lua_ip **) ud); @@ -1415,7 +1415,7 @@ lua_map_on_load(lua_State *L) void luaopen_map(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{map}", maplib_m); + rspamd_lua_new_class(L, rspamd_map_classname, maplib_m); lua_pop(L, 1); } diff --git a/src/lua/lua_mempool.c b/src/lua/lua_mempool.c index 4897d1542..bb855710f 100644 --- a/src/lua/lua_mempool.c +++ b/src/lua/lua_mempool.c @@ -149,7 +149,7 @@ struct lua_mempool_udata { struct memory_pool_s * rspamd_lua_check_mempool(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{mempool}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_mempool_classname); luaL_argcheck(L, ud != NULL, pos, "'mempool' expected"); return ud ? *((struct memory_pool_s **) ud) : NULL; } @@ -165,7 +165,7 @@ lua_mempool_create(lua_State *L) if (mempool) { pmempool = lua_newuserdata(L, sizeof(struct memory_pool_s *)); - rspamd_lua_setclass(L, "rspamd{mempool}", -1); + rspamd_lua_setclass(L, rspamd_mempool_classname, -1); *pmempool = mempool; } else { @@ -606,7 +606,7 @@ lua_load_mempool(lua_State *L) void luaopen_mempool(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{mempool}", mempoollib_m); + rspamd_lua_new_class(L, rspamd_mempool_classname, mempoollib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_mempool", lua_load_mempool); } diff --git a/src/lua/lua_mimepart.c b/src/lua/lua_mimepart.c index 5d4b8b74d..6c38a1275 100644 --- a/src/lua/lua_mimepart.c +++ b/src/lua/lua_mimepart.c @@ -609,7 +609,7 @@ static const struct luaL_reg mimepartlib_m[] = { static struct rspamd_mime_text_part * lua_check_textpart(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{textpart}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_textpart_classname); luaL_argcheck(L, ud != NULL, 1, "'textpart' expected"); return ud ? *((struct rspamd_mime_text_part **) ud) : NULL; } @@ -617,7 +617,7 @@ lua_check_textpart(lua_State *L) static struct rspamd_mime_part * lua_check_mimepart(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{mimepart}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_mimepart_classname); luaL_argcheck(L, ud != NULL, 1, "'mimepart' expected"); return ud ? *((struct rspamd_mime_part **) ud) : NULL; } @@ -759,7 +759,7 @@ lua_textpart_get_content(lua_State *L) } t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = start; t->len = len; @@ -781,7 +781,7 @@ lua_textpart_get_raw_content(lua_State *L) } t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = part->raw.begin; t->len = part->raw.len; t->flags = 0; @@ -1095,7 +1095,7 @@ lua_textpart_get_html(lua_State *L) } else { phc = lua_newuserdata(L, sizeof(*phc)); - rspamd_lua_setclass(L, "rspamd{html}", -1); + rspamd_lua_setclass(L, rspamd_html_classname, -1); *phc = part->html; } @@ -1328,7 +1328,7 @@ lua_textpart_get_mimepart(lua_State *L) if (part != NULL) { if (part->mime_part != NULL) { pmime = lua_newuserdata(L, sizeof(struct rspamd_mime_part *)); - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); *pmime = part->mime_part; return 1; @@ -1410,7 +1410,7 @@ lua_mimepart_get_content(lua_State *L) } t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = part->parsed_data.begin; t->len = part->parsed_data.len; t->flags = 0; @@ -1435,7 +1435,7 @@ lua_mimepart_get_raw_content(lua_State *L) } t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = part->raw_data.begin; t->len = part->raw_data.len; t->flags = 0; @@ -1733,7 +1733,7 @@ lua_mimepart_get_raw_headers(lua_State *L) if (part) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = part->raw_headers_str; t->len = part->raw_headers_len; t->flags = 0; @@ -1932,7 +1932,7 @@ lua_mimepart_get_image(lua_State *L) else { pimg = lua_newuserdata(L, sizeof(*pimg)); *pimg = part->specific.img; - rspamd_lua_setclass(L, "rspamd{image}", -1); + rspamd_lua_setclass(L, rspamd_image_classname, -1); } return 1; @@ -1955,7 +1955,7 @@ lua_mimepart_get_archive(lua_State *L) else { parch = lua_newuserdata(L, sizeof(*parch)); *parch = part->specific.arch; - rspamd_lua_setclass(L, "rspamd{archive}", -1); + rspamd_lua_setclass(L, rspamd_archive_classname, -1); } return 1; @@ -1983,7 +1983,7 @@ lua_mimepart_get_children(lua_State *L) { pcur = lua_newuserdata(L, sizeof(*pcur)); *pcur = cur; - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); lua_rawseti(L, -2, i + 1); } } @@ -2005,7 +2005,7 @@ lua_mimepart_get_parent(lua_State *L) if (part->parent_part) { pparent = lua_newuserdata(L, sizeof(*pparent)); *pparent = part->parent_part; - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); } else { lua_pushnil(L); @@ -2032,7 +2032,7 @@ lua_mimepart_get_text(lua_State *L) else { ppart = lua_newuserdata(L, sizeof(*ppart)); *ppart = part->specific.txt; - rspamd_lua_setclass(L, "rspamd{textpart}", -1); + rspamd_lua_setclass(L, rspamd_textpart_classname, -1); } return 1; @@ -2106,7 +2106,7 @@ lua_mimepart_headers_foreach(lua_State *L) lua_gettable(L, 3); if (lua_isuserdata(L, -1)) { - RSPAMD_LUA_CHECK_UDATA_PTR_OR_RETURN(L, -1, "rspamd{regexp}", + RSPAMD_LUA_CHECK_UDATA_PTR_OR_RETURN(L, -1, rspamd_regexp_classname, struct rspamd_lua_regexp, re); } @@ -2273,7 +2273,7 @@ lua_mimepart_set_specific(lua_State *L) part->specific.lua_specific.type = RSPAMD_LUA_PART_STRING; break; case LUA_TUSERDATA: - if (rspamd_lua_check_udata_maybe(L, 2, "rspamd{text}")) { + if (rspamd_lua_check_udata_maybe(L, 2, rspamd_text_classname)) { part->specific.lua_specific.type = RSPAMD_LUA_PART_TEXT; } else { @@ -2293,12 +2293,12 @@ lua_mimepart_set_specific(lua_State *L) void luaopen_textpart(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{textpart}", textpartlib_m); + rspamd_lua_new_class(L, rspamd_textpart_classname, textpartlib_m); lua_pop(L, 1); } void luaopen_mimepart(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{mimepart}", mimepartlib_m); + rspamd_lua_new_class(L, rspamd_mimepart_classname, mimepartlib_m); lua_pop(L, 1); } diff --git a/src/lua/lua_redis.c b/src/lua/lua_redis.c index 1ad3b3d17..761aa5f94 100644 --- a/src/lua/lua_redis.c +++ b/src/lua/lua_redis.c @@ -159,7 +159,7 @@ struct lua_redis_result { static struct lua_redis_ctx * lua_check_redis(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{redis}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_redis_classname); luaL_argcheck(L, ud != NULL, pos, "'redis' expected"); return ud ? *((struct lua_redis_ctx **) ud) : NULL; } @@ -350,7 +350,7 @@ lua_redis_push_reply(lua_State *L, const redisReply *r, gboolean text_data) case REDIS_REPLY_STATUS: if (text_data) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->flags = 0; t->start = r->str; t->len = r->len; @@ -1206,7 +1206,7 @@ lua_redis_make_request(lua_State *L) if (ret) { pctx = lua_newuserdata(L, sizeof(ctx)); *pctx = ctx; - rspamd_lua_setclass(L, "rspamd{redis}", -1); + rspamd_lua_setclass(L, rspamd_redis_classname, -1); } else { lua_pushnil(L); @@ -1402,7 +1402,7 @@ lua_redis_connect(lua_State *L) lua_pushboolean(L, TRUE); pctx = lua_newuserdata(L, sizeof(ctx)); *pctx = ctx; - rspamd_lua_setclass(L, "rspamd{redis}", -1); + rspamd_lua_setclass(L, rspamd_redis_classname, -1); return 2; } @@ -1438,7 +1438,7 @@ lua_redis_connect_sync(lua_State *L) lua_pushboolean(L, TRUE); pctx = lua_newuserdata(L, sizeof(ctx)); *pctx = ctx; - rspamd_lua_setclass(L, "rspamd{redis}", -1); + rspamd_lua_setclass(L, rspamd_redis_classname, -1); } else { lua_pushboolean(L, FALSE); @@ -1649,7 +1649,7 @@ lua_redis_null_mt(lua_State *L) */ void luaopen_redis(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{redis}", redislib_m); + rspamd_lua_new_class(L, rspamd_redis_classname, redislib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_redis", lua_load_redis); diff --git a/src/lua/lua_regexp.c b/src/lua/lua_regexp.c index 7e638cade..3623b7dd2 100644 --- a/src/lua/lua_regexp.c +++ b/src/lua/lua_regexp.c @@ -73,7 +73,7 @@ rspamd_mempool_t *regexp_static_pool = NULL; struct rspamd_lua_regexp * lua_check_regexp(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{regexp}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_regexp_classname); luaL_argcheck(L, ud != NULL, pos, "'regexp' expected"); return ud ? *((struct rspamd_lua_regexp **) ud) : NULL; @@ -119,7 +119,7 @@ lua_regexp_create(lua_State *L) new->re_pattern = g_strdup(string); new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } } @@ -178,7 +178,7 @@ lua_regexp_import_glob(lua_State *L) new->re_pattern = escaped; new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } } @@ -237,7 +237,7 @@ lua_regexp_import_plain(lua_State *L) new->re_pattern = escaped; new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } } @@ -278,7 +278,7 @@ lua_regexp_get_cached(lua_State *L) new->re_pattern = g_strdup(string); new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } else { @@ -331,7 +331,7 @@ lua_regexp_create_cached(lua_State *L) new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } else { @@ -349,7 +349,7 @@ lua_regexp_create_cached(lua_State *L) new->re_pattern = g_strdup(string); new->module = rspamd_lua_get_module_name(L); pnew = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pnew = new; } } @@ -740,7 +740,7 @@ lua_regexp_split(lua_State *L) } else { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = old_start; t->len = start - old_start; t->flags = 0; @@ -765,7 +765,7 @@ lua_regexp_split(lua_State *L) } else { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = end; t->len = (data + len) - end; t->flags = 0; @@ -845,7 +845,7 @@ void luaopen_regexp(lua_State *L) "regexp_lua_pool", 0); } - rspamd_lua_new_class(L, "rspamd{regexp}", regexplib_m); + rspamd_lua_new_class(L, rspamd_regexp_classname, regexplib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_regexp", lua_load_regexp); } diff --git a/src/lua/lua_rsa.c b/src/lua/lua_rsa.c index ae5acc8a8..c2ea39fa5 100644 --- a/src/lua/lua_rsa.c +++ b/src/lua/lua_rsa.c @@ -94,7 +94,7 @@ static const struct luaL_reg rsasignlib_m[] = { static RSA * lua_check_rsa_pubkey(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{rsa_pubkey}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_rsa_pubkey_classname); luaL_argcheck(L, ud != NULL, 1, "'rsa_pubkey' expected"); return ud ? *((RSA **) ud) : NULL; @@ -103,7 +103,7 @@ lua_check_rsa_pubkey(lua_State *L, int pos) static RSA * lua_check_rsa_privkey(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{rsa_privkey}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_rsa_privkey_classname); luaL_argcheck(L, ud != NULL, 1, "'rsa_privkey' expected"); return ud ? *((RSA **) ud) : NULL; @@ -112,7 +112,7 @@ lua_check_rsa_privkey(lua_State *L, int pos) static rspamd_fstring_t * lua_check_rsa_sign(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{rsa_signature}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_rsa_signature_classname); luaL_argcheck(L, ud != NULL, 1, "'rsa_signature' expected"); return ud ? *((rspamd_fstring_t **) ud) : NULL; @@ -142,7 +142,7 @@ lua_rsa_pubkey_load(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_pubkey_classname, -1); *prsa = rsa; } fclose(f); @@ -238,7 +238,7 @@ lua_rsa_pubkey_create(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_pubkey_classname, -1); *prsa = rsa; } BIO_free(bp); @@ -313,7 +313,7 @@ lua_rsa_privkey_load_file(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = rsa; } fclose(f); @@ -358,7 +358,7 @@ lua_rsa_privkey_load_pem(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = rsa; } @@ -405,7 +405,7 @@ lua_rsa_privkey_load_raw(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = rsa; } @@ -464,7 +464,7 @@ lua_rsa_privkey_load_base64(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = rsa; } @@ -504,7 +504,7 @@ lua_rsa_privkey_create(lua_State *L) } else { prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = rsa; } BIO_free(bp); @@ -554,7 +554,7 @@ lua_rsa_signature_load(lua_State *L) else { sig = rspamd_fstring_new_init(data, st.st_size); psig = lua_newuserdata(L, sizeof(rspamd_fstring_t *)); - rspamd_lua_setclass(L, "rspamd{rsa_signature}", -1); + rspamd_lua_setclass(L, rspamd_rsa_signature_classname, -1); *psig = sig; munmap(data, st.st_size); } @@ -629,7 +629,7 @@ lua_rsa_signature_create(lua_State *L) if (data != NULL) { sig = rspamd_fstring_new_init(data, dlen); psig = lua_newuserdata(L, sizeof(rspamd_fstring_t *)); - rspamd_lua_setclass(L, "rspamd{rsa_signature}", -1); + rspamd_lua_setclass(L, rspamd_rsa_signature_classname, -1); *psig = sig; } @@ -768,7 +768,7 @@ lua_rsa_sign_memory(lua_State *L) else { signature->len = siglen; psig = lua_newuserdata(L, sizeof(rspamd_fstring_t *)); - rspamd_lua_setclass(L, "rspamd{rsa_signature}", -1); + rspamd_lua_setclass(L, rspamd_rsa_signature_classname, -1); *psig = signature; } } @@ -797,12 +797,12 @@ lua_rsa_keypair(lua_State *L) priv_rsa = RSAPrivateKey_dup(rsa); prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_privkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_privkey_classname, -1); *prsa = priv_rsa; pub_rsa = RSAPublicKey_dup(rsa); prsa = lua_newuserdata(L, sizeof(RSA *)); - rspamd_lua_setclass(L, "rspamd{rsa_pubkey}", -1); + rspamd_lua_setclass(L, rspamd_rsa_pubkey_classname, -1); *prsa = pub_rsa; RSA_free(rsa); @@ -849,15 +849,15 @@ lua_load_rsa(lua_State *L) void luaopen_rsa(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{rsa_pubkey}", rsapubkeylib_m); + rspamd_lua_new_class(L, rspamd_rsa_pubkey_classname, rsapubkeylib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_rsa_pubkey", lua_load_pubkey); - rspamd_lua_new_class(L, "rspamd{rsa_privkey}", rsaprivkeylib_m); + rspamd_lua_new_class(L, rspamd_rsa_privkey_classname, rsaprivkeylib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_rsa_privkey", lua_load_privkey); - rspamd_lua_new_class(L, "rspamd{rsa_signature}", rsasignlib_m); + rspamd_lua_new_class(L, rspamd_rsa_signature_classname, rsasignlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_rsa_signature", lua_load_signature); diff --git a/src/lua/lua_spf.c b/src/lua/lua_spf.c index a67a267fa..caea3e3b9 100644 --- a/src/lua/lua_spf.c +++ b/src/lua/lua_spf.c @@ -22,7 +22,7 @@ #include "libserver/spf.h" #include "libutil/ref.h" -#define SPF_RECORD_CLASS "rspamd{spf_record}" +#define SPF_RECORD_CLASS rspamd_spf_record_classname LUA_FUNCTION_DEF(spf, resolve); LUA_FUNCTION_DEF(spf, config); diff --git a/src/lua/lua_sqlite3.c b/src/lua/lua_sqlite3.c index be7a9aeea..dde39bd2e 100644 --- a/src/lua/lua_sqlite3.c +++ b/src/lua/lua_sqlite3.c @@ -64,7 +64,7 @@ static void lua_sqlite3_push_row(lua_State *L, sqlite3_stmt *stmt); static sqlite3 * lua_check_sqlite3(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{sqlite3}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_sqlite3_classname); luaL_argcheck(L, ud != NULL, pos, "'sqlite3' expected"); return ud ? *((sqlite3 **) ud) : NULL; } @@ -72,7 +72,7 @@ lua_check_sqlite3(lua_State *L, gint pos) static sqlite3_stmt * lua_check_sqlite3_stmt(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{sqlite3_stmt}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_sqlite3_stmt_classname); luaL_argcheck(L, ud != NULL, pos, "'sqlite3_stmt' expected"); return ud ? *((sqlite3_stmt **) ud) : NULL; } @@ -110,7 +110,7 @@ lua_sqlite3_open(lua_State *L) pdb = lua_newuserdata(L, sizeof(db)); *pdb = db; - rspamd_lua_setclass(L, "rspamd{sqlite3}", -1); + rspamd_lua_setclass(L, rspamd_sqlite3_classname, -1); return 1; } @@ -317,7 +317,7 @@ lua_sqlite3_rows(lua_State *L) /* Create C closure */ pstmt = lua_newuserdata(L, sizeof(stmt)); *pstmt = stmt; - rspamd_lua_setclass(L, "rspamd{sqlite3_stmt}", -1); + rspamd_lua_setclass(L, rspamd_sqlite3_stmt_classname, -1); lua_pushcclosure(L, lua_sqlite3_next_row, 1); } @@ -369,10 +369,10 @@ lua_load_sqlite3(lua_State *L) */ void luaopen_sqlite3(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{sqlite3}", sqlitelib_m); + rspamd_lua_new_class(L, rspamd_sqlite3_classname, sqlitelib_m); lua_pop(L, 1); - rspamd_lua_new_class(L, "rspamd{sqlite3_stmt}", sqlitestmtlib_m); + rspamd_lua_new_class(L, rspamd_sqlite3_stmt_classname, sqlitestmtlib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_sqlite3", lua_load_sqlite3); diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c index dd2ca108b..cada9f952 100644 --- a/src/lua/lua_task.c +++ b/src/lua/lua_task.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -1382,7 +1382,7 @@ static const struct luaL_reg archivelib_m[] = { struct rspamd_task * lua_check_task(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{task}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_task_classname); luaL_argcheck(L, ud != NULL, pos, "'task' expected"); return ud ? *((struct rspamd_task **) ud) : NULL; } @@ -1390,7 +1390,7 @@ lua_check_task(lua_State *L, gint pos) struct rspamd_task * lua_check_task_maybe(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata_maybe(L, pos, "rspamd{task}"); + void *ud = rspamd_lua_check_udata_maybe(L, pos, rspamd_task_classname); return ud ? *((struct rspamd_task **) ud) : NULL; } @@ -1398,7 +1398,7 @@ lua_check_task_maybe(lua_State *L, gint pos) static struct rspamd_image * lua_check_image(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{image}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_image_classname); luaL_argcheck(L, ud != NULL, 1, "'image' expected"); return ud ? *((struct rspamd_image **) ud) : NULL; } @@ -1406,7 +1406,7 @@ lua_check_image(lua_State *L) static struct rspamd_archive * lua_check_archive(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{archive}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_archive_classname); luaL_argcheck(L, ud != NULL, 1, "'archive' expected"); return ud ? *((struct rspamd_archive **) ud) : NULL; } @@ -1505,7 +1505,7 @@ lua_task_get_cfg(lua_State *L) if (task) { pcfg = lua_newuserdata(L, sizeof(gpointer)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = task->cfg; } else { @@ -1520,7 +1520,7 @@ lua_task_set_cfg(lua_State *L) { LUA_TRACE_POINT; struct rspamd_task *task = lua_check_task(L, 1); - void *ud = rspamd_lua_check_udata(L, 2, "rspamd{config}"); + void *ud = rspamd_lua_check_udata(L, 2, rspamd_config_classname); if (task) { luaL_argcheck(L, ud != NULL, 1, "'config' expected"); @@ -1555,7 +1555,7 @@ lua_task_get_message(lua_State *L) if (task) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->flags = 0; t->start = task->msg.begin; t->len = task->msg.len; @@ -1719,7 +1719,7 @@ lua_task_load_from_file(lua_State *L) if (lua_type(L, 2) == LUA_TUSERDATA) { gpointer p; - p = rspamd_lua_check_udata_maybe(L, 2, "rspamd{config}"); + p = rspamd_lua_check_udata_maybe(L, 2, rspamd_config_classname); if (p) { cfg = *(struct rspamd_config **) p; @@ -1781,7 +1781,7 @@ lua_task_load_from_file(lua_State *L) if (res) { ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); } else { if (err) { @@ -1810,7 +1810,7 @@ lua_task_load_from_string(lua_State *L) if (lua_type(L, 2) == LUA_TUSERDATA) { gpointer p; - p = rspamd_lua_check_udata_maybe(L, 2, "rspamd{config}"); + p = rspamd_lua_check_udata_maybe(L, 2, rspamd_config_classname); if (p) { cfg = *(struct rspamd_config **) p; @@ -1832,7 +1832,7 @@ lua_task_load_from_string(lua_State *L) ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); return 2; } @@ -1847,7 +1847,7 @@ lua_task_create(lua_State *L) if (lua_type(L, 1) == LUA_TUSERDATA) { gpointer p; - p = rspamd_lua_check_udata_maybe(L, 1, "rspamd{config}"); + p = rspamd_lua_check_udata_maybe(L, 1, rspamd_config_classname); if (p) { cfg = *(struct rspamd_config **) p; @@ -1856,7 +1856,7 @@ lua_task_create(lua_State *L) if (lua_type(L, 2) == LUA_TUSERDATA) { gpointer p; - p = rspamd_lua_check_udata_maybe(L, 2, "rspamd{ev_base}"); + p = rspamd_lua_check_udata_maybe(L, 2, rspamd_ev_base_classname); if (p) { ev_base = *(struct ev_loop **) p; @@ -1868,7 +1868,7 @@ lua_task_create(lua_State *L) ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); return 1; } @@ -1882,7 +1882,7 @@ lua_task_get_mempool(lua_State *L) if (task != NULL) { ppool = lua_newuserdata(L, sizeof(rspamd_mempool_t *)); - rspamd_lua_setclass(L, "rspamd{mempool}", -1); + rspamd_lua_setclass(L, rspamd_mempool_classname, -1); *ppool = task->task_pool; } else { @@ -1901,7 +1901,7 @@ lua_task_get_session(lua_State *L) if (task != NULL) { psession = lua_newuserdata(L, sizeof(void *)); - rspamd_lua_setclass(L, "rspamd{session}", -1); + rspamd_lua_setclass(L, rspamd_session_classname, -1); *psession = task->s; } else { @@ -1935,7 +1935,7 @@ lua_task_get_ev_base(lua_State *L) if (task != NULL) { pbase = lua_newuserdata(L, sizeof(struct ev_loop *)); - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); *pbase = task->event_loop; } else { @@ -1954,7 +1954,7 @@ lua_task_get_worker(lua_State *L) if (task != NULL) { if (task->worker) { pworker = lua_newuserdata(L, sizeof(struct rspamd_worker *)); - rspamd_lua_setclass(L, "rspamd{worker}", -1); + rspamd_lua_setclass(L, rspamd_worker_classname, -1); *pworker = task->worker; } else { @@ -2636,7 +2636,7 @@ lua_task_inject_url(lua_State *L) if (lua_isuserdata(L, 3)) { /* We also have a mime part there */ mpart = *((struct rspamd_mime_part **) rspamd_lua_check_udata_maybe(L, - 3, "rspamd{mimepart}")); + 3, rspamd_mimepart_classname)); } if (task && task->message && url && url->url) { @@ -2663,7 +2663,7 @@ lua_task_get_content(lua_State *L) if (task) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->len = task->msg.len; t->start = task->msg.begin; t->flags = 0; @@ -2802,7 +2802,7 @@ lua_task_get_text_parts(lua_State *L) { ppart = lua_newuserdata(L, sizeof(struct rspamd_mime_text_part *)); *ppart = part; - rspamd_lua_setclass(L, "rspamd{textpart}", -1); + rspamd_lua_setclass(L, rspamd_textpart_classname, -1); /* Make it array */ lua_rawseti(L, -2, i + 1); } @@ -2837,7 +2837,7 @@ lua_task_get_parts(lua_State *L) { ppart = lua_newuserdata(L, sizeof(struct rspamd_mime_part *)); *ppart = part; - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); /* Make it array */ lua_rawseti(L, -2, i + 1); } @@ -2869,7 +2869,7 @@ lua_task_get_request_header(lua_State *L) if (hdr) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = hdr->begin; t->len = hdr->len; t->flags = 0; @@ -3181,7 +3181,7 @@ lua_task_get_raw_headers(lua_State *L) if (task && task->message) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = MESSAGE_FIELD(task, raw_headers_content).begin; t->len = MESSAGE_FIELD(task, raw_headers_content).len; t->flags = 0; @@ -3272,7 +3272,7 @@ lua_task_get_resolver(lua_State *L) if (task != NULL && task->resolver != NULL) { presolver = lua_newuserdata(L, sizeof(void *)); - rspamd_lua_setclass(L, "rspamd{resolver}", -1); + rspamd_lua_setclass(L, rspamd_resolver_classname, -1); *presolver = task->resolver; } else { @@ -4472,7 +4472,7 @@ lua_task_get_images(lua_State *L) { if (part->part_type == RSPAMD_MIME_PART_IMAGE) { pimg = lua_newuserdata(L, sizeof(struct rspamd_image *)); - rspamd_lua_setclass(L, "rspamd{image}", -1); + rspamd_lua_setclass(L, rspamd_image_classname, -1); *pimg = part->specific.img; lua_rawseti(L, -2, ++nelt); } @@ -4510,7 +4510,7 @@ lua_task_get_archives(lua_State *L) { if (part->part_type == RSPAMD_MIME_PART_ARCHIVE) { parch = lua_newuserdata(L, sizeof(struct rspamd_archive *)); - rspamd_lua_setclass(L, "rspamd{archive}", -1); + rspamd_lua_setclass(L, rspamd_archive_classname, -1); *parch = part->specific.arch; lua_rawseti(L, -2, ++nelt); } @@ -6685,7 +6685,7 @@ lua_task_headers_foreach(lua_State *L) lua_gettable(L, 3); if (lua_isuserdata(L, -1)) { - RSPAMD_LUA_CHECK_UDATA_PTR_OR_RETURN(L, -1, "rspamd{regexp}", + RSPAMD_LUA_CHECK_UDATA_PTR_OR_RETURN(L, -1, rspamd_regexp_classname, struct rspamd_lua_regexp, re); } @@ -7265,13 +7265,13 @@ lua_load_task(lua_State *L) static void luaopen_archive(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{archive}", archivelib_m); + rspamd_lua_new_class(L, rspamd_archive_classname, archivelib_m); lua_pop(L, 1); } void luaopen_task(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{task}", tasklib_m); + rspamd_lua_new_class(L, rspamd_task_classname, tasklib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_task", lua_load_task); @@ -7281,7 +7281,7 @@ void luaopen_task(lua_State *L) void luaopen_image(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{image}", imagelib_m); + rspamd_lua_new_class(L, rspamd_image_classname, imagelib_m); lua_pop(L, 1); } @@ -7290,6 +7290,6 @@ void rspamd_lua_task_push(lua_State *L, struct rspamd_task *task) struct rspamd_task **ptask; ptask = lua_newuserdata(L, sizeof(gpointer)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; } diff --git a/src/lua/lua_tcp.c b/src/lua/lua_tcp.c index 45faa7964..7040e9f43 100644 --- a/src/lua/lua_tcp.c +++ b/src/lua/lua_tcp.c @@ -484,7 +484,7 @@ lua_tcp_fin(gpointer arg) static struct lua_tcp_cbdata * lua_check_tcp(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{tcp}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_tcp_classname); luaL_argcheck(L, ud != NULL, pos, "'tcp' expected"); return ud ? *((struct lua_tcp_cbdata **) ud) : NULL; } @@ -589,7 +589,7 @@ lua_tcp_push_error(struct lua_tcp_cbdata *cbd, gboolean is_fatal, /* Connection */ pcbd = lua_newuserdata(L, sizeof(*pcbd)); *pcbd = cbd; - rspamd_lua_setclass(L, "rspamd{tcp}", -1); + rspamd_lua_setclass(L, rspamd_tcp_classname, -1); TCP_RETAIN(cbd); if (cbd->item) { @@ -676,7 +676,7 @@ lua_tcp_push_data(struct lua_tcp_cbdata *cbd, const guint8 *str, gsize len) if (hdl->type == LUA_WANT_READ) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = (const gchar *) str; t->len = len; t->flags = 0; @@ -688,7 +688,7 @@ lua_tcp_push_data(struct lua_tcp_cbdata *cbd, const guint8 *str, gsize len) /* Connection */ pcbd = lua_newuserdata(L, sizeof(*pcbd)); *pcbd = cbd; - rspamd_lua_setclass(L, "rspamd{tcp}", -1); + rspamd_lua_setclass(L, rspamd_tcp_classname, -1); TCP_RETAIN(cbd); @@ -792,7 +792,7 @@ lua_tcp_connect_helper(struct lua_tcp_cbdata *cbd) lua_thread_pool_set_running_entry(cbd->cfg->lua_thread_pool, cbd->thread); pcbd = lua_newuserdata(L, sizeof(*pcbd)); *pcbd = cbd; - rspamd_lua_setclass(L, "rspamd{tcp_sync}", -1); + rspamd_lua_setclass(L, rspamd_tcp_sync_classname, -1); msg_debug_tcp("tcp connected"); lua_tcp_shift_handler(cbd); @@ -1145,7 +1145,7 @@ lua_tcp_handler(int fd, short what, gpointer ud) pcbd = lua_newuserdata(L, sizeof(*pcbd)); *pcbd = cbd; TCP_RETAIN(cbd); - rspamd_lua_setclass(L, "rspamd{tcp}", -1); + rspamd_lua_setclass(L, rspamd_tcp_classname, -1); if (cbd->item) { rspamd_symcache_set_cur_item(cbd->task, cbd->item); @@ -1588,7 +1588,7 @@ lua_tcp_request(lua_State *L) if (task == NULL) { lua_pushstring(L, "ev_base"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{ev_base}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_ev_base_classname)) { event_loop = *(struct ev_loop **) lua_touserdata(L, -1); } else { @@ -1600,7 +1600,7 @@ lua_tcp_request(lua_State *L) lua_pushstring(L, "session"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{session}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_session_classname)) { session = *(struct rspamd_async_session **) lua_touserdata(L, -1); } else { @@ -1610,7 +1610,7 @@ lua_tcp_request(lua_State *L) lua_pushstring(L, "config"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{config}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_config_classname)) { cfg = *(struct rspamd_config **) lua_touserdata(L, -1); } else { @@ -1620,7 +1620,7 @@ lua_tcp_request(lua_State *L) lua_pushstring(L, "resolver"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{resolver}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_resolver_classname)) { resolver = *(struct rspamd_dns_resolver **) lua_touserdata(L, -1); } else { @@ -2318,7 +2318,7 @@ lua_tcp_shift_callback(lua_State *L) static struct lua_tcp_cbdata * lua_check_sync_tcp(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{tcp_sync}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_tcp_sync_classname); luaL_argcheck(L, ud != NULL, pos, "'tcp' expected"); return ud ? *((struct lua_tcp_cbdata **) ud) : NULL; } @@ -2560,7 +2560,7 @@ lua_load_tcp(lua_State *L) void luaopen_tcp(lua_State *L) { rspamd_lua_add_preload(L, "rspamd_tcp", lua_load_tcp); - rspamd_lua_new_class(L, "rspamd{tcp}", tcp_libm); - rspamd_lua_new_class(L, "rspamd{tcp_sync}", tcp_sync_libm); + rspamd_lua_new_class(L, rspamd_tcp_classname, tcp_libm); + rspamd_lua_new_class(L, rspamd_tcp_sync_classname, tcp_sync_libm); lua_pop(L, 1); } diff --git a/src/lua/lua_tensor.c b/src/lua/lua_tensor.c index 75e61392e..d4ee3dcca 100644 --- a/src/lua/lua_tensor.c +++ b/src/lua/lua_tensor.c @@ -1,11 +1,11 @@ -/*- - * Copyright 2020 Vsevolod Stakhov +/* + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, @@ -96,7 +96,7 @@ lua_newtensor(lua_State *L, int ndims, const int *dim, bool zero_fill, bool own) res->size = -(res->size); } - rspamd_lua_setclass(L, TENSOR_CLASS, -1); + rspamd_lua_setclass(L, rspamd_tensor_classname, -1); return res; } @@ -802,7 +802,7 @@ lua_load_tensor(lua_State *L) void luaopen_tensor(lua_State *L) { /* Metatables */ - rspamd_lua_new_class(L, TENSOR_CLASS, rspamd_tensor_m); + rspamd_lua_new_class(L, rspamd_tensor_classname, rspamd_tensor_m); lua_pop(L, 1); /* No need in metatable... */ rspamd_lua_add_preload(L, "rspamd_tensor", lua_load_tensor); lua_settop(L, 0); @@ -811,7 +811,7 @@ void luaopen_tensor(lua_State *L) struct rspamd_lua_tensor * lua_check_tensor(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, TENSOR_CLASS); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_tensor_classname); luaL_argcheck(L, ud != NULL, pos, "'tensor' expected"); return ud ? ((struct rspamd_lua_tensor *) ud) : NULL; } diff --git a/src/lua/lua_tensor.h b/src/lua/lua_tensor.h index 2103868ae..ffb2517cf 100644 --- a/src/lua/lua_tensor.h +++ b/src/lua/lua_tensor.h @@ -1,11 +1,11 @@ -/*- - * Copyright 2020 Vsevolod Stakhov +/* + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * - * http://www.apache.org/licenses/LICENSE-2.0 + * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, @@ -16,8 +16,6 @@ #ifndef RSPAMD_LUA_TENSOR_H #define RSPAMD_LUA_TENSOR_H -#define TENSOR_CLASS "rspamd{tensor}" - typedef float rspamd_tensor_num_t; struct rspamd_lua_tensor { diff --git a/src/lua/lua_text.c b/src/lua/lua_text.c index 26a5c08e0..d05eee268 100644 --- a/src/lua/lua_text.c +++ b/src/lua/lua_text.c @@ -270,7 +270,7 @@ static const struct luaL_reg textlib_m[] = { struct rspamd_lua_text * lua_check_text(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{text}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_text_classname); luaL_argcheck(L, ud != NULL, pos, "'text' expected"); return ud ? (struct rspamd_lua_text *) ud : NULL; } @@ -281,7 +281,7 @@ lua_check_text_or_string(lua_State *L, gint pos) gint pos_type = lua_type(L, pos); if (pos_type == LUA_TUSERDATA) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{text}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_text_classname); luaL_argcheck(L, ud != NULL, pos, "'text' expected"); return ud ? (struct rspamd_lua_text *) ud : NULL; } @@ -341,7 +341,7 @@ lua_new_text(lua_State *L, const gchar *start, gsize len, gboolean own) } t->len = len; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); return t; } @@ -376,7 +376,7 @@ lua_new_text_task(lua_State *L, struct rspamd_task *task, } t->len = len; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); return t; } @@ -572,7 +572,7 @@ lua_text_fromtable(lua_State *L) t->start = dest; t->len = textlen; t->flags = RSPAMD_TEXT_FLAG_OWN; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); lua_pushvalue(L, 1); lua_text_tbl_append(L, delim, dlen, &dest, 0); @@ -792,7 +792,7 @@ rspamd_lua_text_push_line(lua_State *L, struct rspamd_lua_text *ntext; ntext = lua_newuserdata(L, sizeof(*ntext)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); ntext->start = start; ntext->len = len; ntext->flags = 0; /* Not own as it must be owned by a top object */ @@ -907,7 +907,7 @@ rspamd_lua_text_regexp_split(lua_State *L) } else { new_t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); new_t->start = old_start; new_t->len = start - old_start; new_t->flags = 0; @@ -943,7 +943,7 @@ rspamd_lua_text_regexp_split(lua_State *L) } else { new_t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); new_t->start = end; new_t->len = (t->start + t->len) - end; new_t->flags = 0; @@ -1013,7 +1013,7 @@ lua_text_split(lua_State *L) if (own_re) { struct rspamd_lua_regexp **pre; pre = lua_newuserdata(L, sizeof(struct rspamd_lua_regexp *)); - rspamd_lua_setclass(L, "rspamd{regexp}", -1); + rspamd_lua_setclass(L, rspamd_regexp_classname, -1); *pre = re; } else { @@ -1378,7 +1378,7 @@ lua_text_base64(lua_State *L) out->start = rspamd_encode_base64_common(t->start, t->len, line_len, &sz_len, fold, how); out->len = sz_len; - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); } else { return luaL_error(L, "invalid arguments"); @@ -1480,7 +1480,7 @@ lua_text_exclude_chars(lua_State *L) dest = g_malloc(t->len); nt = lua_newuserdata(L, sizeof(*nt)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); nt->len = t->len; nt->flags = RSPAMD_TEXT_FLAG_OWN; memcpy(dest, t->start, t->len); @@ -1592,7 +1592,7 @@ lua_text_oneline(lua_State *L) dest = g_malloc(t->len); nt = lua_newuserdata(L, sizeof(*nt)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); nt->len = t->len; nt->flags = RSPAMD_TEXT_FLAG_OWN; memcpy(dest, t->start, t->len); @@ -1779,7 +1779,7 @@ lua_load_text(lua_State *L) void luaopen_text(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{text}", textlib_m); + rspamd_lua_new_class(L, rspamd_text_classname, textlib_m); lua_pushstring(L, "cookie"); lua_pushnumber(L, rspamd_lua_text_cookie); lua_settable(L, -3); diff --git a/src/lua/lua_trie.c b/src/lua/lua_trie.c index 3b0b55e97..b92832928 100644 --- a/src/lua/lua_trie.c +++ b/src/lua/lua_trie.c @@ -62,7 +62,7 @@ static const struct luaL_reg trielib_f[] = { static struct rspamd_multipattern * lua_check_trie(lua_State *L, gint idx) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{trie}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_trie_classname); luaL_argcheck(L, ud != NULL, 1, "'trie' expected"); return ud ? *((struct rspamd_multipattern **) ud) : NULL; @@ -150,7 +150,7 @@ lua_trie_create(lua_State *L) } else { ptrie = lua_newuserdata(L, sizeof(void *)); - rspamd_lua_setclass(L, "rspamd{trie}", -1); + rspamd_lua_setclass(L, rspamd_trie_classname, -1); *ptrie = trie; } } @@ -494,7 +494,7 @@ lua_load_trie(lua_State *L) void luaopen_trie(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{trie}", trielib_m); + rspamd_lua_new_class(L, rspamd_trie_classname, trielib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_trie", lua_load_trie); } diff --git a/src/lua/lua_udp.c b/src/lua/lua_udp.c index c79e35a8c..d20475933 100644 --- a/src/lua/lua_udp.c +++ b/src/lua/lua_udp.c @@ -424,7 +424,7 @@ lua_udp_sendto(lua_State *L) if (task == NULL) { lua_pushstring(L, "ev_base"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{ev_base}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_ev_base_classname)) { ev_base = *(struct ev_loop **) lua_touserdata(L, -1); } else { @@ -434,7 +434,7 @@ lua_udp_sendto(lua_State *L) lua_pushstring(L, "session"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{session}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_session_classname)) { session = *(struct rspamd_async_session **) lua_touserdata(L, -1); } else { @@ -444,7 +444,7 @@ lua_udp_sendto(lua_State *L) lua_pushstring(L, "pool"); lua_gettable(L, -2); - if (rspamd_lua_check_udata_maybe(L, -1, "rspamd{mempool}")) { + if (rspamd_lua_check_udata_maybe(L, -1, rspamd_mempool_classname)) { pool = *(rspamd_mempool_t **) lua_touserdata(L, -1); } else { diff --git a/src/lua/lua_upstream.c b/src/lua/lua_upstream.c index 583ee6a6e..69d9f39c4 100644 --- a/src/lua/lua_upstream.c +++ b/src/lua/lua_upstream.c @@ -95,7 +95,7 @@ static const struct luaL_reg upstream_m[] = { struct rspamd_lua_upstream * lua_check_upstream(lua_State *L, int pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{upstream}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_upstream_classname); luaL_argcheck(L, ud != NULL, 1, "'upstream' expected"); return ud ? (struct rspamd_lua_upstream *) ud : NULL; @@ -232,7 +232,7 @@ lua_upstream_destroy(lua_State *L) static struct upstream_list * lua_check_upstream_list(lua_State *L) { - void *ud = rspamd_lua_check_udata(L, 1, "rspamd{upstream_list}"); + void *ud = rspamd_lua_check_udata(L, 1, rspamd_upstream_list_classname); luaL_argcheck(L, ud != NULL, 1, "'upstream_list' expected"); return ud ? *((struct upstream_list **) ud) : NULL; @@ -249,7 +249,7 @@ lua_push_upstream(lua_State *L, gint up_idx, struct upstream *up) lua_ups = lua_newuserdata(L, sizeof(*lua_ups)); lua_ups->up = up; - rspamd_lua_setclass(L, "rspamd{upstream}", -1); + rspamd_lua_setclass(L, rspamd_upstream_classname, -1); /* Store parent in the upstream to prevent gc */ lua_pushvalue(L, up_idx); lua_ups->upref = luaL_ref(L, LUA_REGISTRYINDEX); @@ -295,7 +295,7 @@ lua_upstream_list_create(lua_State *L) if (rspamd_upstreams_parse_line(new, def, default_port, NULL)) { pnew = lua_newuserdata(L, sizeof(struct upstream_list *)); - rspamd_lua_setclass(L, "rspamd{upstream_list}", -1); + rspamd_lua_setclass(L, rspamd_upstream_list_classname, -1); *pnew = new; } else { @@ -306,7 +306,7 @@ lua_upstream_list_create(lua_State *L) else if (lua_type(L, top) == LUA_TTABLE) { new = rspamd_upstreams_create(cfg ? cfg->ups_ctx : NULL); pnew = lua_newuserdata(L, sizeof(struct upstream_list *)); - rspamd_lua_setclass(L, "rspamd{upstream_list}", -1); + rspamd_lua_setclass(L, rspamd_upstream_list_classname, -1); *pnew = new; lua_pushvalue(L, top); @@ -563,7 +563,7 @@ lua_upstream_watch_func(struct upstream *up, struct rspamd_lua_upstream *lua_ups = lua_newuserdata(L, sizeof(*lua_ups)); lua_ups->up = up; - rspamd_lua_setclass(L, "rspamd{upstream}", -1); + rspamd_lua_setclass(L, rspamd_upstream_classname, -1); /* Store parent in the upstream to prevent gc */ lua_rawgeti(L, LUA_REGISTRYINDEX, cdata->parent_cbref); lua_ups->upref = luaL_ref(L, LUA_REGISTRYINDEX); @@ -663,10 +663,10 @@ lua_load_upstream_list(lua_State *L) void luaopen_upstream(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{upstream_list}", upstream_list_m); + rspamd_lua_new_class(L, rspamd_upstream_list_classname, upstream_list_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_upstream_list", lua_load_upstream_list); - rspamd_lua_new_class(L, "rspamd{upstream}", upstream_m); + rspamd_lua_new_class(L, rspamd_upstream_classname, upstream_m); lua_pop(L, 1); } diff --git a/src/lua/lua_url.c b/src/lua/lua_url.c index c09eedea6..f84f64a2c 100644 --- a/src/lua/lua_url.c +++ b/src/lua/lua_url.c @@ -119,7 +119,7 @@ static const struct luaL_reg urllib_f[] = { struct rspamd_lua_url * lua_check_url(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{url}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_url_classname); luaL_argcheck(L, ud != NULL, pos, "'url' expected"); return ud ? ((struct rspamd_lua_url *) ud) : NULL; } @@ -132,7 +132,7 @@ lua_url_single_inserter(struct rspamd_url *url, gsize start_offset, struct rspamd_lua_url *lua_url; lua_url = lua_newuserdata(L, sizeof(struct rspamd_lua_url)); - rspamd_lua_setclass(L, "rspamd{url}", -1); + rspamd_lua_setclass(L, rspamd_url_classname, -1); lua_url->url = url; return TRUE; @@ -572,7 +572,7 @@ lua_url_get_phished(lua_State *L) if (url->url->flags & (RSPAMD_URL_FLAG_PHISHED | RSPAMD_URL_FLAG_REDIRECTED)) { purl = lua_newuserdata(L, sizeof(struct rspamd_lua_url)); - rspamd_lua_setclass(L, "rspamd{url}", -1); + rspamd_lua_setclass(L, rspamd_url_classname, -1); purl->url = url->url->ext->linked_url; return 1; @@ -928,7 +928,7 @@ lua_url_table_inserter(struct rspamd_url *url, gsize start_offset, n = rspamd_lua_table_size(L, -1); lua_url = lua_newuserdata(L, sizeof(struct rspamd_lua_url)); - rspamd_lua_setclass(L, "rspamd{url}", -1); + rspamd_lua_setclass(L, rspamd_url_classname, -1); lua_url->url = url; lua_rawseti(L, -2, n + 1); @@ -1353,7 +1353,7 @@ lua_url_cbdata_fill(lua_State *L, cbd->flags_mask = flags_mask; /* This needs to be removed from the stack */ - rspamd_lua_class_metatable(L, "rspamd{url}"); + rspamd_lua_class_metatable(L, rspamd_url_classname); cbd->metatable_pos = lua_gettop(L); (void) lua_checkstack(L, cbd->metatable_pos + 4); @@ -1470,7 +1470,7 @@ lua_url_cbdata_fill_exclude_include(lua_State *L, cbd->flags_exclude_mask = exclude_flags_mask; /* This needs to be removed from the stack */ - rspamd_lua_class_metatable(L, "rspamd{url}"); + rspamd_lua_class_metatable(L, rspamd_url_classname); cbd->metatable_pos = lua_gettop(L); (void) lua_checkstack(L, cbd->metatable_pos + 4); @@ -1562,7 +1562,7 @@ lua_load_url(lua_State *L) void luaopen_url(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{url}", urllib_m); + rspamd_lua_new_class(L, rspamd_url_classname, urllib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_url", lua_load_url); diff --git a/src/lua/lua_util.c b/src/lua/lua_util.c index 152c02d1e..d1d64b79c 100644 --- a/src/lua/lua_util.c +++ b/src/lua/lua_util.c @@ -763,7 +763,7 @@ static const struct luaL_reg ev_baselib_m[] = { static gint64 lua_check_int64(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{int64}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_int64_classname); luaL_argcheck(L, ud != NULL, pos, "'int64' expected"); return ud ? *((gint64 *) ud) : 0LL; } @@ -776,7 +776,7 @@ lua_util_create_event_base(lua_State *L) struct ev_loop **pev_base; pev_base = lua_newuserdata(L, sizeof(struct ev_loop *)); - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); *pev_base = ev_loop_new(EVFLAG_SIGNALFD | EVBACKEND_ALL); return 1; @@ -802,7 +802,7 @@ lua_util_load_rspamd_config(lua_State *L) else { rspamd_config_post_load(cfg, 0); pcfg = lua_newuserdata(L, sizeof(struct rspamd_config *)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; } } @@ -898,7 +898,7 @@ lua_util_config_from_ucl(lua_State *L) rspamd_config_post_load(cfg, int_options); pcfg = lua_newuserdata(L, sizeof(struct rspamd_config *)); - rspamd_lua_setclass(L, "rspamd{config}", -1); + rspamd_lua_setclass(L, rspamd_config_classname, -1); *pcfg = cfg; } @@ -1085,7 +1085,7 @@ lua_util_encode_qp(lua_State *L) if (out != NULL) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = out; t->len = outlen; /* Need destruction */ @@ -1125,7 +1125,7 @@ lua_util_decode_qp(lua_State *L) } else { out = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); out->start = g_malloc(inlen + 1); out->flags = RSPAMD_TEXT_FLAG_OWN; outlen = rspamd_decode_qp_buf(s, inlen, (gchar *) out->start, inlen + 1); @@ -1167,7 +1167,7 @@ lua_util_decode_base64(lua_State *L) if (s != NULL) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->len = (inlen / 4) * 3 + 3; t->start = g_malloc(t->len); @@ -1222,7 +1222,7 @@ lua_util_encode_base32(lua_State *L) if (out != NULL) { t = lua_newuserdata(L, sizeof(*t)); outlen = strlen(out); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = out; t->len = outlen; /* Need destruction */ @@ -1272,7 +1272,7 @@ lua_util_decode_base32(lua_State *L) if (decoded) { t = lua_newuserdata(L, sizeof(*t)); - rspamd_lua_setclass(L, "rspamd{text}", -1); + rspamd_lua_setclass(L, rspamd_text_classname, -1); t->start = (const gchar *) decoded; t->len = outlen; t->flags = RSPAMD_TEXT_FLAG_OWN; @@ -2077,7 +2077,7 @@ lua_util_caseless_hash(lua_State *L) h = rspamd_icase_hash(t->start, t->len, seed); r = lua_newuserdata(L, sizeof(*r)); *r = h; - rspamd_lua_setclass(L, "rspamd{int64}", -1); + rspamd_lua_setclass(L, rspamd_int64_classname, -1); return 1; } @@ -3468,9 +3468,9 @@ lua_load_int64(lua_State *L) void luaopen_util(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{ev_base}", ev_baselib_m); + rspamd_lua_new_class(L, rspamd_ev_base_classname, ev_baselib_m); lua_pop(L, 1); - rspamd_lua_new_class(L, "rspamd{int64}", int64lib_m); + rspamd_lua_new_class(L, rspamd_int64_classname, int64lib_m); lua_pop(L, 1); rspamd_lua_add_preload(L, "rspamd_util", lua_load_util); rspamd_lua_add_preload(L, "rspamd_int64", lua_load_int64); @@ -3530,7 +3530,7 @@ lua_int64_fromstring(lua_State *L) } gint64 *i64_p = lua_newuserdata(L, sizeof(gint64)); - rspamd_lua_setclass(L, "rspamd{int64}", -1); + rspamd_lua_setclass(L, rspamd_int64_classname, -1); memcpy(i64_p, &u64, sizeof(u64)); if (neg) { diff --git a/src/lua/lua_worker.c b/src/lua/lua_worker.c index 025b97ba1..9bf2a2469 100644 --- a/src/lua/lua_worker.c +++ b/src/lua/lua_worker.c @@ -63,7 +63,7 @@ const luaL_reg worker_reg[] = { static struct rspamd_worker * lua_check_worker(lua_State *L, gint pos) { - void *ud = rspamd_lua_check_udata(L, pos, "rspamd{worker}"); + void *ud = rspamd_lua_check_udata(L, pos, rspamd_worker_classname); luaL_argcheck(L, ud != NULL, pos, "'worker' expected"); return ud ? *((struct rspamd_worker **) ud) : NULL; } @@ -309,7 +309,7 @@ lua_worker_control_handler(struct rspamd_main *rspamd_main, err_idx = lua_gettop(L); lua_rawgeti(L, LUA_REGISTRYINDEX, cbd->cbref); psession = lua_newuserdata(L, sizeof(*psession)); - rspamd_lua_setclass(L, "rspamd{session}", -1); + rspamd_lua_setclass(L, rspamd_session_classname, -1); *psession = session; /* Command name */ @@ -879,5 +879,5 @@ lua_worker_spawn_process(lua_State *L) void luaopen_worker(lua_State *L) { - rspamd_lua_new_class(L, "rspamd{worker}", worker_reg); + rspamd_lua_new_class(L, rspamd_worker_classname, worker_reg); } diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c index 85db83d08..62ddef504 100644 --- a/src/plugins/fuzzy_check.c +++ b/src/plugins/fuzzy_check.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -1566,11 +1566,11 @@ fuzzy_rule_check_mimepart(struct rspamd_task *task, ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); ppart = lua_newuserdata(L, sizeof(*ppart)); *ppart = part; - rspamd_lua_setclass(L, "rspamd{mimepart}", -1); + rspamd_lua_setclass(L, rspamd_mimepart_classname, -1); lua_pushnumber(L, rule->lua_id); @@ -3510,7 +3510,7 @@ fuzzy_process_handler(struct rspamd_http_connection_entry *conn_ent, lua_rawgeti(L, LUA_REGISTRYINDEX, rule->learn_condition_cb); ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_pcall(L, 1, LUA_MULTRET, err_idx) != 0) { msg_err_task("call to fuzzy learn condition failed: %s", diff --git a/src/plugins/regexp.c b/src/plugins/regexp.c index 59a84c507..83d2fc963 100644 --- a/src/plugins/regexp.c +++ b/src/plugins/regexp.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -475,7 +475,7 @@ rspamd_lua_call_expression_func(struct ucl_lua_funcdata *lua_data, lua_rawgeti(L, LUA_REGISTRYINDEX, lua_data->idx); /* Now we got function in top of stack */ ptask = lua_newuserdata(L, sizeof(struct rspamd_task *)); - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); *ptask = task; /* Now push all arguments */ diff --git a/src/rspamadm/lua_repl.c b/src/rspamadm/lua_repl.c index 432c4de76..d3f32c9db 100644 --- a/src/rspamadm/lua_repl.c +++ b/src/rspamadm/lua_repl.c @@ -1,5 +1,5 @@ /* - * Copyright 2023 Vsevolod Stakhov + * Copyright 2024 Vsevolod Stakhov * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -448,7 +448,7 @@ rspamadm_lua_message_handler(lua_State *L, gint argc, gchar **argv) lua_pushvalue(L, func_idx); ptask = lua_newuserdata(L, sizeof(*ptask)); *ptask = task; - rspamd_lua_setclass(L, "rspamd{task}", -1); + rspamd_lua_setclass(L, rspamd_task_classname, -1); if (lua_repl_thread_call(thread, 1, argv[i], lua_thread_str_error_cb) == 0) { diff --git a/src/rspamadm/rspamadm.c b/src/rspamadm/rspamadm.c index 0e38dc326..0b7a65006 100644 --- a/src/rspamadm/rspamadm.c +++ b/src/rspamadm/rspamadm.c @@ -336,17 +336,17 @@ rspamadm_add_lua_globals(struct rspamd_dns_resolver *resolver) NULL, (event_finalizer_t) NULL, NULL); psession = lua_newuserdata(L, sizeof(struct rspamd_async_session *)); - rspamd_lua_setclass(L, "rspamd{session}", -1); + rspamd_lua_setclass(L, rspamd_session_classname, -1); *psession = rspamadm_session; lua_setglobal(L, "rspamadm_session"); pev_base = lua_newuserdata(L, sizeof(struct ev_loop *)); - rspamd_lua_setclass(L, "rspamd{ev_base}", -1); + rspamd_lua_setclass(L, rspamd_ev_base_classname, -1); *pev_base = rspamd_main->event_loop; lua_setglobal(L, "rspamadm_ev_base"); presolver = lua_newuserdata(L, sizeof(struct rspamd_dns_resolver *)); - rspamd_lua_setclass(L, "rspamd{resolver}", -1); + rspamd_lua_setclass(L, rspamd_resolver_classname, -1); *presolver = resolver; lua_setglobal(L, "rspamadm_dns_resolver"); } |