summaryrefslogtreecommitdiffstats
path: root/src/libmime
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-05-10 16:38:43 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-05-10 16:38:43 +0100
commit952185f2b093374b878db91eafa5cbfa0777c100 (patch)
tree3f5a2aaa40edcf100b4c7b2641f369fdd0c9ed70 /src/libmime
parentd96c3b80561784386ba83f1421f091a65a8341ab (diff)
downloadrspamd-952185f2b093374b878db91eafa5cbfa0777c100.tar.gz
rspamd-952185f2b093374b878db91eafa5cbfa0777c100.zip
[Feature] New abstract hashing API in cryptobox
Diffstat (limited to 'src/libmime')
-rw-r--r--src/libmime/filter.c5
-rw-r--r--src/libmime/message.c10
2 files changed, 11 insertions, 4 deletions
diff --git a/src/libmime/filter.c b/src/libmime/filter.c
index e1a33f3e2..6aaa19aaf 100644
--- a/src/libmime/filter.c
+++ b/src/libmime/filter.c
@@ -19,7 +19,7 @@
#include "rspamd.h"
#include "message.h"
#include "lua/lua_common.h"
-#include "xxhash.h"
+#include "cryptobox.h"
#include <math.h>
@@ -273,7 +273,8 @@ rspamd_action_from_str (const gchar *data, gint *result)
{
guint64 h;
- h = XXH64 (data, strlen (data), 0xdeadbabe);
+ h = rspamd_cryptobox_fast_hash_specific (RSPAMD_CRYPTOBOX_XXHASH64,
+ data, strlen (data), 0xdeadbabe);
switch (h) {
case 0x9917BFDB46332B8CULL: /* reject */
diff --git a/src/libmime/message.c b/src/libmime/message.c
index 4877fde9f..d1fca6b87 100644
--- a/src/libmime/message.c
+++ b/src/libmime/message.c
@@ -24,7 +24,7 @@
#include "email_addr.h"
#include "utlist.h"
#include "tokenizers/tokenizers.h"
-#include "xxhash.h"
+#include "cryptobox.h"
#ifdef WITH_SNOWBALL
#include "libstemmer.h"
@@ -42,6 +42,7 @@
static const gchar gtube_pattern[] = "XJS*C4JDBQADN1.NSBN3*2IDNEN*"
"GTUBE-STANDARD-ANTI-UBE-TEST-EMAIL*C.34X";
static rspamd_regexp_t *utf_compatible_re = NULL;
+static const guint64 words_hash_seed = 0xdeadbabe;
static GQuark
rspamd_message_quark (void)
@@ -1074,7 +1075,12 @@ rspamd_normalize_text_part (struct rspamd_task *task,
}
if (w->len > 0) {
- h = XXH64 (w->begin, w->len, rspamd_hash_seed ());
+ /*
+ * We use static hash seed if we would want to use that in shingles
+ * computation in future
+ */
+ h = rspamd_cryptobox_fast_hash_specific (RSPAMD_CRYPTOBOX_XXHASH64,
+ w->begin, w->len, words_hash_seed);
g_array_append_val (part->normalized_hashes, h);
}
}