aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-01-28 21:39:18 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-01-28 21:39:18 +0000
commit3dbb1735156d3ccbdd51a5c91604b952dc650103 (patch)
tree577da828a7c8bd863e28a31d882a1806e3bc9850
parent62c3edb0742cb95890150ab06b4a1d792a7fed68 (diff)
downloadrspamd-3dbb1735156d3ccbdd51a5c91604b952dc650103.tar.gz
rspamd-3dbb1735156d3ccbdd51a5c91604b952dc650103.zip
Do not pad encrypted messages.
-rw-r--r--contrib/tweetnacl/tweetnacl.c14
-rw-r--r--contrib/tweetnacl/tweetnacl.h4
2 files changed, 10 insertions, 8 deletions
diff --git a/contrib/tweetnacl/tweetnacl.c b/contrib/tweetnacl/tweetnacl.c
index feec43f35..4e07b5fcf 100644
--- a/contrib/tweetnacl/tweetnacl.c
+++ b/contrib/tweetnacl/tweetnacl.c
@@ -246,10 +246,11 @@ int crypto_onetimeauth_verify(const u8 *h,const u8 *m,u64 n,const u8 *k)
int crypto_secretbox(u8 *c,const u8 *m,u64 d,const u8 *n,const u8 *k)
{
unsigned int i;
- if (d < 32) return -1;
+ if (d < crypto_box_ZEROBYTES) return -1;
crypto_stream_xor(c,m,d,n,k);
- crypto_onetimeauth(c + 16,c + 32,d - 32,c);
- FOR(i,16) c[i] = 0;
+ crypto_onetimeauth(c + crypto_box_BOXZEROBYTES,c + crypto_box_ZEROBYTES,
+ d - crypto_box_ZEROBYTES,c);
+ FOR(i,crypto_box_BOXZEROBYTES) c[i] = 0;
return 0;
}
@@ -257,11 +258,12 @@ int crypto_secretbox_open(u8 *m,const u8 *c,u64 d,const u8 *n,const u8 *k)
{
unsigned int i;
u8 x[32];
- if (d < 32) return -1;
+ if (d < crypto_box_ZEROBYTES) return -1;
crypto_stream(x,32,n,k);
- if (crypto_onetimeauth_verify(c + 16,c + 32,d - 32,x) != 0) return -1;
+ if (crypto_onetimeauth_verify(c + crypto_box_BOXZEROBYTES,
+ c + crypto_box_ZEROBYTES,d - crypto_box_ZEROBYTES,x) != 0) return -1;
crypto_stream_xor(m,c,d,n,k);
- FOR(i,32) m[i] = 0;
+ FOR(i,crypto_box_ZEROBYTES) m[i] = 0;
return 0;
}
diff --git a/contrib/tweetnacl/tweetnacl.h b/contrib/tweetnacl/tweetnacl.h
index c9d75fe8a..b661b69c2 100644
--- a/contrib/tweetnacl/tweetnacl.h
+++ b/contrib/tweetnacl/tweetnacl.h
@@ -39,8 +39,8 @@ extern int crypto_auth_hmacsha512256_tweet_verify(const guchar *,const guchar *,
#define crypto_box_curve25519xsalsa20poly1305_tweet_SECRETKEYBYTES 32
#define crypto_box_curve25519xsalsa20poly1305_tweet_BEFORENMBYTES 32
#define crypto_box_curve25519xsalsa20poly1305_tweet_NONCEBYTES 24
-#define crypto_box_curve25519xsalsa20poly1305_tweet_ZEROBYTES 32
-#define crypto_box_curve25519xsalsa20poly1305_tweet_BOXZEROBYTES 16
+#define crypto_box_curve25519xsalsa20poly1305_tweet_ZEROBYTES 16
+#define crypto_box_curve25519xsalsa20poly1305_tweet_BOXZEROBYTES 0
extern int crypto_box_curve25519xsalsa20poly1305_tweet(guchar *,const guchar *,guint64,const guchar *,const guchar *,const guchar *);
extern int crypto_box_curve25519xsalsa20poly1305_tweet_open(guchar *,const guchar *,guint64,const guchar *,const guchar *,const guchar *);
extern int crypto_box_curve25519xsalsa20poly1305_tweet_keypair(guchar *,guchar *);