8#ifndef BOTAN_SM2_KEY_H_
9#define BOTAN_SM2_KEY_H_
11#include <botan/ecc_key.h>
37 const std::vector<uint8_t>& key_bits) :
44 std::string algo_name()
const override;
49 {
return domain().get_order().bytes(); }
51 std::unique_ptr<PK_Ops::Verification>
52 create_verification_op(
const std::string& params,
53 const std::string& provider)
const override;
55 std::unique_ptr<PK_Ops::Encryption>
57 const std::string& params,
58 const std::string& provider)
const override;
92 std::unique_ptr<PK_Ops::Signature>
94 const std::string& params,
95 const std::string& provider)
const override;
97 std::unique_ptr<PK_Ops::Decryption>
99 const std::string& params,
100 const std::string& provider)
const override;
111 const
std::
string& user_id,
112 const EC_Group& domain,
113 const PointGFp& pubkey);
const BigInt & get_da_inv() const
size_t message_part_size() const override
SM2_PublicKey(const AlgorithmIdentifier &alg_id, const std::vector< uint8_t > &key_bits)
size_t message_parts() const override
SM2_PublicKey(const EC_Group &dom_par, const PointGFp &public_point)
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
std::vector< uint8_t > sm2_compute_za(HashFunction &hash, const std::string &user_id, const EC_Group &domain, const PointGFp &pubkey)
std::vector< T, secure_allocator< T > > secure_vector