QUICHE team | a6ef0a6 | 2019-03-07 20:34:33 -0500 | [diff] [blame] | 1 | // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #ifndef QUICHE_QUIC_CORE_CRYPTO_COMMON_CERT_SET_H_ |
| 6 | #define QUICHE_QUIC_CORE_CRYPTO_COMMON_CERT_SET_H_ |
| 7 | |
| 8 | #include <cstdint> |
| 9 | |
| 10 | #include "net/third_party/quiche/src/quic/core/crypto/crypto_protocol.h" |
| 11 | #include "net/third_party/quiche/src/quic/platform/api/quic_export.h" |
| 12 | #include "net/third_party/quiche/src/quic/platform/api/quic_string_piece.h" |
| 13 | |
| 14 | namespace quic { |
| 15 | |
| 16 | // CommonCertSets is an interface to an object that contains a number of common |
| 17 | // certificate sets and can match against them. |
| 18 | class QUIC_EXPORT_PRIVATE CommonCertSets { |
| 19 | public: |
| 20 | virtual ~CommonCertSets(); |
| 21 | |
| 22 | // GetInstanceQUIC returns the standard QUIC common certificate sets. |
| 23 | static const CommonCertSets* GetInstanceQUIC(); |
| 24 | |
| 25 | // GetCommonHashes returns a QuicStringPiece containing the hashes of common |
| 26 | // sets supported by this object. The 64-bit hashes are concatenated in the |
| 27 | // QuicStringPiece. |
| 28 | virtual QuicStringPiece GetCommonHashes() const = 0; |
| 29 | |
| 30 | // GetCert returns a specific certificate (at index |index|) in the common |
| 31 | // set identified by |hash|. If no such certificate is known, an empty |
| 32 | // QuicStringPiece is returned. |
| 33 | virtual QuicStringPiece GetCert(uint64_t hash, uint32_t index) const = 0; |
| 34 | |
| 35 | // MatchCert tries to find |cert| in one of the common certificate sets |
| 36 | // identified by |common_set_hashes|. On success it puts the hash of the |
| 37 | // set in |out_hash|, the index of |cert| in the set in |out_index| and |
| 38 | // returns true. Otherwise it returns false. |
| 39 | virtual bool MatchCert(QuicStringPiece cert, |
| 40 | QuicStringPiece common_set_hashes, |
| 41 | uint64_t* out_hash, |
| 42 | uint32_t* out_index) const = 0; |
| 43 | }; |
| 44 | |
| 45 | } // namespace quic |
| 46 | |
| 47 | #endif // QUICHE_QUIC_CORE_CRYPTO_COMMON_CERT_SET_H_ |