CCF
Loading...
Searching...
No Matches
public_key.h
Go to the documentation of this file.
1// Copyright (c) Microsoft Corporation. All rights reserved.
2// Licensed under the Apache 2.0 License.
3#pragma once
4
7
8#include <openssl/err.h>
9#include <openssl/evp.h>
10#include <stdexcept>
11#include <string>
12
13namespace ccf::crypto
14{
16 {
17 protected:
18 EVP_PKEY* key = nullptr;
20
21 static std::vector<uint8_t> ec_point_public_from_jwk(
22 const JsonWebKeyECPublic& jwk);
23
24 public:
26 PublicKey_OpenSSL(EVP_PKEY* key);
27 PublicKey_OpenSSL(const Pem& pem);
28 PublicKey_OpenSSL(std::span<const uint8_t> der);
30 virtual ~PublicKey_OpenSSL();
31
32 using PublicKey::verify;
33 using PublicKey::verify_hash;
34
35 virtual bool verify(
36 const uint8_t* contents,
37 size_t contents_size,
38 const uint8_t* sig,
39 size_t sig_size,
40 MDType md_type,
41 HashBytes& bytes) override;
42
43 virtual bool verify_hash(
44 const uint8_t* hash,
45 size_t hash_size,
46 const uint8_t* sig,
47 size_t sig_size,
48 MDType md_type) override;
49
50 virtual Pem public_key_pem() const override;
51 virtual std::vector<uint8_t> public_key_der() const override;
52 virtual std::vector<uint8_t> public_key_raw() const override;
53
54 virtual CurveID get_curve_id() const override;
55
56 int get_openssl_group_id() const;
57 static int get_openssl_group_id(CurveID gid);
58
59 operator EVP_PKEY*() const
60 {
61 return key;
62 }
63
64 virtual Coordinates coordinates() const override;
65
67 const std::optional<std::string>& kid = std::nullopt) const override;
68 };
69
70 OpenSSL::Unique_PKEY key_from_raw_ec_point(
71 const std::vector<uint8_t>& raw, int nid);
72}
Definition pem.h:18
Definition public_key.h:16
virtual ~PublicKey_OpenSSL()
Definition public_key.cpp:108
virtual CurveID get_curve_id() const override
Definition public_key.cpp:116
virtual Pem public_key_pem() const override
Definition public_key.cpp:219
virtual std::vector< uint8_t > public_key_raw() const override
Definition public_key.cpp:241
virtual std::vector< uint8_t > public_key_der() const override
Definition public_key.cpp:230
virtual 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 public_key.cpp:169
virtual bool verify_hash(const uint8_t *hash, size_t hash_size, const uint8_t *sig, size_t sig_size, MDType md_type) override
Definition public_key.cpp:186
virtual JsonWebKeyECPublic public_key_jwk(const std::optional< std::string > &kid=std::nullopt) const override
Definition public_key.cpp:313
EVP_PKEY * key
Definition public_key.h:18
static std::vector< uint8_t > ec_point_public_from_jwk(const JsonWebKeyECPublic &jwk)
Definition public_key.cpp:67
virtual Coordinates coordinates() const override
Definition public_key.cpp:293
int get_openssl_group_id() const
Definition public_key.cpp:131
PublicKey_OpenSSL(PublicKey_OpenSSL &&key)=default
Definition public_key.h:19
Definition base64.h:10
std::vector< uint8_t > HashBytes
Definition hash_bytes.h:10
Unique_PKEY key_from_raw_ec_point(const std::vector< uint8_t > &raw, int nid)
Definition public_key.cpp:259
MDType
Definition md_type.h:10
CurveID
Definition curve.h:18