mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 21:37:17 +01:00
openssl 1.1 for ECDSA
This commit is contained in:
parent
46f927fc1b
commit
a4d586b24e
6
Crypto.h
6
Crypto.h
|
@ -7,6 +7,7 @@
|
||||||
#include <openssl/dh.h>
|
#include <openssl/dh.h>
|
||||||
#include <openssl/aes.h>
|
#include <openssl/aes.h>
|
||||||
#include <openssl/dsa.h>
|
#include <openssl/dsa.h>
|
||||||
|
#include <openssl/ecdsa.h>
|
||||||
#include <openssl/rsa.h>
|
#include <openssl/rsa.h>
|
||||||
#include <openssl/sha.h>
|
#include <openssl/sha.h>
|
||||||
#include <openssl/rand.h>
|
#include <openssl/rand.h>
|
||||||
|
@ -296,6 +297,11 @@ inline int DSA_SIG_set0(DSA_SIG *sig, BIGNUM *r, BIGNUM *s)
|
||||||
inline void DSA_SIG_get0(const DSA_SIG *sig, const BIGNUM **pr, const BIGNUM **ps)
|
inline void DSA_SIG_get0(const DSA_SIG *sig, const BIGNUM **pr, const BIGNUM **ps)
|
||||||
{ *pr = sig->r; *ps = sig->s; }
|
{ *pr = sig->r; *ps = sig->s; }
|
||||||
|
|
||||||
|
inline int ECDSA_SIG_set0(ECDSA_SIG *sig, BIGNUM *r, BIGNUM *s)
|
||||||
|
{ sig->r = r; sig->s = s; return 1; }
|
||||||
|
inline void ECDSA_SIG_get0(const ECDSA_SIG *sig, const BIGNUM **pr, const BIGNUM **ps)
|
||||||
|
{ *pr = sig->r; *ps = sig->s; }
|
||||||
|
|
||||||
inline int RSA_set0_key(RSA *r, BIGNUM *n, BIGNUM *e, BIGNUM *d)
|
inline int RSA_set0_key(RSA *r, BIGNUM *n, BIGNUM *e, BIGNUM *d)
|
||||||
{ r->n = n; r->e = e; r->d = d; return 1; }
|
{ r->n = n; r->e = e; r->d = d; return 1; }
|
||||||
inline void RSA_get0_key(const RSA *r, const BIGNUM **n, const BIGNUM **e, const BIGNUM **d)
|
inline void RSA_get0_key(const RSA *r, const BIGNUM **n, const BIGNUM **e, const BIGNUM **d)
|
||||||
|
|
13
Signature.h
13
Signature.h
|
@ -169,8 +169,9 @@ namespace crypto
|
||||||
uint8_t digest[Hash::hashLen];
|
uint8_t digest[Hash::hashLen];
|
||||||
Hash::CalculateHash (buf, len, digest);
|
Hash::CalculateHash (buf, len, digest);
|
||||||
ECDSA_SIG * sig = ECDSA_SIG_new();
|
ECDSA_SIG * sig = ECDSA_SIG_new();
|
||||||
sig->r = BN_bin2bn (signature, GetSignatureLen ()/2, NULL);
|
auto r = BN_bin2bn (signature, GetSignatureLen ()/2, NULL);
|
||||||
sig->s = BN_bin2bn (signature + GetSignatureLen ()/2, GetSignatureLen ()/2, NULL);
|
auto s = BN_bin2bn (signature + GetSignatureLen ()/2, GetSignatureLen ()/2, NULL);
|
||||||
|
ECDSA_SIG_set0(sig, r, s);
|
||||||
// ECDSA verification
|
// ECDSA verification
|
||||||
int ret = ECDSA_do_verify (digest, Hash::hashLen, sig, m_PublicKey);
|
int ret = ECDSA_do_verify (digest, Hash::hashLen, sig, m_PublicKey);
|
||||||
ECDSA_SIG_free(sig);
|
ECDSA_SIG_free(sig);
|
||||||
|
@ -207,9 +208,11 @@ namespace crypto
|
||||||
uint8_t digest[Hash::hashLen];
|
uint8_t digest[Hash::hashLen];
|
||||||
Hash::CalculateHash (buf, len, digest);
|
Hash::CalculateHash (buf, len, digest);
|
||||||
ECDSA_SIG * sig = ECDSA_do_sign (digest, Hash::hashLen, m_PrivateKey);
|
ECDSA_SIG * sig = ECDSA_do_sign (digest, Hash::hashLen, m_PrivateKey);
|
||||||
|
const BIGNUM * r, * s;
|
||||||
|
ECDSA_SIG_get0 (sig, &r, &s);
|
||||||
// signatureLen = keyLen
|
// signatureLen = keyLen
|
||||||
bn2buf (sig->r, signature, keyLen/2);
|
bn2buf (r, signature, keyLen/2);
|
||||||
bn2buf (sig->s, signature + keyLen/2, keyLen/2);
|
bn2buf (s, signature + keyLen/2, keyLen/2);
|
||||||
ECDSA_SIG_free(sig);
|
ECDSA_SIG_free(sig);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -271,7 +274,6 @@ namespace crypto
|
||||||
RSAVerifier (const uint8_t * signingKey)
|
RSAVerifier (const uint8_t * signingKey)
|
||||||
{
|
{
|
||||||
m_PublicKey = RSA_new ();
|
m_PublicKey = RSA_new ();
|
||||||
memset (m_PublicKey, 0, sizeof (RSA));
|
|
||||||
RSA_set0_key (m_PublicKey, BN_bin2bn (signingKey, keyLen, NULL) /* n */ , BN_dup (GetRSAE ()) /* d */, NULL);
|
RSA_set0_key (m_PublicKey, BN_bin2bn (signingKey, keyLen, NULL) /* n */ , BN_dup (GetRSAE ()) /* d */, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -304,7 +306,6 @@ namespace crypto
|
||||||
RSASigner (const uint8_t * signingPrivateKey)
|
RSASigner (const uint8_t * signingPrivateKey)
|
||||||
{
|
{
|
||||||
m_PrivateKey = RSA_new ();
|
m_PrivateKey = RSA_new ();
|
||||||
memset (m_PrivateKey, 0, sizeof (RSA));
|
|
||||||
RSA_set0_key (m_PrivateKey, BN_bin2bn (signingPrivateKey, keyLen, NULL), /* n */
|
RSA_set0_key (m_PrivateKey, BN_bin2bn (signingPrivateKey, keyLen, NULL), /* n */
|
||||||
BN_dup (GetRSAE ()) /* e */, BN_bin2bn (signingPrivateKey + keyLen, keyLen, NULL) /* d */);
|
BN_dup (GetRSAE ()) /* e */, BN_bin2bn (signingPrivateKey + keyLen, keyLen, NULL) /* d */);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue