blob: 57c0feafc9a970b3deae161eae1b292de884a103 [file] [log] [blame]
QUICHE teama6ef0a62019-03-07 20:34:33 -05001// 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
14namespace quic {
15
16// CommonCertSets is an interface to an object that contains a number of common
17// certificate sets and can match against them.
18class 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_