26 [[nodiscard]] std::vector<uint8_t>
public_key_der()
const override;
32 const std::vector<uint8_t>& contents,
33 const std::vector<uint8_t>& signature)
override;
36 const uint8_t* contents,
38 const uint8_t* signature,
39 size_t signature_size)
override;
41 [[nodiscard]] std::vector<uint8_t>
sign(
42 std::span<const uint8_t> d,
MDType md_type = {})
const override;
45 std::span<const uint8_t> d,
48 MDType md_type = {})
const;
51 const uint8_t* hash,
size_t hash_size)
const override;
57 uint8_t* sig)
const override;
60 const std::string& subject_name,
61 const std::vector<SubjectAltName>& subject_alt_names,
62 const std::optional<Pem>& public_key = std::nullopt)
const override;
65 const std::string& subject_name,
66 const std::vector<SubjectAltName>& subject_alt_names,
67 const std::optional<Pem>& public_key = std::nullopt)
const override;
70 const std::optional<Pem>& issuer_cert,
71 const Pem& signing_request,
72 const std::string& valid_from,
73 const std::string& valid_to,
82 [[nodiscard]] std::vector<uint8_t>
public_key_raw()
const override;
84 [[nodiscard]] ECPublicKey::Coordinates
coordinates()
const override;
87 const std::optional<std::string>& kid = std::nullopt)
const override;
90 [[nodiscard]] OpenSSL::Unique_X509_REQ
create_req(
91 const std::string& subject_name,
92 const std::vector<SubjectAltName>& subject_alt_names,
93 const std::optional<Pem>& public_key)
const;
Definition ec_key_pair.h:16
~ECKeyPair_OpenSSL() override=default
bool verify(const std::vector< uint8_t > &contents, const std::vector< uint8_t > &signature) override
Definition ec_key_pair.cpp:143
ECKeyPair_OpenSSL(const ECKeyPair_OpenSSL &)=delete
Pem public_key_pem() const override
Definition ec_key_pair.cpp:122
OpenSSL::Unique_X509_REQ create_req(const std::string &subject_name, const std::vector< SubjectAltName > &subject_alt_names, const std::optional< Pem > &public_key) const
Definition ec_key_pair.cpp:210
std::vector< uint8_t > private_key_der() const override
Definition ec_key_pair.cpp:132
ECPublicKey::Coordinates coordinates() const override
Definition ec_key_pair.cpp:502
std::vector< uint8_t > create_csr_der(const std::string &subject_name, const std::vector< SubjectAltName > &subject_alt_names, const std::optional< Pem > &public_key=std::nullopt) const override
Definition ec_key_pair.cpp:285
std::vector< uint8_t > public_key_raw() const override
Definition ec_key_pair.cpp:476
JsonWebKeyECPrivate private_key_jwk(const std::optional< std::string > &kid=std::nullopt) const override
Definition ec_key_pair.cpp:507
std::vector< uint8_t > sign_hash(const uint8_t *hash, size_t hash_size) const override
Definition ec_key_pair.cpp:186
std::vector< uint8_t > derive_shared_secret(const ECPublicKey &peer_key) override
Definition ec_key_pair.cpp:481
Pem create_csr(const std::string &subject_name, const std::vector< SubjectAltName > &subject_alt_names, const std::optional< Pem > &public_key=std::nullopt) const override
Definition ec_key_pair.cpp:269
Pem private_key_pem() const override
Definition ec_key_pair.cpp:109
std::vector< uint8_t > public_key_der() const override
Definition ec_key_pair.cpp:127
std::vector< uint8_t > sign(std::span< const uint8_t > d, MDType md_type={}) const override
Definition ec_key_pair.cpp:159
CurveID get_curve_id() const override
Definition ec_key_pair.cpp:471
Pem sign_csr_impl(const std::optional< Pem > &issuer_cert, const Pem &signing_request, const std::string &valid_from, const std::string &valid_to, bool ca=false, Signer signer=Signer::SUBJECT) const override
Definition ec_key_pair.cpp:304
Definition ec_key_pair.h:19
Signer
Definition ec_key_pair.h:77
Definition ec_public_key.h:17
bool verify(const uint8_t *contents, size_t contents_size, const uint8_t *sig, size_t sig_size, MDType md_type, HashBytes &bytes) override
Definition ec_public_key.cpp:174
CurveID
Definition curve.h:18
MDType
Definition md_type.h:10
std::vector< uint8_t > ECPublicKey
Definition jwt.h:38