core-lightning/common/hmac.c
Rusty Russell af90fdc0bb common/utils: macros to help get copy/compare across different types right.
Things are often equivalent but different types:
1. u8 arrays in libwally.
2. sha256
3. Secrets derived via sha256
4. txids

Rather than open-coding a BUILD_ASSERT & memcpy, create a macro to do it.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2024-07-23 09:54:47 +09:30

56 lines
1.3 KiB
C

#include "config.h"
#include <bitcoin/privkey.h>
#include <ccan/array_size/array_size.h>
#include <ccan/mem/mem.h>
#include <common/hmac.h>
#include <common/utils.h>
#include <wire/wire.h>
void hmac_start(crypto_auth_hmacsha256_state *state,
const void *key, size_t klen)
{
crypto_auth_hmacsha256_init(state, memcheck(key, klen), klen);
}
void hmac_update(crypto_auth_hmacsha256_state *state,
const void *src, size_t slen)
{
crypto_auth_hmacsha256_update(state, memcheck(src, slen), slen);
}
void hmac_done(crypto_auth_hmacsha256_state *state,
struct hmac *hmac)
{
crypto_auth_hmacsha256_final(state, hmac->bytes);
}
void hmac(const void *src, size_t slen,
const void *key, size_t klen,
struct hmac *hmac)
{
crypto_auth_hmacsha256_state state;
hmac_start(&state, key, klen);
hmac_update(&state, src, slen);
hmac_done(&state, hmac);
}
void subkey_from_hmac(const char *prefix,
const struct secret *base,
struct secret *key)
{
struct hmac h;
hmac(base->data, sizeof(base->data), prefix, strlen(prefix), &h);
CROSS_TYPE_ASSIGNMENT(&key->data, &h.bytes);
}
void towire_hmac(u8 **pptr, const struct hmac *hmac)
{
towire_u8_array(pptr, hmac->bytes, ARRAY_SIZE(hmac->bytes));
}
void fromwire_hmac(const u8 **ptr, size_t *max, struct hmac *hmac)
{
fromwire_u8_array(ptr, max, hmac->bytes, ARRAY_SIZE(hmac->bytes));
}