summaryrefslogtreecommitdiff
path: root/lib/internal/crypto
diff options
context:
space:
mode:
authorFilip Skokan <panva.ip@gmail.com>2019-03-19 12:09:01 +0100
committerTobias Nießen <tniessen@tnie.de>2019-03-25 01:40:54 +0100
commit85fda7e8481003ec0d6b5217c90440ad79dc2204 (patch)
treee604e67cc7ad619f2e6d3f92d996e26288daadc3 /lib/internal/crypto
parent4a07a62d04b219ca72271f7cda0880a2a4300d05 (diff)
downloadandroid-node-v8-85fda7e8481003ec0d6b5217c90440ad79dc2204.tar.gz
android-node-v8-85fda7e8481003ec0d6b5217c90440ad79dc2204.tar.bz2
android-node-v8-85fda7e8481003ec0d6b5217c90440ad79dc2204.zip
crypto: add support for x25119 and x448 KeyObjects
PR-URL: https://github.com/nodejs/node/pull/26774 Refs: https://github.com/nodejs/node/issues/26626 Reviewed-By: Tobias Nießen <tniessen@tnie.de> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Sam Roberts <vieuxtech@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com>
Diffstat (limited to 'lib/internal/crypto')
-rw-r--r--lib/internal/crypto/keygen.js22
1 files changed, 20 insertions, 2 deletions
diff --git a/lib/internal/crypto/keygen.js b/lib/internal/crypto/keygen.js
index efa6c6c31b..80efa01b1b 100644
--- a/lib/internal/crypto/keygen.js
+++ b/lib/internal/crypto/keygen.js
@@ -8,6 +8,8 @@ const {
generateKeyPairEdDSA,
EVP_PKEY_ED25519,
EVP_PKEY_ED448,
+ EVP_PKEY_X25519,
+ EVP_PKEY_X448,
OPENSSL_EC_NAMED_CURVE,
OPENSSL_EC_EXPLICIT_CURVE
} = internalBinding('crypto');
@@ -197,8 +199,24 @@ function check(type, options, callback) {
break;
case 'ed25519':
case 'ed448':
+ case 'x25519':
+ case 'x448':
{
- const id = type === 'ed25519' ? EVP_PKEY_ED25519 : EVP_PKEY_ED448;
+ let id;
+ switch (type) {
+ case 'ed25519':
+ id = EVP_PKEY_ED25519;
+ break;
+ case 'ed448':
+ id = EVP_PKEY_ED448;
+ break;
+ case 'x25519':
+ id = EVP_PKEY_X25519;
+ break;
+ case 'x448':
+ id = EVP_PKEY_X448;
+ break;
+ }
impl = (wrap) => generateKeyPairEdDSA(id,
publicFormat, publicType,
privateFormat, privateType,
@@ -208,7 +226,7 @@ function check(type, options, callback) {
default:
throw new ERR_INVALID_ARG_VALUE('type', type,
"must be one of 'rsa', 'dsa', 'ec', " +
- "'ed25519', 'ed448'");
+ "'ed25519', 'ed448', 'x25519', 'x448'");
}
if (options) {