11#include <botan/asn1_obj.h>
12#include <botan/pkix_types.h>
13#include <botan/x509cert.h>
14#include <botan/bigint.h>
19class Certificate_Store;
29 const BigInt& subject_serial);
34 void encode_into(
class DER_Encoder& to)
const override;
42 std::vector<uint8_t> m_issuer_dn_hash;
43 std::vector<uint8_t> m_issuer_key_hash;
58 void encode_into(
class DER_Encoder& to)
const override;
63 size_t m_cert_status = 2;
83 const BigInt& subject_serial);
106 {
return m_certid.issuer_key_hash(); }
149 Response(
const std::vector<uint8_t>& response_bits) :
150 Response(response_bits.data(), response_bits.size())
158 Response(
const uint8_t response_bits[],
159 size_t response_bits_len);
171 const std::vector<std::shared_ptr<const X509_Certificate>>& cert_path = {})
const;
200 const std::vector<uint8_t>&
raw_bits()
const {
return m_response_bits; }
220 std::chrono::system_clock::time_point ref_time = std::chrono::system_clock::now(),
221 std::chrono::seconds max_age = std::chrono::seconds::zero())
const;
226 const std::vector<X509_Certificate> &
certificates()
const {
return m_certs; }
230 std::vector<uint8_t> m_response_bits;
233 std::vector<uint8_t> m_key_hash;
234 std::vector<uint8_t> m_tbs_bits;
236 std::vector<uint8_t> m_signature;
237 std::vector<X509_Certificate> m_certs;
239 std::vector<SingleResponse> m_responses;
244#if defined(BOTAN_HAS_HTTP_UTIL)
257 const
BigInt& subject_serial,
258 const
std::
string& ocsp_responder,
260 std::chrono::milliseconds timeout =
std::chrono::milliseconds(3000));
274 std::chrono::milliseconds timeout =
std::chrono::milliseconds(3000));
const std::vector< uint8_t > & issuer_key_hash() const
const X509_Certificate & subject() const
const std::vector< uint8_t > & issuer_key_hash() const
const X509_Certificate & issuer() const
Response(const std::vector< uint8_t > &response_bits)
Response_Status_Code status() const
const X509_DN & signer_name() const
const X509_Time & produced_at() const
const std::vector< X509_Certificate > & certificates() const
const std::vector< uint8_t > & raw_bits() const
const std::vector< uint8_t > & signer_key_hash() const
const CertID & certid() const
X509_Time next_update() const
X509_Time this_update() const
size_t cert_status() const
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
secure_vector< uint8_t > BER_encode(const Private_Key &key)
size_t base64_encode(char out[], const uint8_t in[], size_t input_length, size_t &input_consumed, bool final_inputs)