10#include <botan/pk_keys.h>
16 std::string
algo_name()
const override {
return "X25519"; }
26 std::vector<uint8_t> raw_public_key_bits()
const override;
28 std::vector<uint8_t> public_key_bits()
const override;
92 std::unique_ptr<Public_Key> public_key()
const override;
97 std::string_view params,
98 std::string_view provider)
const override;
111void
curve25519_donna(uint8_t mypublic[32], const uint8_t secret[32], const uint8_t basepoint[32]);
#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)
#define BOTAN_DEPRECATED_API(msg)
const secure_vector< uint8_t > & get_x() const
std::vector< uint8_t > public_value() const override
secure_vector< uint8_t > raw_private_key_bits() const override
X25519_PrivateKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
std::string algo_name() const override
size_t estimated_strength() const override
std::vector< uint8_t > raw_public_key_bits() const override
std::vector< uint8_t > m_public
X25519_PublicKey()=default
std::vector< uint8_t > public_value() const
X25519_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
bool supports_operation(PublicKeyOperation op) const override
size_t key_length() const override
void curve25519_donna(uint8_t mypublic[32], const uint8_t secret[32], const uint8_t basepoint[32])
std::vector< T, secure_allocator< T > > secure_vector
void curve25519_basepoint(uint8_t mypublic[32], const uint8_t secret[32])