OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ | 5 #ifndef NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ |
6 #define NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ | 6 #define NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ |
7 | 7 |
8 #include <set> | 8 #include <set> |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
(...skipping 12 matching lines...) Expand all Loading... |
23 class CertVerifier; | 23 class CertVerifier; |
24 class TransportSecurityState; | 24 class TransportSecurityState; |
25 | 25 |
26 // ProofVerifyDetailsChromium is the implementation-specific information that a | 26 // ProofVerifyDetailsChromium is the implementation-specific information that a |
27 // ProofVerifierChromium returns about a certificate verification. | 27 // ProofVerifierChromium returns about a certificate verification. |
28 class NET_EXPORT_PRIVATE ProofVerifyDetailsChromium | 28 class NET_EXPORT_PRIVATE ProofVerifyDetailsChromium |
29 : public ProofVerifyDetails { | 29 : public ProofVerifyDetails { |
30 public: | 30 public: |
31 | 31 |
32 // ProofVerifyDetails implementation | 32 // ProofVerifyDetails implementation |
33 virtual ProofVerifyDetails* Clone() const override; | 33 ProofVerifyDetails* Clone() const override; |
34 | 34 |
35 CertVerifyResult cert_verify_result; | 35 CertVerifyResult cert_verify_result; |
36 | 36 |
37 // pinning_failure_log contains a message produced by | 37 // pinning_failure_log contains a message produced by |
38 // TransportSecurityState::DomainState::CheckPublicKeyPins in the event of a | 38 // TransportSecurityState::DomainState::CheckPublicKeyPins in the event of a |
39 // pinning failure. It is a (somewhat) human-readable string. | 39 // pinning failure. It is a (somewhat) human-readable string. |
40 std::string pinning_failure_log; | 40 std::string pinning_failure_log; |
41 }; | 41 }; |
42 | 42 |
43 // ProofVerifyContextChromium is the implementation-specific information that a | 43 // ProofVerifyContextChromium is the implementation-specific information that a |
44 // ProofVerifierChromium needs in order to log correctly. | 44 // ProofVerifierChromium needs in order to log correctly. |
45 struct ProofVerifyContextChromium : public ProofVerifyContext { | 45 struct ProofVerifyContextChromium : public ProofVerifyContext { |
46 public: | 46 public: |
47 explicit ProofVerifyContextChromium(const BoundNetLog& net_log) | 47 explicit ProofVerifyContextChromium(const BoundNetLog& net_log) |
48 : net_log(net_log) {} | 48 : net_log(net_log) {} |
49 | 49 |
50 BoundNetLog net_log; | 50 BoundNetLog net_log; |
51 }; | 51 }; |
52 | 52 |
53 // ProofVerifierChromium implements the QUIC ProofVerifier interface. It is | 53 // ProofVerifierChromium implements the QUIC ProofVerifier interface. It is |
54 // capable of handling multiple simultaneous requests. | 54 // capable of handling multiple simultaneous requests. |
55 class NET_EXPORT_PRIVATE ProofVerifierChromium : public ProofVerifier { | 55 class NET_EXPORT_PRIVATE ProofVerifierChromium : public ProofVerifier { |
56 public: | 56 public: |
57 ProofVerifierChromium(CertVerifier* cert_verifier, | 57 ProofVerifierChromium(CertVerifier* cert_verifier, |
58 TransportSecurityState* transport_security_state); | 58 TransportSecurityState* transport_security_state); |
59 virtual ~ProofVerifierChromium(); | 59 ~ProofVerifierChromium() override; |
60 | 60 |
61 // ProofVerifier interface | 61 // ProofVerifier interface |
62 virtual QuicAsyncStatus VerifyProof( | 62 QuicAsyncStatus VerifyProof(const std::string& hostname, |
63 const std::string& hostname, | 63 const std::string& server_config, |
64 const std::string& server_config, | 64 const std::vector<std::string>& certs, |
65 const std::vector<std::string>& certs, | 65 const std::string& signature, |
66 const std::string& signature, | 66 const ProofVerifyContext* verify_context, |
67 const ProofVerifyContext* verify_context, | 67 std::string* error_details, |
68 std::string* error_details, | 68 scoped_ptr<ProofVerifyDetails>* verify_details, |
69 scoped_ptr<ProofVerifyDetails>* verify_details, | 69 ProofVerifierCallback* callback) override; |
70 ProofVerifierCallback* callback) override; | |
71 | 70 |
72 private: | 71 private: |
73 class Job; | 72 class Job; |
74 typedef std::set<Job*> JobSet; | 73 typedef std::set<Job*> JobSet; |
75 | 74 |
76 void OnJobComplete(Job* job); | 75 void OnJobComplete(Job* job); |
77 | 76 |
78 // Set owning pointers to active jobs. | 77 // Set owning pointers to active jobs. |
79 JobSet active_jobs_; | 78 JobSet active_jobs_; |
80 | 79 |
81 // Underlying verifier used to verify certificates. | 80 // Underlying verifier used to verify certificates. |
82 CertVerifier* const cert_verifier_; | 81 CertVerifier* const cert_verifier_; |
83 | 82 |
84 TransportSecurityState* const transport_security_state_; | 83 TransportSecurityState* const transport_security_state_; |
85 | 84 |
86 DISALLOW_COPY_AND_ASSIGN(ProofVerifierChromium); | 85 DISALLOW_COPY_AND_ASSIGN(ProofVerifierChromium); |
87 }; | 86 }; |
88 | 87 |
89 } // namespace net | 88 } // namespace net |
90 | 89 |
91 #endif // NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ | 90 #endif // NET_QUIC_CRYPTO_PROOF_VERIFIER_CHROMIUM_H_ |
OLD | NEW |