/* * Certificate Store * (C) 1999-2019 Jack Lloyd * (C) 2019 René Meusel * * Botan is released under the Simplified BSD License (see license.txt) */ #ifndef BOTAN_CERT_STORE_SYSTEM_MACOS_H_ #define BOTAN_CERT_STORE_SYSTEM_MACOS_H_ #include #include namespace Botan { class Certificate_Store_MacOS_Impl; /** * Certificate Store that is backed by the system trust store on macOS. This * opens a handle to the macOS keychain and serves certificate queries directly * from there. */ class BOTAN_PUBLIC_API(2, 10) Certificate_Store_MacOS final : public Certificate_Store { public: Certificate_Store_MacOS(); Certificate_Store_MacOS(const Certificate_Store_MacOS&) = default; Certificate_Store_MacOS(Certificate_Store_MacOS&&) = default; Certificate_Store_MacOS& operator=(const Certificate_Store_MacOS&) = default; Certificate_Store_MacOS& operator=(Certificate_Store_MacOS&&) = default; /** * @return DNs for all certificates managed by the store */ std::vector all_subjects() const override; /** * Find a certificate by Subject DN and (optionally) key identifier * @return the first certificate that matches */ std::shared_ptr find_cert( const X509_DN& subject_dn, const std::vector& key_id) const override; /** * Find all certificates with a given Subject DN. * Subject DN and even the key identifier might not be unique. */ std::vector> find_all_certs( const X509_DN& subject_dn, const std::vector& key_id) const override; /** * Find a certificate by searching for one with a matching SHA-1 hash of * public key. * @return a matching certificate or nullptr otherwise */ std::shared_ptr find_cert_by_pubkey_sha1(const std::vector& key_hash) const override; /** * @throws Botan::Not_Implemented */ std::shared_ptr find_cert_by_raw_subject_dn_sha256(const std::vector& subject_hash) const override; /** * Fetching CRLs is not supported by the keychain on macOS. This will * always return an empty list. */ std::shared_ptr find_crl_for(const X509_Certificate& subject) const override; private: std::shared_ptr m_impl; }; } #endif