From e6e1f4e8bd0e5d7f8284e9653a6e5c4f6df4f3f9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Nie=C3=9Fen?= Date: Tue, 27 Aug 2024 10:17:21 +0200 Subject: [PATCH] src: remove redundant AESCipherMode For each supported variant of AES, we already have OpenSSL's associated NID, so we can simply retrieve the block cipher mode of operation from the NID. PR-URL: https://github.com/nodejs/node/pull/54438 Reviewed-By: James M Snell Reviewed-By: Benjamin Gruenbaum --- src/crypto/crypto_aes.cc | 28 +++++++++++++--------------- src/crypto/crypto_aes.h | 33 +++++++++++++-------------------- 2 files changed, 26 insertions(+), 35 deletions(-) diff --git a/src/crypto/crypto_aes.cc b/src/crypto/crypto_aes.cc index fa93f767574299..f9f9a73d46dbb1 100644 --- a/src/crypto/crypto_aes.cc +++ b/src/crypto/crypto_aes.cc @@ -471,12 +471,9 @@ Maybe AESCipherTraits::AdditionalConfig( params->variant = static_cast(args[offset].As()->Value()); - AESCipherMode cipher_op_mode; int cipher_nid; - -#define V(name, _, mode, nid) \ +#define V(name, _, nid) \ case kKeyVariantAES_##name: { \ - cipher_op_mode = mode; \ cipher_nid = nid; \ break; \ } @@ -487,15 +484,22 @@ Maybe AESCipherTraits::AdditionalConfig( } #undef V - if (cipher_op_mode != AESCipherMode::KW) { + params->cipher = EVP_get_cipherbynid(cipher_nid); + if (params->cipher == nullptr) { + THROW_ERR_CRYPTO_UNKNOWN_CIPHER(env); + return Nothing(); + } + + int cipher_op_mode = EVP_CIPHER_mode(params->cipher); + if (cipher_op_mode != EVP_CIPH_WRAP_MODE) { if (!ValidateIV(env, mode, args[offset + 1], params)) { return Nothing(); } - if (cipher_op_mode == AESCipherMode::CTR) { + if (cipher_op_mode == EVP_CIPH_CTR_MODE) { if (!ValidateCounter(env, args[offset + 2], params)) { return Nothing(); } - } else if (cipher_op_mode == AESCipherMode::GCM) { + } else if (cipher_op_mode == EVP_CIPH_GCM_MODE) { if (!ValidateAuthTag(env, mode, cipher_mode, args[offset + 2], params) || !ValidateAdditionalData(env, mode, args[offset + 3], params)) { return Nothing(); @@ -505,12 +509,6 @@ Maybe AESCipherTraits::AdditionalConfig( UseDefaultIV(params); } - params->cipher = EVP_get_cipherbynid(cipher_nid); - if (params->cipher == nullptr) { - THROW_ERR_CRYPTO_UNKNOWN_CIPHER(env); - return Nothing(); - } - if (params->iv.size() < static_cast(EVP_CIPHER_iv_length(params->cipher))) { THROW_ERR_CRYPTO_INVALID_IV(env); @@ -527,7 +525,7 @@ WebCryptoCipherStatus AESCipherTraits::DoCipher( const AESCipherConfig& params, const ByteSource& in, ByteSource* out) { -#define V(name, fn, _, __) \ +#define V(name, fn, _) \ case kKeyVariantAES_##name: \ return fn(env, key_data.get(), cipher_mode, params, in, out); switch (params.variant) { @@ -541,7 +539,7 @@ WebCryptoCipherStatus AESCipherTraits::DoCipher( void AES::Initialize(Environment* env, Local target) { AESCryptoJob::Initialize(env, target); -#define V(name, _, __, ___) NODE_DEFINE_CONSTANT(target, kKeyVariantAES_##name); +#define V(name, _, __) NODE_DEFINE_CONSTANT(target, kKeyVariantAES_##name); VARIANTS(V) #undef V } diff --git a/src/crypto/crypto_aes.h b/src/crypto/crypto_aes.h index 2ddbc14b8e606e..a9ec45c26606de 100644 --- a/src/crypto/crypto_aes.h +++ b/src/crypto/crypto_aes.h @@ -15,29 +15,22 @@ constexpr size_t kAesBlockSize = 16; constexpr unsigned kNoAuthTagLength = static_cast(-1); constexpr const char* kDefaultWrapIV = "\xa6\xa6\xa6\xa6\xa6\xa6\xa6\xa6"; -enum class AESCipherMode { - CTR, - CBC, - GCM, - KW, -}; - #define VARIANTS(V) \ - V(CTR_128, AES_CTR_Cipher, AESCipherMode::CTR, NID_aes_128_ctr) \ - V(CTR_192, AES_CTR_Cipher, AESCipherMode::CTR, NID_aes_192_ctr) \ - V(CTR_256, AES_CTR_Cipher, AESCipherMode::CTR, NID_aes_256_ctr) \ - V(CBC_128, AES_Cipher, AESCipherMode::CBC, NID_aes_128_cbc) \ - V(CBC_192, AES_Cipher, AESCipherMode::CBC, NID_aes_192_cbc) \ - V(CBC_256, AES_Cipher, AESCipherMode::CBC, NID_aes_256_cbc) \ - V(GCM_128, AES_Cipher, AESCipherMode::GCM, NID_aes_128_gcm) \ - V(GCM_192, AES_Cipher, AESCipherMode::GCM, NID_aes_192_gcm) \ - V(GCM_256, AES_Cipher, AESCipherMode::GCM, NID_aes_256_gcm) \ - V(KW_128, AES_Cipher, AESCipherMode::KW, NID_id_aes128_wrap) \ - V(KW_192, AES_Cipher, AESCipherMode::KW, NID_id_aes192_wrap) \ - V(KW_256, AES_Cipher, AESCipherMode::KW, NID_id_aes256_wrap) + V(CTR_128, AES_CTR_Cipher, NID_aes_128_ctr) \ + V(CTR_192, AES_CTR_Cipher, NID_aes_192_ctr) \ + V(CTR_256, AES_CTR_Cipher, NID_aes_256_ctr) \ + V(CBC_128, AES_Cipher, NID_aes_128_cbc) \ + V(CBC_192, AES_Cipher, NID_aes_192_cbc) \ + V(CBC_256, AES_Cipher, NID_aes_256_cbc) \ + V(GCM_128, AES_Cipher, NID_aes_128_gcm) \ + V(GCM_192, AES_Cipher, NID_aes_192_gcm) \ + V(GCM_256, AES_Cipher, NID_aes_256_gcm) \ + V(KW_128, AES_Cipher, NID_id_aes128_wrap) \ + V(KW_192, AES_Cipher, NID_id_aes192_wrap) \ + V(KW_256, AES_Cipher, NID_id_aes256_wrap) enum AESKeyVariant { -#define V(name, _, __, ___) kKeyVariantAES_##name, +#define V(name, _, __) kKeyVariantAES_##name, VARIANTS(V) #undef V };