aboutsummaryrefslogtreecommitdiffstats
path: root/contrib
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-01-30 17:47:01 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-01-30 17:47:01 +0000
commitd6c756289e5284c9da5c29edda3f8cd7382e4fc6 (patch)
tree7444cf53cf1bd0841ff1f05bd4bdfa346b2c9948 /contrib
parent39c853952b97d56726839e6e5681cd7e1849c364 (diff)
downloadrspamd-d6c756289e5284c9da5c29edda3f8cd7382e4fc6.tar.gz
rspamd-d6c756289e5284c9da5c29edda3f8cd7382e4fc6.zip
Fix cryptobox code.
Diffstat (limited to 'contrib')
-rw-r--r--contrib/tweetnacl/tweetnacl.c20
1 files changed, 8 insertions, 12 deletions
diff --git a/contrib/tweetnacl/tweetnacl.c b/contrib/tweetnacl/tweetnacl.c
index 1f66a1e47..2924ad800 100644
--- a/contrib/tweetnacl/tweetnacl.c
+++ b/contrib/tweetnacl/tweetnacl.c
@@ -161,11 +161,10 @@ int crypto_stream_salsa20_xor2(u8 *c1, u8 *c2,const u8 *m1,const u8 *m2,u64 d1,u
FOR(i,16) z[i] = 0;
FOR(i,8) z[i] = n[i];
- rspamd_printf("encrypt %*xs\n", 64, k);
for(j = 0; j < 2; j ++, m = m2, b = d2, c = c2) {
if (r > 0) {
if (r <= b) {
- FOR(i,r) c[i] = (m?m[i]:0) ^ x[i];
+ FOR(i,r) c[i] = (m?m[i]:0) ^ x[(64 - r) + i];
m += r;
c += r;
b -= r;
@@ -181,7 +180,6 @@ int crypto_stream_salsa20_xor2(u8 *c1, u8 *c2,const u8 *m1,const u8 *m2,u64 d1,u
FOR(i,b) c[i] = (m?m[i]:0) ^ x[i];
return 0;
}
- r = 0;
}
while (b >= 64) {
crypto_core_salsa20(x,z,k,sigma);
@@ -295,7 +293,6 @@ int crypto_onetimeauth(u8 *out,const u8 *m,u64 n,const u8 *k)
c[16] = 0;
add1305(h,c);
FOR(j,16) out[j] = h[j];
- rspamd_printf("poly1305 key=%*xs, tag=%*xs\n", 32, k, 16, out);
return 0;
}
@@ -320,13 +317,13 @@ int crypto_secretbox(u8 *c,const u8 *m,u64 d,const u8 *n,const u8 *k)
int crypto_secretbox_detached(u8 *c,const u8 *m,u64 d,const u8 *n,const u8 *k, u8 *a)
{
unsigned int i;
- volatile u8 mk[crypto_onetimeauth_poly1305_KEYBYTES];
+ volatile u8 mk[32];
if (d == 0) return -1;
- FOR(i, crypto_onetimeauth_poly1305_KEYBYTES) mk[i] = 0;
+ FOR(i, 32) mk[i] = 0;
crypto_stream_xor2((u8 *)mk,c,(u8 *)mk,m,crypto_onetimeauth_poly1305_KEYBYTES,d,n,k);
crypto_onetimeauth(a,c,d,(const u8*)mk);
/* TODO: add really secure bzero here */
- FOR(i,crypto_onetimeauth_poly1305_KEYBYTES) mk[i] = 0;
+ FOR(i,32) mk[i] = 0;
return 0;
}
@@ -334,12 +331,11 @@ 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 < crypto_box_ZEROBYTES) return -1;
+ if (d < 16) return -1;
crypto_stream(x,32,n,k);
- 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,crypto_box_ZEROBYTES) m[i] = 0;
+ if (crypto_onetimeauth_verify(c,c + 16,d - 16,x) != 0) return -1;
+ crypto_stream_xor2(x,m + 16,x,c + 16,32,d-16,n,k);
+ FOR(i,16) m[i] = 0;
return 0;
}