8#ifndef BOTAN_ECKCDSA_KEY_H_
9#define BOTAN_ECKCDSA_KEY_H_
11#include <botan/ecc_key.h>
37 std::span<const uint8_t> key_bits) :
43 std::string
algo_name()
const override {
return "ECKCDSA"; }
48 {
return domain().get_order().bytes(); }
52 return (op == PublicKeyOperation::Signature);
55 std::unique_ptr<PK_Ops::Verification>
56 create_verification_op(std::string_view params,
57 std::string_view provider)
const override;
59 std::unique_ptr<PK_Ops::Verification>
61 std::string_view provider)
const override;
84 std::span<const uint8_t> key_bits) :
95 const BigInt& x = BigInt::zero()) :
100 std::unique_ptr<Public_Key> public_key()
const override;
102 std::unique_ptr<PK_Ops::Signature>
104 std::string_view params,
105 std::string_view provider)
const override;
ECKCDSA_PrivateKey(RandomNumberGenerator &rng, const EC_Group &domain, const BigInt &x=BigInt::zero())
ECKCDSA_PrivateKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
bool supports_operation(PublicKeyOperation op) const override
std::string algo_name() const override
ECKCDSA_PublicKey(const EC_Group &dom_par, const EC_Point &public_point)
ECKCDSA_PublicKey()=default
size_t message_part_size() const override
size_t message_parts() const override
ECKCDSA_PublicKey(const AlgorithmIdentifier &alg_id, std::span< const uint8_t > key_bits)
int(* final)(unsigned char *, CTX *)
#define BOTAN_DIAGNOSTIC_POP
#define BOTAN_DIAGNOSTIC_PUSH
#define BOTAN_DIAGNOSTIC_IGNORE_INHERITED_VIA_DOMINANCE
#define BOTAN_PUBLIC_API(maj, min)