10#ifndef BOTAN_ECDSA_KEY_H_
11#define BOTAN_ECDSA_KEY_H_
13#include <botan/ecc_key.h>
29#if defined(BOTAN_HAS_LEGACY_EC_POINT)
56 const EC_Group& group,
const std::vector<uint8_t>& msg,
const BigInt& r,
const BigInt& s, uint8_t v);
62 std::string
algo_name()
const override {
return "ECDSA"; }
65 return domain().get_order_bytes();
72 uint8_t recovery_param(
const std::vector<uint8_t>& msg,
const BigInt& r,
const BigInt& s)
const;
74 std::unique_ptr<PK_Ops::Verification> create_verification_op(std::string_view params,
75 std::string_view provider)
const override;
77 std::unique_ptr<PK_Ops::Verification> create_x509_verification_op(
const AlgorithmIdentifier& signature_algorithm,
78 std::string_view provider)
const override;
128 std::unique_ptr<Public_Key> public_key()
const override;
131 std::string_view params,
132 std::string_view provider)
const override;
#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)
ECDSA_PrivateKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
ECDSA_PrivateKey(RandomNumberGenerator &rng, EC_Group group)
ECDSA_PrivateKey(EC_Group group, EC_Scalar x)
ECDSA_PublicKey(const EC_Group &group, const EC_AffinePoint &public_key)
std::string algo_name() const override
ECDSA_PublicKey()=default
ECDSA_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
bool supports_operation(PublicKeyOperation op) const override
std::optional< size_t > _signature_element_size_for_DER_encoding() const override
int(* final)(unsigned char *, CTX *)