11 #ifndef BOTAN_ED25519_H_ 12 #define BOTAN_ED25519_H_ 14 #include <botan/pk_keys.h> 21 std::string
algo_name()
const override {
return "Ed25519"; }
31 std::vector<uint8_t> public_key_bits()
const override;
39 const std::vector<uint8_t>& key_bits);
41 template<
typename Alloc>
47 std::unique_ptr<PK_Ops::Verification>
48 create_verification_op(
const std::string& params,
49 const std::string& provider)
const override;
88 std::unique_ptr<PK_Ops::Signature>
90 const std::string& params,
91 const std::string& provider)
const override;
102 const uint8_t sk[64],
103 const uint8_t domain_sep[],
size_t domain_sep_len);
107 const uint8_t sig[64],
108 const uint8_t pk[32],
109 const uint8_t domain_sep[],
size_t domain_sep_len);
void ed25519_gen_keypair(uint8_t *pk, uint8_t *sk, const uint8_t seed[32])
std::vector< uint8_t > m_public
std::string algo_name() const override
size_t estimated_strength() const override
const std::vector< uint8_t > & get_public_key() const
int(* final)(unsigned char *, CTX *)
Ed25519_PublicKey(const std::vector< uint8_t, Alloc > &pub)
#define BOTAN_PUBLIC_API(maj, min)
size_t key_length() const override
const secure_vector< uint8_t > & get_private_key() const
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)
std::vector< T, secure_allocator< T > > secure_vector
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)