blob: ae7376563a0bfe4be50a6337480c8b37c36abe12 [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#if !defined(BSSL_PKI_SIGNATURE_VERIFY_CACHE_H_) && defined(__cplusplus)
#define BSSL_PKI_SIGNATURE_VERIFY_CACHE_H_
#include <openssl/base.h>
#include <string>
namespace bssl {
class OPENSSL_EXPORT SignatureVerifyCache {
public:
enum class Value {
kValid, // Cached as a valid signature result.
kInvalid, // Cached as an invalid signature result.
kUnknown, // Cache has no information.
};
virtual ~SignatureVerifyCache() = default;
// This interface uses a const std::string reference instead of
// std::string_view because any implementation that may reasonably want to use
// std::unordered_map or similar can run into problems with std::hash before
// C++20. (https://en.cppreference.com/w/cpp/container/unordered_map/find)
// |Store| is called to store the result of a verification for |key| as kValid
// or kInvalid after a signature check.
virtual void Store(const std::string &key, Value value) = 0;
// |Check| is called to fetch a cached value for a verification for |key|. If
// the result is kValid, or kInvalid, signature checking is skipped and the
// corresponding cached result is used. If the result is kUnknown signature
// checking is performed and the corresponding result saved using |Store|.
virtual Value Check(const std::string &key) = 0;
};
} // namespace bssl
#endif // BSSL_PKI_SIGNATURE_VERIFY_CACHE_H_ && __cplusplus