10#ifndef BOTAN_ECDSA_KEY_H_
11#define BOTAN_ECDSA_KEY_H_
13#include <botan/ecc_key.h>
39 const std::vector<uint8_t>& key_bits) :
52 const std::vector<uint8_t>& msg,
61 std::string
algo_name()
const override {
return "ECDSA"; }
66 {
return domain().get_order().bytes(); }
68 uint8_t recovery_param(
const std::vector<uint8_t>& msg,
72 std::unique_ptr<PK_Ops::Verification>
73 create_verification_op(
const std::string& params,
74 const std::string& provider)
const override;
109 std::unique_ptr<Public_Key> public_key()
const override;
111 std::unique_ptr<PK_Ops::Signature>
113 const std::string& params,
114 const std::string& provider)
const override;
ECDSA_PrivateKey(RandomNumberGenerator &rng, const EC_Group &domain, const BigInt &x=BigInt::zero())
ECDSA_PrivateKey(const AlgorithmIdentifier &alg_id, const secure_vector< uint8_t > &key_bits)
std::string algo_name() const override
ECDSA_PublicKey()=default
size_t message_part_size() const override
ECDSA_PublicKey(const EC_Group &dom_par, const PointGFp &public_point)
size_t message_parts() const override
ECDSA_PublicKey(const AlgorithmIdentifier &alg_id, const std::vector< uint8_t > &key_bits)
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
std::vector< T, secure_allocator< T > > secure_vector