commit 9f754e6: [Project] Temporary fixes to start new bayes logic debug

Vsevolod Stakhov vsevolod at rspamd.com
Mon Jul 29 17:49:40 UTC 2024


Author: Vsevolod Stakhov
Date: 2023-12-04 15:18:50 +0000
URL: https://github.com/rspamd/rspamd/commit/9f754e6c7738f2d0b136c07bf4ac8060888cb3b4

[Project] Temporary fixes to start new bayes logic debug

---
 lualib/lua_bayes_redis.lua           | 21 ++++++++++++++++++---
 src/libstat/backends/redis_backend.c |  4 ++++
 2 files changed, 22 insertions(+), 3 deletions(-)

diff --git a/lualib/lua_bayes_redis.lua b/lualib/lua_bayes_redis.lua
index 27d6c3e6f..5dca2db43 100644
--- a/lualib/lua_bayes_redis.lua
+++ b/lualib/lua_bayes_redis.lua
@@ -19,15 +19,30 @@ limitations under the License.
 local exports = {}
 local lua_redis = require "lua_redis"
 local logger = require "rspamd_logger"
+local lua_util = require "lua_util"
+
+local N = "stat_redis"
 
 local function gen_classify_functor(redis_params, classify_script_id)
-  return function(task, expanded_key, stat_tokens)
-    -- TODO: write this function
+  return function(task, expanded_key, id, is_spam, stat_tokens, callback)
+
+    local function classify_redis_cb(err, data)
+      lua_util.debugm(N, task, 'classify redis cb: %s, %s', err, data)
+      if err then
+        callback(task, false, err)
+      else
+        callback(task, true, data[1], data[2], data[3])
+      end
+    end
+
+    lua_redis.exec_redis_script(classify_script_id,
+        { task = task, is_write = false, key = expanded_key },
+        classify_redis_cb, { expanded_key, stat_tokens })
   end
 end
 
 local function gen_learn_functor(redis_params, learn_script_id)
-  return function(task, expanded_key, stat_tokens)
+  return function(task, expanded_key, id, is_spam, stat_tokens, callback)
     -- TODO: write this function
   end
 end
diff --git a/src/libstat/backends/redis_backend.c b/src/libstat/backends/redis_backend.c
index 9263f479e..57cf059d8 100644
--- a/src/libstat/backends/redis_backend.c
+++ b/src/libstat/backends/redis_backend.c
@@ -1248,12 +1248,14 @@ rspamd_redis_init(struct rspamd_stat_ctx *ctx,
 	st_elt = g_malloc0(sizeof(*st_elt));
 	st_elt->event_loop = ctx->event_loop;
 	st_elt->ctx = backend;
+#if 0
 	backend->stat_elt = rspamd_stat_ctx_register_async(
 		rspamd_redis_async_stat_cb,
 		rspamd_redis_async_stat_fin,
 		st_elt,
 		REDIS_STAT_TIMEOUT);
 	st_elt->async = backend->stat_elt;
+#endif
 
 	return (gpointer) backend;
 }
@@ -1284,6 +1286,7 @@ rspamd_redis_runtime(struct rspamd_task *task,
 	rt->task = task;
 	rt->ctx = ctx;
 	rt->redis_object_expanded = object_expanded;
+	rt->stcf = stcf;
 
 	rspamd_mempool_add_destructor(task->task_pool, rspamd_redis_fin, rt);
 
@@ -1382,6 +1385,7 @@ rspamd_redis_process_tokens(struct rspamd_task *task,
 	gint err_idx = lua_gettop(L);
 
 	/* Function arguments */
+	lua_rawgeti(L, LUA_REGISTRYINDEX, rt->ctx->cbref_classify);
 	rspamd_lua_task_push(L, task);
 	lua_pushstring(L, rt->redis_object_expanded);
 	lua_pushinteger(L, id);


More information about the Commits mailing list