summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2023-05-24 14:25:18 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2023-05-24 14:25:38 +0100
commit1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4 (patch)
tree03cc068625cbca48f216bb17c86fe4710ca0f916 /src
parentc3b5b6fe0a536bd3ec0809ca12ad96502906c126 (diff)
downloadrspamd-1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4.tar.gz
rspamd-1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4.zip
[Fix] Fix parsing due to old bug revealed
Diffstat (limited to 'src')
-rw-r--r--src/fuzzy_storage.c10
-rw-r--r--src/libserver/cfg_rcl.c2
-rw-r--r--src/libserver/cfg_rcl.h2
3 files changed, 7 insertions, 7 deletions
diff --git a/src/fuzzy_storage.c b/src/fuzzy_storage.c
index fe9160880..33f9d40e8 100644
--- a/src/fuzzy_storage.c
+++ b/src/fuzzy_storage.c
@@ -2296,7 +2296,7 @@ fuzzy_parse_ids (rspamd_mempool_t *pool,
struct rspamd_rcl_struct_parser *pd = (struct rspamd_rcl_struct_parser *)ud;
khash_t(fuzzy_key_ids_set) *target;
- target = (khash_t(fuzzy_key_ids_set) *)pd->user_struct;
+ target = *(khash_t(fuzzy_key_ids_set) **)((gchar *)pd->user_struct + pd->offset);
if (ucl_object_type (obj) == UCL_ARRAY) {
const ucl_object_t *cur;
@@ -2543,8 +2543,8 @@ init_fuzzy (struct rspamd_config *cfg)
type,
"forbidden_ids",
fuzzy_parse_ids,
- ctx->default_forbidden_ids,
- 0,
+ ctx,
+ G_STRUCT_OFFSET(struct rspamd_fuzzy_storage_ctx, default_forbidden_ids),
0,
"Deny specific flags by default");
@@ -2552,8 +2552,8 @@ init_fuzzy (struct rspamd_config *cfg)
type,
"weak_ids",
fuzzy_parse_ids,
- ctx->weak_ids,
- 0,
+ ctx,
+ G_STRUCT_OFFSET(struct rspamd_fuzzy_storage_ctx, weak_ids),
0,
"Treat these flags as weak (i.e. they do not overwrite strong flags)");
diff --git a/src/libserver/cfg_rcl.c b/src/libserver/cfg_rcl.c
index 08d534eb3..073a01126 100644
--- a/src/libserver/cfg_rcl.c
+++ b/src/libserver/cfg_rcl.c
@@ -759,7 +759,7 @@ rspamd_rcl_worker_handler (rspamd_mempool_t *pool, const ucl_object_t *obj,
while ((cur = ucl_object_iterate_full (it, UCL_ITERATE_EXPLICIT)) != NULL) {
srch.name = ucl_object_key (cur);
- srch.ptr = wrk->ctx; /* XXX: is it valid? */
+ srch.ptr = wrk->ctx; /* XXX: is it valid? Update! no, it is not valid, omfg... */
whandler = g_hash_table_lookup (wparser->parsers, &srch);
if (whandler != NULL) {
diff --git a/src/libserver/cfg_rcl.h b/src/libserver/cfg_rcl.h
index 1a2d69c58..d7777ccc7 100644
--- a/src/libserver/cfg_rcl.h
+++ b/src/libserver/cfg_rcl.h
@@ -363,7 +363,7 @@ gboolean rspamd_rcl_parse_struct_ucl (rspamd_mempool_t *pool,
* @param type type of worker (GQuark)
* @param name name of option
* @param handler handler of option
- * @param target opaque target structure
+ * @param target opaque target structure, note it **MUST** be worker ctx due to some reasons I don't really remember
* @param offset offset inside a structure
*/
void rspamd_rcl_register_worker_option (struct rspamd_config *cfg,