mirror of https://github.com/PurpleI2P/i2pd.git
I2P: End-to-End encrypted and anonymous Internet
https://i2pd.website/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
34 lines
684 B
34 lines
684 B
#include <string.h> |
|
#include "crypto_sign.h" |
|
#include "crypto_hash_sha512.h" |
|
#include "ge.h" |
|
#include "sc.h" |
|
|
|
int crypto_sign( |
|
unsigned char *sig, |
|
const unsigned char* m, unsigned long long mlen, |
|
const unsigned char* sk, const unsigned char* pk |
|
) |
|
{ |
|
unsigned char az[64]; |
|
unsigned char nonce[64]; |
|
unsigned char hram[64]; |
|
ge_p3 R; |
|
|
|
crypto_hash_sha512(az,sk,32); |
|
az[0] &= 248; |
|
az[31] &= 63; |
|
az[31] |= 64; |
|
|
|
crypto_hash_sha512_2(nonce, az + 32, 32, m, mlen); |
|
|
|
sc_reduce(nonce); |
|
ge_scalarmult_base(&R,nonce); |
|
ge_p3_tobytes(sig,&R); |
|
|
|
crypto_hash_sha512_3(hram, sig, 32, pk, 32, m, mlen); |
|
sc_reduce(hram); |
|
sc_muladd(sig + 32,hram,az,nonce); |
|
|
|
return 0; |
|
}
|
|
|