openldap/libraries/liblmdb/crypto.c
Howard Chu e895f5fd36 ITS#9920 crypto: use libsodium instead of OpenSSL
Note: even though the same algorithms were used, the data produced by
this module doesn't work with the OpenSSL-based module and vice versa.
2024-10-14 19:39:32 +01:00

77 lines
2 KiB
C

/* crypto.c - LMDB encryption helper module */
/*
* Copyright 2020-2024 Howard Chu, Symas Corp.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted only as authorized by the Symas
* Dual-Use License.
*
* A copy of this license is available in the file LICENSE in the
* source distribution.
*/
#include <string.h>
#include <sodium.h>
#include "lmdb.h"
#define KEYBYTES crypto_aead_chacha20poly1305_ietf_KEYBYTES
#define NONCEBYTES crypto_aead_chacha20poly1305_ietf_NPUBBYTES
#define MACBYTES crypto_aead_chacha20poly1305_ietf_ABYTES
MDB_crypto_hooks MDB_crypto;
static int mcf_str2key(const char *passwd, MDB_val *key)
{
crypto_hash_sha256_state state;
crypto_hash_sha256_init(&state);
crypto_hash_sha256_update(&state, (const unsigned char *)"Just a Constant", sizeof("Just a Constant"));
crypto_hash_sha256_update(&state, (const unsigned char *)passwd, strlen(passwd));
crypto_hash_sha256_final(&state, key->mv_data);
return 0;
}
#define ENC(dst, src, mac, key, iv) \
crypto_aead_chacha20poly1305_ietf_encrypt_detached(dst->mv_data, mac, &mlen, \
src->mv_data, src->mv_size, NULL, 0, NULL, iv, key)
#define DEC(dst, src, mac, key, iv) \
crypto_aead_chacha20poly1305_ietf_decrypt_detached(dst->mv_data, NULL, src->mv_data, \
src->mv_size, mac, NULL, 0, iv, key)
static int mcf_encfunc(const MDB_val *src, MDB_val *dst, const MDB_val *key, int encdec)
{
unsigned char iv[NONCEBYTES];
mdb_size_t *ptr;
int ivl, rc;
unsigned long long mlen;
/* the nonce is only 12 bytes */
ptr = key[1].mv_data;
ivl = ptr[0] & 0xffffffff;
memcpy(iv, &ivl, 4);
memcpy(iv+4, ptr+1, sizeof(mdb_size_t));
if (encdec) {
rc = ENC(dst, src, key[2].mv_data, key[0].mv_data, iv);
} else {
rc = DEC(dst, src, key[2].mv_data, key[0].mv_data, iv);
}
return rc;
}
static const MDB_crypto_funcs mcf_table = {
mcf_str2key,
mcf_encfunc,
NULL,
KEYBYTES,
MACBYTES,
0
};
MDB_crypto_funcs *MDB_crypto()
{
return (MDB_crypto_funcs *)&mcf_table;
}