blob: af211ad79ffed9732540e4c35d96ec06edce04c7 [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"
dmcardle904ef182019-12-13 08:34:33 -080012#include "net/third_party/quiche/src/common/platform/api/quiche_string_piece.h"
QUICHE teama6ef0a62019-03-07 20:34:33 -050013
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
dmcardle904ef182019-12-13 08:34:33 -080025 // GetCommonHashes returns a quiche::QuicheStringPiece containing the hashes
26 // of common sets supported by this object. The 64-bit hashes are concatenated
27 // in the quiche::QuicheStringPiece.
28 virtual quiche::QuicheStringPiece GetCommonHashes() const = 0;
QUICHE teama6ef0a62019-03-07 20:34:33 -050029
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
dmcardle904ef182019-12-13 08:34:33 -080032 // quiche::QuicheStringPiece is returned.
33 virtual quiche::QuicheStringPiece GetCert(uint64_t hash,
34 uint32_t index) const = 0;
QUICHE teama6ef0a62019-03-07 20:34:33 -050035
36 // MatchCert tries to find |cert| in one of the common certificate sets
37 // identified by |common_set_hashes|. On success it puts the hash of the
38 // set in |out_hash|, the index of |cert| in the set in |out_index| and
39 // returns true. Otherwise it returns false.
dmcardle904ef182019-12-13 08:34:33 -080040 virtual bool MatchCert(quiche::QuicheStringPiece cert,
41 quiche::QuicheStringPiece common_set_hashes,
QUICHE teama6ef0a62019-03-07 20:34:33 -050042 uint64_t* out_hash,
43 uint32_t* out_index) const = 0;
44};
45
46} // namespace quic
47
48#endif // QUICHE_QUIC_CORE_CRYPTO_COMMON_CERT_SET_H_