From 84c0f3425b61ab8bf2477d6f01c311bee0dc324a Mon Sep 17 00:00:00 2001 From: Damian Krolik Date: Wed, 17 Jan 2024 19:26:35 +0100 Subject: [PATCH] Code review --- src/crypto/RawKeySessionKeystore.cpp | 3 ++- src/crypto/SessionKeystore.h | 37 +++++++++++++++------------- 2 files changed, 22 insertions(+), 18 deletions(-) diff --git a/src/crypto/RawKeySessionKeystore.cpp b/src/crypto/RawKeySessionKeystore.cpp index 3e1a3e16f9a327..5192962da0a170 100644 --- a/src/crypto/RawKeySessionKeystore.cpp +++ b/src/crypto/RawKeySessionKeystore.cpp @@ -29,7 +29,8 @@ struct RawHkdfKeyHandle { ByteSpan Span() const { return ByteSpan(data, size); } - static constexpr size_t kMaxDataSize = std::min(CHIP_CONFIG_HKDF_KEY_HANDLE_CONTEXT_SIZE - 1, UINT8_MAX); + // Cap the data size so that the entire structure fits in the opaque context of the HKDF key handle. + static constexpr size_t kMaxDataSize = std::min(CHIP_CONFIG_HKDF_KEY_HANDLE_CONTEXT_SIZE - sizeof(uint8_t), UINT8_MAX); uint8_t data[kMaxDataSize]; uint8_t size; diff --git a/src/crypto/SessionKeystore.h b/src/crypto/SessionKeystore.h index 305dacdf79d1e2..d668524ac93aed 100644 --- a/src/crypto/SessionKeystore.h +++ b/src/crypto/SessionKeystore.h @@ -100,41 +100,44 @@ class SessionKeystore *****************************/ /** - * @brief Derive key from a shared secret. + * @brief Derive key from a session establishment's `SharedSecret`. * - * Use HKDF as defined in the Matter specification to derive an AES key from the shared secret. + * Use `Crypto_KDF` (HKDF) primitive as defined in the Matter specification to derive + * a symmetric (AES) key from the session establishment's `SharedSecret`. * - * If the method returns no error, the application is responsible for destroying the handle - * using DestroyKey() method when the key is no longer needed. + * If the method returns no error, the caller is responsible for destroying the symmetric key + * using the DestroyKey() method when the key is no longer needed. */ virtual CHIP_ERROR DeriveKey(const P256ECDHDerivedSecret & secret, const ByteSpan & salt, const ByteSpan & info, Aes128KeyHandle & key) = 0; /** - * @brief Derive session keys from a shared secret. + * @brief Derive session keys from a session establishment's `SharedSecret`. * - * Use HKDF as defined in the Matter specification to derive AES keys for both directions, and - * the attestation challenge from the shared secret. + * Use `Crypto_KDF` (HKDF) primitive as defined in the Matter specification to derive symmetric + * (AES) session keys for both directions, and the attestation challenge from the session + * establishment's `SharedSecret`. * - * If the method returns no error, the application is responsible for destroying the AES keys - * using DestroyKey() method when the keys are no longer needed. On failure, the method must - * release all handles that it allocated so far. + * If the method returns no error, the caller is responsible for destroying the symmetric keys + * using the DestroyKey() method when the keys are no longer needed. On failure, the method is + * responsible for releasing all keys that it allocated so far. */ virtual CHIP_ERROR DeriveSessionKeys(const ByteSpan & secret, const ByteSpan & salt, const ByteSpan & info, Aes128KeyHandle & i2rKey, Aes128KeyHandle & r2iKey, AttestationChallenge & attestationChallenge) = 0; /** - * @brief Derive session keys from the HKDF key + * @brief Derive session keys from a session establishment's `SharedSecret`. * - * Use HKDF as defined in the Matter specification to derive AES keys for both directions, and - * the attestation challenge from the HKDF key. + * Use Crypto_KDF (HKDF) primitive as defined in the Matter specification to derive symmetric + * (AES) session keys for both directions, and the attestation challenge from the session + * establishment's `SharedSecret`, represented as the key handle. * - * If the method returns no error, the application is responsible for destroying the AES keys - * using DestroyKey() method when the keys are no longer needed. On failure, the method must - * release all handles that it allocated so far. + * If the method returns no error, the caller is responsible for destroying the symmetric keys + * using the DestroyKey() method when the keys are no longer needed. On failure, the method is + * responsible for releasing all keys that it allocated so far. */ - virtual CHIP_ERROR DeriveSessionKeys(const HkdfKeyHandle & hkdfKey, const ByteSpan & salt, const ByteSpan & info, + virtual CHIP_ERROR DeriveSessionKeys(const HkdfKeyHandle & secretKey, const ByteSpan & salt, const ByteSpan & info, Aes128KeyHandle & i2rKey, Aes128KeyHandle & r2iKey, AttestationChallenge & attestationChallenge) = 0; };