blob: 04c8f3e13a3870500d57d0c6d31472064800b8c8 [file] [log] [blame]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef BSSL_PKI_TRUST_STORE_COLLECTION_H_
#define BSSL_PKI_TRUST_STORE_COLLECTION_H_
#include <openssl/base.h>
#include "trust_store.h"
BSSL_NAMESPACE_BEGIN
// TrustStoreCollection is an implementation of TrustStore which combines the
// results from multiple TrustStores.
//
// The order of the matches will correspond to a concatenation of matches in
// the order the stores were added.
class OPENSSL_EXPORT TrustStoreCollection : public TrustStore {
public:
TrustStoreCollection();
TrustStoreCollection(const TrustStoreCollection &) = delete;
TrustStoreCollection &operator=(const TrustStoreCollection &) = delete;
~TrustStoreCollection() override;
// Includes results from |store| in the combined output. |store| must
// outlive the TrustStoreCollection.
void AddTrustStore(TrustStore *store);
// TrustStore implementation:
void SyncGetIssuersOf(const ParsedCertificate *cert,
ParsedCertificateList *issuers) override;
CertificateTrust GetTrust(const ParsedCertificate *cert) override;
private:
std::vector<TrustStore *> stores_;
};
BSSL_NAMESPACE_END
#endif // BSSL_PKI_TRUST_STORE_COLLECTION_H_