diff options
author | Vsevolod Stakhov <vsevolod@rspamd.com> | 2023-05-24 14:25:18 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rspamd.com> | 2023-05-24 14:25:38 +0100 |
commit | 1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4 (patch) | |
tree | 03cc068625cbca48f216bb17c86fe4710ca0f916 /src | |
parent | c3b5b6fe0a536bd3ec0809ca12ad96502906c126 (diff) | |
download | rspamd-1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4.tar.gz rspamd-1c11ff329d2532f3bd2f0b9af1d6a3a4d6079fc4.zip |
[Fix] Fix parsing due to old bug revealed
Diffstat (limited to 'src')
-rw-r--r-- | src/fuzzy_storage.c | 10 | ||||
-rw-r--r-- | src/libserver/cfg_rcl.c | 2 | ||||
-rw-r--r-- | src/libserver/cfg_rcl.h | 2 |
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, |