14#ifndef BOTAN_DILITHIUM_COMMON_H_
15#define BOTAN_DILITHIUM_COMMON_H_
17#include <botan/pk_keys.h>
41 OID object_identifier()
const;
46 bool is_ml_dsa() const;
50 bool is_available()
const;
58class Dilithium_PublicKeyInternal;
59class Dilithium_PrivateKeyInternal;
97 std::unique_ptr<PK_Ops::Verification> create_verification_op(std::string_view params,
98 std::string_view provider)
const override;
100 std::unique_ptr<PK_Ops::Verification> create_x509_verification_op(
const AlgorithmIdentifier& signature_algorithm,
101 std::string_view provider)
const override;
109 std::shared_ptr<Dilithium_PublicKeyInternal>
m_public;
118 std::unique_ptr<Public_Key>
public_key()
const override;
145 std::string_view params,
146 std::string_view provider)
const override;
151 std::shared_ptr<Dilithium_PrivateKeyInternal> m_private;
#define BOTAN_DIAGNOSTIC_POP
#define BOTAN_DIAGNOSTIC_PUSH
#define BOTAN_DIAGNOSTIC_IGNORE_INHERITED_VIA_DOMINANCE
#define BOTAN_PUBLIC_API(maj, min)
#define BOTAN_DEPRECATED(msg)
bool is_dilithium_round3() const
friend class Dilithium_Signature_Operation
Dilithium_PrivateKey(RandomNumberGenerator &rng, DilithiumMode mode)
secure_vector< uint8_t > raw_private_key_bits() const override
std::unique_ptr< PK_Ops::Signature > create_signature_op(RandomNumberGenerator &, std::string_view params, std::string_view provider) const override
secure_vector< uint8_t > private_key_bits() const override
std::unique_ptr< Public_Key > public_key() const override
AlgorithmIdentifier algorithm_identifier() const override
std::vector< uint8_t > public_key_bits() const override
friend class Dilithium_Signature_Operation
OID object_identifier() const override
bool check_key(RandomNumberGenerator &, bool) const override
bool supports_operation(PublicKeyOperation op) const override
Dilithium_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > pk)
size_t key_length() const override
~Dilithium_PublicKey() override=default
Dilithium_PublicKey & operator=(const Dilithium_PublicKey &other)=default
friend class Dilithium_Verification_Operation
std::string algo_name() const override
size_t estimated_strength() const override
Dilithium_PublicKey()=default
std::vector< uint8_t > raw_public_key_bits() const override
std::shared_ptr< Dilithium_PublicKeyInternal > m_public
std::vector< T, secure_allocator< T > > secure_vector
std::string to_string(ErrorType type)
Convert an ErrorType to string.