4#if defined(USE_ESP32) || defined(USE_ESP8266) || defined(USE_RP2040) || defined(USE_LIBRETINY) || defined(USE_HOST)
9#include <esp_idf_version.h>
10#if ESP_IDF_VERSION >= ESP_IDF_VERSION_VAL(6, 0, 0)
13#define USE_HMAC_SHA256_PSA
14#include <psa/crypto.h>
16#define USE_HMAC_SHA256_MBEDTLS
17#include "mbedtls/md.h"
19#elif defined(USE_LIBRETINY)
20#define USE_HMAC_SHA256_MBEDTLS
21#include "mbedtls/md.h"
34 void init(
const uint8_t *key,
size_t len);
35 void init(
const char *key,
size_t len) { this->
init((
const uint8_t *) key,
len); }
36 void init(
const std::string &key) { this->
init(key.c_str(), key.length()); }
39 void add(
const uint8_t *data,
size_t len);
40 void add(
const char *data,
size_t len) { this->
add((
const uint8_t *) data,
len); }
60#if defined(USE_HMAC_SHA256_PSA)
62 psa_mac_operation_t
op_ = PSA_MAC_OPERATION_INIT;
63 mbedtls_svc_key_id_t
key_id_ = MBEDTLS_SVC_KEY_ID_INIT;
65#elif defined(USE_HMAC_SHA256_MBEDTLS)
67 mbedtls_md_context_t
ctx_{};
bool equals_bytes(const uint8_t *expected)
Compare the digest against a provided byte-encoded digest (32 bytes).
mbedtls_md_context_t ctx_
mbedtls_svc_key_id_t key_id_
bool equals_hex(const char *expected)
Compare the digest against a provided hex-encoded digest (64 bytes).
void add(const char *data, size_t len)
void add(const uint8_t *data, size_t len)
Add bytes of data for the digest.
void get_hex(char *output)
Retrieve the HMAC-SHA256 digest as hex characters.
void get_bytes(uint8_t *output)
Retrieve the HMAC-SHA256 digest as bytes.
void init(const std::string &key)
static constexpr size_t SHA256_DIGEST_SIZE
uint8_t digest_[SHA256_DIGEST_SIZE]
void calculate()
Compute the digest, based on the provided data.
void init(const uint8_t *key, size_t len)
Initialize a new HMAC-SHA256 digest computation.
void init(const char *key, size_t len)
SHA256 hash implementation.