Botan 3.12.0
Crypto and TLS for C&
certstor_windows.h
Go to the documentation of this file.
1/*
2* Certificate Store
3* (C) 1999-2019 Jack Lloyd
4* (C) 2019 Patrick Schmidt
5* (C) 2021 René Meusel
6*
7* Botan is released under the Simplified BSD License (see license.txt)
8*/
9
10#ifndef BOTAN_CERT_STORE_SYSTEM_WINDOWS_H_
11#define BOTAN_CERT_STORE_SYSTEM_WINDOWS_H_
12
13#include <botan/certstor.h>
14#include <memory>
15
16// Use Certificate_Store_System instead
17BOTAN_FUTURE_INTERNAL_HEADER(certstor_windows.h)
18
19namespace Botan {
20
21class Certificate_Store_Windows_Impl;
22
23/**
24* Certificate Store that is backed by the system trust store on Windows.
25*/
27 public:
29
34
35 /**
36 * @return DNs for all certificates managed by the store
37 */
38 std::vector<X509_DN> all_subjects() const override;
39
40 /**
41 * Find a certificate by Subject DN and (optionally) key identifier
42 * @return the first certificate that matches
43 */
44 std::optional<X509_Certificate> find_cert(const X509_DN& subject_dn,
45 const std::vector<uint8_t>& key_id) const override;
46
47 /**
48 * Find all certificates with a given Subject DN.
49 * Subject DN and even the key identifier might not be unique.
50 */
51 std::vector<X509_Certificate> find_all_certs(const X509_DN& subject_dn,
52 const std::vector<uint8_t>& key_id) const override;
53
54 /**
55 * Find a certificate by searching for one with a matching SHA-1 hash of
56 * public key.
57 * @return a matching certificate or nullptr otherwise
58 */
59 std::optional<X509_Certificate> find_cert_by_pubkey_sha1(const std::vector<uint8_t>& key_hash) const override;
60
61 /**
62 * @throws Not_Implemented as this is not possible in the Windows system cert API
63 */
64 std::optional<X509_Certificate> find_cert_by_raw_subject_dn_sha256(
65 const std::vector<uint8_t>& subject_hash) const override;
66
67 std::optional<X509_Certificate> find_cert_by_issuer_dn_and_serial_number(
68 const X509_DN& issuer_dn, std::span<const uint8_t> serial_number) const override;
69
70 /**
71 * Not Yet Implemented
72 * @return nullptr;
73 */
74 std::optional<X509_CRL> find_crl_for(const X509_Certificate& subject) const override;
75
76 bool contains(const X509_Certificate& cert) const override;
77
78 private:
79 std::shared_ptr<Certificate_Store_Windows_Impl> m_impl;
80};
81
82} // namespace Botan
83
84#endif
#define BOTAN_PUBLIC_API(maj, min)
Definition api.h:21
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)
Definition api.h:98
Certificate_Store_Windows(const Certificate_Store_Windows &)=default
Certificate_Store_Windows & operator=(const Certificate_Store_Windows &)=default
Certificate_Store_Windows(Certificate_Store_Windows &&)=default
Certificate_Store_Windows & operator=(Certificate_Store_Windows &&)=default
virtual std::optional< X509_CRL > find_crl_for(const X509_Certificate &subject) const
Definition certstor.cpp:50
virtual std::vector< X509_DN > all_subjects() const =0
virtual std::optional< X509_Certificate > find_cert_by_raw_subject_dn_sha256(const std::vector< uint8_t > &subject_hash) const =0
virtual bool contains(const X509_Certificate &cert) const
Definition certstor.cpp:28
virtual std::optional< X509_Certificate > find_cert_by_issuer_dn_and_serial_number(const X509_DN &issuer_dn, std::span< const uint8_t > serial_number) const =0
virtual std::optional< X509_Certificate > find_cert_by_pubkey_sha1(const std::vector< uint8_t > &key_hash) const =0
virtual std::vector< X509_Certificate > find_all_certs(const X509_DN &subject_dn, const std::vector< uint8_t > &key_id) const =0
virtual std::optional< X509_Certificate > find_cert(const X509_DN &subject_dn, const std::vector< uint8_t > &key_id) const
Definition certstor.cpp:38