aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-07-07 21:04:49 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-07-07 21:05:17 +0100
commita34a5be0f79fbd9620c57590b8a9f4882b5e66e2 (patch)
tree2a9ba32453e978f2e59e3cd4fc79247eb3e65543 /src
parent2511a18378e2ffdf4b59c5537e585291a98db182 (diff)
downloadrspamd-a34a5be0f79fbd9620c57590b8a9f4882b5e66e2.tar.gz
rspamd-a34a5be0f79fbd9620c57590b8a9f4882b5e66e2.zip
[Project] Attach extensions to the binary fuzzy commands
Diffstat (limited to 'src')
-rw-r--r--src/plugins/fuzzy_check.c22
1 files changed, 17 insertions, 5 deletions
diff --git a/src/plugins/fuzzy_check.c b/src/plugins/fuzzy_check.c
index 8798c0aca..6d869bd1f 100644
--- a/src/plugins/fuzzy_check.c
+++ b/src/plugins/fuzzy_check.c
@@ -1661,7 +1661,6 @@ fuzzy_cmd_from_text_part (struct rspamd_task *task,
rspamd_cryptobox_hash_final (&st, shcmd->basic.digest);
-
msg_debug_task ("loading shingles of type %s with key %*xs",
rule->algorithm_str,
16, rule->shingles_key->str);
@@ -1859,13 +1858,20 @@ fuzzy_cmd_from_data_part (struct fuzzy_rule *rule,
struct rspamd_fuzzy_cmd *cmd;
struct rspamd_fuzzy_encrypted_cmd *enccmd = NULL;
struct fuzzy_cmd_io *io;
+ guint additional_length;
+ guchar *additional_data;
+
+ additional_length = fuzzy_cmd_extension_length (task, rule);
if (rule->peer_key) {
- enccmd = rspamd_mempool_alloc0 (task->task_pool, sizeof (*enccmd));
+ enccmd = rspamd_mempool_alloc0 (task->task_pool,
+ sizeof (*enccmd) + additional_length);
cmd = &enccmd->cmd;
+ additional_data = ((guchar *)enccmd) + sizeof (*enccmd);
}
else {
cmd = rspamd_mempool_alloc0 (task->task_pool, sizeof (*cmd));
+ additional_data = ((guchar *)cmd) + sizeof (*cmd);
}
cmd->cmd = c;
@@ -1884,15 +1890,21 @@ fuzzy_cmd_from_data_part (struct fuzzy_rule *rule,
io->part = mp;
memcpy (&io->cmd, cmd, sizeof (io->cmd));
+ if (additional_length > 0) {
+ fuzzy_cmd_write_extensions (task, rule, additional_data,
+ additional_length);
+ }
+
if (rule->peer_key) {
g_assert (enccmd != NULL);
- fuzzy_encrypt_cmd (rule, &enccmd->hdr, (guchar *) cmd, sizeof (*cmd));
+ fuzzy_encrypt_cmd (rule, &enccmd->hdr, (guchar *)cmd,
+ sizeof (*cmd) + additional_length);
io->io.iov_base = enccmd;
- io->io.iov_len = sizeof (*enccmd);
+ io->io.iov_len = sizeof (*enccmd) + additional_length;
}
else {
io->io.iov_base = cmd;
- io->io.iov_len = sizeof (*cmd);
+ io->io.iov_len = sizeof (*cmd) + additional_length;
}
return io;