#ifndef OSSL_MLX_KEM_H
#define OSSL_MLX_KEM_H
#pragma once
#include <openssl/evp.h>
#include <openssl/ml_kem.h>
#include <crypto/ml_kem.h>
#include <crypto/ecx.h>
typedef struct ecdh_vinfo_st {
const char *algorithm_name;
const char *group_name;
size_t pubkey_bytes;
size_t prvkey_bytes;
size_t shsec_bytes;
int ml_kem_slot;
int ml_kem_variant;
} ECDH_VINFO;
typedef struct mlx_key_st {
OSSL_LIB_CTX *libctx;
char *propq;
const ML_KEM_VINFO *minfo;
const ECDH_VINFO *xinfo;
EVP_PKEY *mkey;
EVP_PKEY *xkey;
unsigned int state;
} MLX_KEY;
#define MLX_HAVE_NOKEYS 0
#define MLX_HAVE_PUBKEY 1
#define MLX_HAVE_PRVKEY 2
#define mlx_kem_have_pubkey(key) ((key)->state > 0)
#define mlx_kem_have_prvkey(key) ((key)->state > 1)
#endif