9#ifndef BOTAN_ED25519_H_
10#define BOTAN_ED25519_H_
12#include <botan/pk_keys.h>
19 std::string
algo_name()
const override {
return "Ed25519"; }
29 std::vector<uint8_t> raw_public_key_bits()
const override;
31 std::vector<uint8_t> public_key_bits()
const override;
53 std::unique_ptr<PK_Ops::Verification> create_verification_op(std::string_view params,
54 std::string_view provider)
const override;
56 std::unique_ptr<PK_Ops::Verification> create_x509_verification_op(
const AlgorithmIdentifier& signature_algorithm,
57 std::string_view provider)
const override;
122 std::unique_ptr<Public_Key> public_key()
const override;
127 std::string_view params,
128 std::string_view provider)
const override;
136BOTAN_DEPRECATED(
"Use Ed25519_PrivateKey or Sodium::crypto_sign_ed25519_seed_keypair")
139BOTAN_DEPRECATED(
"Use Ed25519_PrivateKey or Sodium::crypto_sign_ed25519_detached")
143 const uint8_t sk[64],
144 const uint8_t domain_sep[],
145 size_t domain_sep_len);
147BOTAN_DEPRECATED(
"Use Ed25519_PublicKey or Sodium::crypto_sign_ed25519_verify_detached")
150 const uint8_t sig[64],
151 const uint8_t pk[32],
152 const uint8_t domain_sep[],
153 size_t domain_sep_len);
#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_FUTURE_EXPLICIT
Ed25519_PrivateKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
const secure_vector< uint8_t > & get_private_key() const
static Ed25519_PrivateKey from_seed(std::span< const uint8_t > seed)
static Ed25519_PrivateKey from_bytes(std::span< const uint8_t > bytes)
secure_vector< uint8_t > raw_private_key_bits() const override
BOTAN_FUTURE_EXPLICIT Ed25519_PublicKey(std::span< const uint8_t > pub)
std::vector< uint8_t > m_public
Ed25519_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
const std::vector< uint8_t > & get_public_key() const
std::string algo_name() const override
bool supports_operation(PublicKeyOperation op) const override
size_t key_length() const override
size_t estimated_strength() const override
Ed25519_PublicKey()=default
void ed25519_sign(uint8_t sig[64], const uint8_t m[], size_t mlen, const uint8_t sk[64], const uint8_t domain_sep[], size_t domain_sep_len)
void ed25519_gen_keypair(uint8_t pk[32], uint8_t sk[64], const uint8_t seed[32])
std::vector< T, secure_allocator< T > > secure_vector
bool ed25519_verify(const uint8_t *m, size_t mlen, const uint8_t sig[64], const uint8_t *pk, const uint8_t domain_sep[], size_t domain_sep_len)