8#ifndef BOTAN_DIFFIE_HELLMAN_H_
9#define BOTAN_DIFFIE_HELLMAN_H_
11#include <botan/pk_keys.h>
55 std::string
algo_name()
const override {
return "DH"; }
57 const BigInt& get_int_field(std::string_view field)
const override;
70 DH_PublicKey(std::shared_ptr<const DL_PublicKey> key) : m_public_key(std::move(key)) {}
72 std::shared_ptr<const DL_PublicKey> m_public_key;
107 std::unique_ptr<Public_Key>
public_key()
const override;
118 std::string_view params,
119 std::string_view provider)
const override;
122 std::shared_ptr<const DL_PrivateKey> m_private_key;
#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)
DH_PrivateKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
std::vector< uint8_t > public_value() const override
secure_vector< uint8_t > raw_private_key_bits() const override
const BigInt & get_int_field(std::string_view field) const override
secure_vector< uint8_t > private_key_bits() const override
std::unique_ptr< Public_Key > public_key() const override
std::unique_ptr< PK_Ops::Key_Agreement > create_key_agreement_op(RandomNumberGenerator &rng, std::string_view params, std::string_view provider) const override
size_t key_length() const override
bool supports_operation(PublicKeyOperation op) const override
bool check_key(RandomNumberGenerator &rng, bool strong) const override
DH_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
std::vector< uint8_t > public_value() const
std::vector< uint8_t > public_key_bits() const override
friend class DH_PrivateKey
AlgorithmIdentifier algorithm_identifier() const override
std::string algo_name() const override
const DL_Group & group() const
size_t estimated_strength() const override
std::vector< uint8_t > raw_public_key_bits() const override
std::vector< T, secure_allocator< T > > secure_vector