12#include <botan/pk_keys.h>
14#include <botan/cmce_parameter_set.h>
62 std::string
algo_name()
const override {
return "ClassicMcEliece"; }
66 OID object_identifier()
const override;
68 size_t key_length()
const override;
70 size_t estimated_strength()
const override;
72 std::vector<uint8_t> public_key_bits()
const override;
74 std::vector<uint8_t> raw_public_key_bits()
const override;
84 std::unique_ptr<PK_Ops::KEM_Encryption> create_kem_encryption_op(std::string_view params,
85 std::string_view provider)
const override;
91 std::shared_ptr<Classic_McEliece_PublicKeyInternal>
125 std::unique_ptr<Public_Key>
public_key()
const override;
134 std::string_view params,
135 std::string_view provider)
const override;
138 std::shared_ptr<Classic_McEliece_PrivateKeyInternal> m_private;
#define BOTAN_DIAGNOSTIC_POP
#define BOTAN_DIAGNOSTIC_PUSH
#define BOTAN_DIAGNOSTIC_IGNORE_INHERITED_VIA_DOMINANCE
#define BOTAN_PUBLIC_API(maj, min)
Representation of a Classic McEliece private key.
Classic_McEliece_PrivateKey(RandomNumberGenerator &rng, Classic_McEliece_Parameter_Set param_set)
Create a new Classic McEliece private key for a specified parameter set.
std::unique_ptr< PK_Ops::KEM_Decryption > create_kem_decryption_op(RandomNumberGenerator &rng, std::string_view params, std::string_view provider) const override
secure_vector< uint8_t > private_key_bits() const override
bool check_key(RandomNumberGenerator &, bool) const override
std::unique_ptr< Public_Key > public_key() const override
secure_vector< uint8_t > raw_private_key_bits() const override
Representation of a Classic McEliece public key.
bool supports_operation(PublicKeyOperation op) const override
Classic_McEliece_PublicKey()=default
Classic_McEliece_PublicKey & operator=(Classic_McEliece_PublicKey &&)=default
std::shared_ptr< Classic_McEliece_PublicKeyInternal > m_public
Classic_McEliece_PublicKey(Classic_McEliece_PublicKey &&)=default
~Classic_McEliece_PublicKey() override=default
Classic_McEliece_PublicKey & operator=(const Classic_McEliece_PublicKey &other)
Classic_McEliece_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
Load a Classic McEliece public key from bytes.
std::string algo_name() const override
std::vector< T, secure_allocator< T > > secure_vector