diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-10-25 23:23:20 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-10-25 23:23:20 +0000 |
commit | 293fbe463c776c1d169d4030db62fff6cf1fbba4 (patch) | |
tree | d597d0fc3b33fddbacf23916809ca9da73e78927 | |
parent | 6ca35268fea102054277895f45425bc8a64992b8 (diff) | |
download | rspamd-293fbe463c776c1d169d4030db62fff6cf1fbba4.tar.gz rspamd-293fbe463c776c1d169d4030db62fff6cf1fbba4.zip |
Fix issues with keyed hash API.
-rw-r--r-- | src/libcryptobox/blake2/blake2.c | 14 | ||||
-rw-r--r-- | src/libcryptobox/blake2/blake2.h | 2 | ||||
-rw-r--r-- | src/libcryptobox/cryptobox.h | 1 |
3 files changed, 6 insertions, 11 deletions
diff --git a/src/libcryptobox/blake2/blake2.c b/src/libcryptobox/blake2/blake2.c index 9c3ce8c2b..594459bf7 100644 --- a/src/libcryptobox/blake2/blake2.c +++ b/src/libcryptobox/blake2/blake2.c @@ -140,15 +140,9 @@ void blake2b_keyed_init (blake2b_state *S, const unsigned char *key, size_t keylen) { unsigned char k[BLAKE2B_BLOCKBYTES] = {0}; - if (keylen > BLAKE2B_KEYBYTES) { - fprintf (stderr, - "key size larger than %u passed to blake2b_keyed_init", - BLAKE2B_KEYBYTES); - exit (-1); - } - else { - memcpy (k, key, keylen); - } + + g_assert (keylen <= BLAKE2B_KEYBYTES); + memcpy (k, key, keylen); blake2b_init (S); blake2b_update (S, k, BLAKE2B_BLOCKBYTES); } @@ -278,4 +272,4 @@ blake2b_load (void) } } } -}
\ No newline at end of file +} diff --git a/src/libcryptobox/blake2/blake2.h b/src/libcryptobox/blake2/blake2.h index 33a5e99c4..37f1dbb4b 100644 --- a/src/libcryptobox/blake2/blake2.h +++ b/src/libcryptobox/blake2/blake2.h @@ -65,7 +65,7 @@ void blake2b_keyed (unsigned char *hash, const unsigned char *key, size_t keylen); -int blake2b_load (void); +void blake2b_load (void); #if defined(__cplusplus) } diff --git a/src/libcryptobox/cryptobox.h b/src/libcryptobox/cryptobox.h index 7d18e2c32..7977bd0e6 100644 --- a/src/libcryptobox/cryptobox.h +++ b/src/libcryptobox/cryptobox.h @@ -37,6 +37,7 @@ struct rspamd_cryptobox_segment { #define rspamd_cryptobox_MAX_NMBYTES 32 #define rspamd_cryptobox_SIPKEYBYTES 16 #define rspamd_cryptobox_HASHBYTES 64 +#define rspamd_cryptobox_HASHKEYBYTES 64 #define rspamd_cryptobox_HASHSTATEBYTES 256 typedef guchar rspamd_pk_t[rspamd_cryptobox_MAX_PKBYTES]; |