11#ifndef BOTAN_TLS_13_HYBRID_KEM_PUBLIC_KEY_H_
12#define BOTAN_TLS_13_HYBRID_KEM_PUBLIC_KEY_H_
14#include <botan/pubkey.h>
16#include <botan/tls_algos.h>
43 std::span<const uint8_t> concatenated_public_values);
66 std::string_view kdf, std::string_view provider =
"base")
const override;
75 size_t m_estimated_strength;
98 std::unique_ptr<Public_Key>
public_key()
const override;
103 RandomNumberGenerator& rng, std::string_view kdf, std::string_view provider =
"base")
const override;
108 std::vector<std::unique_ptr<Private_Key>> m_private_keys;
#define BOTAN_DIAGNOSTIC_POP
#define BOTAN_DIAGNOSTIC_PUSH
#define BOTAN_DIAGNOSTIC_IGNORE_INHERITED_VIA_DOMINANCE
static std::unique_ptr< Hybrid_KEM_PrivateKey > generate_from_group(Group_Params group, RandomNumberGenerator &rng)
bool check_key(RandomNumberGenerator &rng, bool strong) const override
std::unique_ptr< Public_Key > public_key() const override
std::unique_ptr< PK_Ops::KEM_Decryption > create_kem_decryption_op(RandomNumberGenerator &rng, std::string_view kdf, std::string_view provider="base") const override
const auto & private_keys() const
Hybrid_KEM_PrivateKey(std::vector< std::unique_ptr< Private_Key > > private_keys)
secure_vector< uint8_t > private_key_bits() const override
AlgorithmIdentifier algorithm_identifier() const override
Hybrid_KEM_PublicKey(Hybrid_KEM_PublicKey &&)=default
~Hybrid_KEM_PublicKey()=default
std::vector< uint8_t > raw_public_key_bits() const override
std::vector< std::unique_ptr< Public_Key > > m_public_keys
const auto & public_keys() const
Hybrid_KEM_PublicKey(std::vector< std::unique_ptr< Public_Key > > pks)
bool check_key(RandomNumberGenerator &rng, bool strong) const override
size_t estimated_strength() const override
static std::unique_ptr< Hybrid_KEM_PublicKey > load_for_group(Group_Params group, std::span< const uint8_t > concatenated_public_values)
Hybrid_KEM_PublicKey(const Hybrid_KEM_PublicKey &)=delete
Hybrid_KEM_PublicKey & operator=(const Hybrid_KEM_PublicKey &)=delete
std::unique_ptr< Private_Key > generate_another(RandomNumberGenerator &rng) const final
Hybrid_KEM_PublicKey & operator=(Hybrid_KEM_PublicKey &&)=default
bool supports_operation(PublicKeyOperation op) const override
std::string algo_name() const override
std::vector< uint8_t > public_key_bits() const override
size_t key_length() const override
std::unique_ptr< PK_Ops::KEM_Encryption > create_kem_encryption_op(std::string_view kdf, std::string_view provider="base") const override
std::vector< T, secure_allocator< T > > secure_vector