aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-05-06 17:21:35 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-05-06 17:21:35 +0100
commitaf759431158fe123b5b5facc937869d59fbefd22 (patch)
tree0be36c7ed68e5c9e172af3470416d11a00522fc5 /src
parent4950b1e115df10cd76c8684e084a4cb2550f20e1 (diff)
downloadrspamd-af759431158fe123b5b5facc937869d59fbefd22.tar.gz
rspamd-af759431158fe123b5b5facc937869d59fbefd22.zip
[Feature] Implement compare scripts for mirrors results
Diffstat (limited to 'src')
-rw-r--r--src/rspamd_proxy.c58
1 files changed, 54 insertions, 4 deletions
diff --git a/src/rspamd_proxy.c b/src/rspamd_proxy.c
index 5112e7328..8bbc664dc 100644
--- a/src/rspamd_proxy.c
+++ b/src/rspamd_proxy.c
@@ -561,10 +561,6 @@ proxy_backend_close_connection (struct rspamd_proxy_backend_connection *conn)
close (conn->backend_sock);
- if (conn->results) {
- ucl_object_unref (conn->results);
- }
-
conn->flags |= RSPAMD_BACKEND_CLOSED;
}
@@ -624,9 +620,54 @@ proxy_backend_parse_results (struct rspamd_proxy_session *session,
}
static void
+proxy_call_cmp_script (struct rspamd_proxy_session *session, gint cbref)
+{
+ GString *tb = NULL;
+ gint err_idx;
+ guint i;
+ struct rspamd_proxy_backend_connection *conn;
+ lua_State *L;
+
+ L = session->ctx->lua_state;
+ lua_pushcfunction (L, &rspamd_lua_traceback);
+ err_idx = lua_gettop (L);
+
+ lua_rawgeti (L, LUA_REGISTRYINDEX, cbref);
+
+ lua_createtable (L, 0, session->mirror_conns->len + 1);
+ /* Now push master results */
+ if (session->master_conn->results) {
+ lua_pushstring (L, "master");
+ ucl_object_push_lua (L, session->master_conn->results, true);
+ lua_settable (L, -3);
+ }
+
+ for (i = 0; i < session->mirror_conns->len; i ++) {
+ conn = g_ptr_array_index (session->mirror_conns, i);
+
+ if (conn->results) {
+ lua_pushstring (L, conn->name);
+ ucl_object_push_lua (L, conn->results, true);
+ lua_settable (L, -3);
+ }
+ }
+
+ if (lua_pcall (L, 1, 0, err_idx) != 0) {
+ tb = lua_touserdata (L, -1);
+ msg_err_session (
+ "cannot run lua compare script: %s",
+ tb->str);
+ g_string_free (tb, TRUE);
+ }
+
+ lua_settop (L, 0);
+}
+
+static void
proxy_session_dtor (struct rspamd_proxy_session *session)
{
guint i;
+ gint cbref;
struct rspamd_proxy_backend_connection *conn;
if (session->master_conn) {
@@ -642,12 +683,21 @@ proxy_session_dtor (struct rspamd_proxy_session *session)
rspamd_http_connection_unref (session->client_conn);
}
+ for (i = 0; i < session->ctx->cmp_refs->len; i ++) {
+ cbref = g_array_index (session->ctx->cmp_refs, gint, i);
+ proxy_call_cmp_script (session, cbref);
+ }
+
for (i = 0; i < session->mirror_conns->len; i ++) {
conn = g_ptr_array_index (session->mirror_conns, i);
if (!(conn->flags & RSPAMD_BACKEND_CLOSED)) {
proxy_backend_close_connection (conn);
}
+
+ if (conn->results) {
+ ucl_object_unref (conn->results);
+ }
}
g_ptr_array_free (session->mirror_conns, TRUE);