OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ | 5 #ifndef NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ |
6 #define NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ | 6 #define NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ |
7 | 7 |
8 #include <unordered_map> | 8 #include <unordered_map> |
9 | 9 |
10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
11 #include "base/strings/string_piece.h" | 11 #include "base/strings/string_piece.h" |
12 #include "net/base/net_export.h" | 12 #include "net/base/net_export.h" |
13 #include "net/cert/internal/trust_store.h" | 13 #include "net/cert/internal/trust_store.h" |
14 | 14 |
15 namespace net { | 15 namespace net { |
16 | 16 |
17 // A very simple implementation of a TrustStore, which contains a set of | 17 // A very simple implementation of a TrustStore, which contains a set of |
18 // trust anchors. | 18 // trust anchors. |
19 class NET_EXPORT TrustStoreInMemory : public TrustStore { | 19 class NET_EXPORT TrustStoreInMemory : public TrustStore { |
20 public: | 20 public: |
21 TrustStoreInMemory(); | 21 TrustStoreInMemory(); |
22 ~TrustStoreInMemory() override; | 22 ~TrustStoreInMemory() override; |
23 | 23 |
24 // Empties the trust store, resetting it to original state. | 24 // Empties the trust store, resetting it to original state. |
25 void Clear(); | 25 void Clear(); |
26 | 26 |
27 void AddTrustAnchor(scoped_refptr<TrustAnchor> anchor); | 27 void AddTrustAnchor(scoped_refptr<TrustAnchor> anchor); |
28 | 28 |
29 // TrustStore implementation: | 29 // TrustStore implementation: |
30 void FindTrustAnchorsForCert(const scoped_refptr<ParsedCertificate>& cert, | 30 void FindIssuers(const scoped_refptr<ParsedCertificate>& cert, |
31 TrustAnchors* matches) const override; | 31 TrustAnchors* trust_anchors, |
| 32 ParsedCertificateList* intermediates) const override; |
| 33 bool IsBlacklisted( |
| 34 const scoped_refptr<ParsedCertificate>& cert) const override; |
32 | 35 |
33 // Returns true if the trust store contains the given TrustAnchor instance. | 36 // Returns true if the trust store contains the given TrustAnchor instance. |
34 // Note that this considers only pointer equality and not a more | 37 // Note that this considers only pointer equality and not a more |
35 // broad notion of equivalence based on the object's content. | 38 // broad notion of equivalence based on the object's content. |
36 bool Contains(const TrustAnchor* anchor) const; | 39 bool Contains(const TrustAnchor* anchor) const; |
37 | 40 |
38 private: | 41 private: |
39 // Multimap from normalized subject -> TrustAnchor. | 42 // Multimap from normalized subject -> TrustAnchor. |
40 std::unordered_multimap<base::StringPiece, | 43 std::unordered_multimap<base::StringPiece, |
41 scoped_refptr<TrustAnchor>, | 44 scoped_refptr<TrustAnchor>, |
42 base::StringPieceHash> | 45 base::StringPieceHash> |
43 anchors_; | 46 anchors_; |
44 | 47 |
45 DISALLOW_COPY_AND_ASSIGN(TrustStoreInMemory); | 48 DISALLOW_COPY_AND_ASSIGN(TrustStoreInMemory); |
46 }; | 49 }; |
47 | 50 |
48 } // namespace net | 51 } // namespace net |
49 | 52 |
50 #endif // NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ | 53 #endif // NET_CERT_INTERNAL_TRUST_STORE_IN_MEMORY_H_ |
OLD | NEW |