8 #ifndef BOTAN_CURVE_25519_H_
9 #define BOTAN_CURVE_25519_H_
11 #include <botan/pk_keys.h>
18 std::string
algo_name()
const override {
return "Curve25519"; }
28 std::vector<uint8_t> public_key_bits()
const override;
38 const std::vector<uint8_t>& key_bits);
93 std::unique_ptr<PK_Ops::Key_Agreement>
95 const std::string& params,
96 const std::string& provider)
const override;
110 const uint8_t secret[32],
111 const uint8_t basepoint[32]);
119 const uint8_t secret[32]);
Curve25519_PublicKey X25519_PublicKey
Curve25519_PublicKey(const secure_vector< uint8_t > &pub)
const secure_vector< uint8_t > & get_x() const
std::string algo_name() const override
void curve25519_donna(uint8_t mypublic[32], const uint8_t secret[32], const uint8_t basepoint[32])
void curve25519_basepoint(uint8_t mypublic[32], const uint8_t secret[32])
size_t key_length() const override
std::shared_ptr< const RSA_Public_Data > m_public
int(* final)(unsigned char *, CTX *)
size_t estimated_strength() const override
#define BOTAN_PUBLIC_API(maj, min)
std::vector< uint8_t > public_value() const
std::vector< T, secure_allocator< T >> secure_vector
std::shared_ptr< const RSA_Private_Data > m_private
std::vector< uint8_t > m_public
Curve25519_PublicKey(const std::vector< uint8_t > &pub)
std::vector< uint8_t > public_value() const override
Curve25519_PrivateKey X25519_PrivateKey