// Copyright (c) 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_QUIC_CRYPTO_COMMON_CERT_SET_H_ #define NET_QUIC_CRYPTO_COMMON_CERT_SET_H_ #include "base/basictypes.h" #include "base/compiler_specific.h" #include "base/strings/string_piece.h" #include "net/base/net_export.h" #include "net/quic/crypto/crypto_protocol.h" namespace net { // CommonCertSets is an interface to an object that contains a number of common // certificate sets and can match against them. class NET_EXPORT_PRIVATE CommonCertSets { public: virtual ~CommonCertSets(); // GetInstanceQUIC returns the standard QUIC common certificate sets. static const CommonCertSets* GetInstanceQUIC(); // GetCommonHashes returns a StringPiece containing the hashes of common sets // supported by this object. The 64-bit hashes are concatenated in the // StringPiece. virtual base::StringPiece GetCommonHashes() const = 0; // GetCert returns a specific certificate (at index |index|) in the common // set identified by |hash|. If no such certificate is known, an empty // StringPiece is returned. virtual base::StringPiece GetCert(uint64 hash, uint32 index) const = 0; // MatchCert tries to find |cert| in one of the common certificate sets // identified by |common_set_hashes|. On success it puts the hash of the // set in |out_hash|, the index of |cert| in the set in |out_index| and // returns true. Otherwise it returns false. virtual bool MatchCert(base::StringPiece cert, base::StringPiece common_set_hashes, uint64* out_hash, uint32* out_index) const = 0; }; } // namespace net #endif // NET_QUIC_CRYPTO_COMMON_CERT_SET_H_