aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-09-10 14:55:22 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-09-10 14:55:22 +0100
commitea79cda0ba71ccbaefc4fdd90e3a15714487124a (patch)
treeacce1d516237f65bbe4e3c746eeca325f00d6083
parenta5bd97a363284ce99d43054a5b4ac57b83534327 (diff)
downloadrspamd-ea79cda0ba71ccbaefc4fdd90e3a15714487124a.tar.gz
rspamd-ea79cda0ba71ccbaefc4fdd90e3a15714487124a.zip
[Fix] Fix occasional encryption of the cached data
-rw-r--r--src/plugins/fuzzy_check.c29
1 files changed, 14 insertions, 15 deletions
diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c
index 6211b22f1..5c9ef7fe7 100644
--- a/src/plugins/fuzzy_check.c
+++ b/src/plugins/fuzzy_check.c
@@ -1653,9 +1653,20 @@ fuzzy_cmd_from_text_part (struct rspamd_task *task,
}
}
else {
- cached = rspamd_mempool_alloc0 (task->task_pool, sizeof (*cached));
additional_length = fuzzy_cmd_extension_length (task, rule);
+ cached = rspamd_mempool_alloc0 (task->task_pool, sizeof (*cached) +
+ additional_length);
+ /*
+ * Allocate extensions and never touch it except copying to avoid
+ * occasional encryption
+ */
cached->additional_length = additional_length;
+ cached->additional_data = ((guchar *)cached) + sizeof (*cached);
+
+ if (additional_length > 0) {
+ fuzzy_cmd_write_extensions (task, rule, cached->additional_data,
+ additional_length);
+ }
if (short_text) {
enccmd = rspamd_mempool_alloc0 (task->task_pool,
@@ -1678,13 +1689,7 @@ fuzzy_cmd_from_text_part (struct rspamd_task *task,
cached->sh = NULL;
additional_data = ((guchar *)enccmd) + sizeof (*enccmd);
-
- if (additional_length > 0) {
- fuzzy_cmd_write_extensions (task, rule, additional_data,
- additional_length);
- }
-
- cached->additional_data = additional_data;
+ memcpy (additional_data, cached->additional_data, additional_length);
}
else {
encshcmd = rspamd_mempool_alloc0 (task->task_pool,
@@ -1724,13 +1729,7 @@ fuzzy_cmd_from_text_part (struct rspamd_task *task,
cached->sh = sh;
memcpy (cached->digest, shcmd->basic.digest, sizeof (cached->digest));
additional_data = ((guchar *)encshcmd) + sizeof (*encshcmd);
-
- if (additional_length > 0) {
- fuzzy_cmd_write_extensions (task, rule, additional_data,
- additional_length);
- }
-
- cached->additional_data = additional_data;
+ memcpy (additional_data, cached->additional_data, additional_length);
}
/*