mirror of https://github.com/procxx/kepka.git
Fix crash in RSA public key wrapper.
This commit is contained in:
parent
f74793ca3f
commit
71daae1227
|
@ -180,6 +180,9 @@ public:
|
|||
const BIGNUM *raw() const {
|
||||
return _data;
|
||||
}
|
||||
BIGNUM *takeRaw() {
|
||||
return base::take(_data);
|
||||
}
|
||||
|
||||
bool failed() const {
|
||||
return _failed;
|
||||
|
|
|
@ -35,7 +35,7 @@ namespace {
|
|||
// This is a key setter for compatibility with OpenSSL 1.0
|
||||
int RSA_set0_key(RSA *r, BIGNUM *n, BIGNUM *e, BIGNUM *d) {
|
||||
if ((r->n == nullptr && n == nullptr) || (r->e == nullptr && e == nullptr)) {
|
||||
return false;
|
||||
return 0;
|
||||
}
|
||||
if (n != nullptr) {
|
||||
BN_free(r->n);
|
||||
|
@ -49,7 +49,7 @@ int RSA_set0_key(RSA *r, BIGNUM *n, BIGNUM *e, BIGNUM *d) {
|
|||
BN_free(r->d);
|
||||
r->d = d;
|
||||
}
|
||||
return true;
|
||||
return 1;
|
||||
}
|
||||
|
||||
// This is a key getter for compatibility with OpenSSL 1.0
|
||||
|
@ -79,10 +79,12 @@ public:
|
|||
}
|
||||
Private(base::const_byte_span nBytes, base::const_byte_span eBytes) : _rsa(RSA_new()) {
|
||||
if (_rsa) {
|
||||
BIGNUM *n = openssl::BigNum(nBytes).raw();
|
||||
BIGNUM *e = openssl::BigNum(eBytes).raw();
|
||||
RSA_set0_key(_rsa, n, e, nullptr);
|
||||
if (!n || !e) {
|
||||
auto n = openssl::BigNum(nBytes).takeRaw();
|
||||
auto e = openssl::BigNum(eBytes).takeRaw();
|
||||
auto valid = (n != nullptr) && (e != nullptr);
|
||||
// We still pass both values to RSA_set0_key() so that even
|
||||
// if only one of them is valid RSA would take ownership of it.
|
||||
if (!RSA_set0_key(_rsa, n, e, nullptr) || !valid) {
|
||||
RSA_free(base::take(_rsa));
|
||||
} else {
|
||||
computeFingerprint();
|
||||
|
|
Loading…
Reference in New Issue