| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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_QUIC_CRYPTO_CLIENT_STREAM_H_ | 5 #ifndef NET_QUIC_QUIC_CRYPTO_CLIENT_STREAM_H_ |
| 6 #define NET_QUIC_QUIC_CRYPTO_CLIENT_STREAM_H_ | 6 #define NET_QUIC_QUIC_CRYPTO_CLIENT_STREAM_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "net/quic/crypto/proof_verifier.h" | 10 #include "net/quic/crypto/proof_verifier.h" |
| 11 #include "net/quic/crypto/quic_crypto_client_config.h" | 11 #include "net/quic/crypto/quic_crypto_client_config.h" |
| 12 #include "net/quic/quic_config.h" | 12 #include "net/quic/quic_config.h" |
| 13 #include "net/quic/quic_crypto_stream.h" | 13 #include "net/quic/quic_crypto_stream.h" |
| 14 #include "net/quic/quic_session_key.h" | 14 #include "net/quic/quic_server_id.h" |
| 15 | 15 |
| 16 namespace net { | 16 namespace net { |
| 17 | 17 |
| 18 class QuicClientSessionBase; | 18 class QuicClientSessionBase; |
| 19 | 19 |
| 20 namespace test { | 20 namespace test { |
| 21 class CryptoTestUtils; | 21 class CryptoTestUtils; |
| 22 } // namespace test | 22 } // namespace test |
| 23 | 23 |
| 24 class NET_EXPORT_PRIVATE QuicCryptoClientStream : public QuicCryptoStream { | 24 class NET_EXPORT_PRIVATE QuicCryptoClientStream : public QuicCryptoStream { |
| 25 public: | 25 public: |
| 26 QuicCryptoClientStream(const QuicSessionKey& server_key, | 26 QuicCryptoClientStream(const QuicServerId& server_id, |
| 27 QuicClientSessionBase* session, | 27 QuicClientSessionBase* session, |
| 28 ProofVerifyContext* verify_context, | 28 ProofVerifyContext* verify_context, |
| 29 QuicCryptoClientConfig* crypto_config); | 29 QuicCryptoClientConfig* crypto_config); |
| 30 virtual ~QuicCryptoClientStream(); | 30 virtual ~QuicCryptoClientStream(); |
| 31 | 31 |
| 32 // CryptoFramerVisitorInterface implementation | 32 // CryptoFramerVisitorInterface implementation |
| 33 virtual void OnHandshakeMessage( | 33 virtual void OnHandshakeMessage( |
| 34 const CryptoHandshakeMessage& message) OVERRIDE; | 34 const CryptoHandshakeMessage& message) OVERRIDE; |
| 35 | 35 |
| 36 // Performs a crypto handshake with the server. Returns true if the crypto | 36 // Performs a crypto handshake with the server. Returns true if the crypto |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 90 | 90 |
| 91 State next_state_; | 91 State next_state_; |
| 92 // num_client_hellos_ contains the number of client hello messages that this | 92 // num_client_hellos_ contains the number of client hello messages that this |
| 93 // connection has sent. | 93 // connection has sent. |
| 94 int num_client_hellos_; | 94 int num_client_hellos_; |
| 95 | 95 |
| 96 QuicCryptoClientConfig* const crypto_config_; | 96 QuicCryptoClientConfig* const crypto_config_; |
| 97 | 97 |
| 98 // Client's connection nonce (4-byte timestamp + 28 random bytes) | 98 // Client's connection nonce (4-byte timestamp + 28 random bytes) |
| 99 std::string nonce_; | 99 std::string nonce_; |
| 100 // Server's (hostname, port, is_https) tuple. | 100 // Server's (hostname, port, is_https, privacy_mode) tuple. |
| 101 const QuicSessionKey server_key_; | 101 const QuicServerId server_id_; |
| 102 | 102 |
| 103 // Generation counter from QuicCryptoClientConfig's CachedState. | 103 // Generation counter from QuicCryptoClientConfig's CachedState. |
| 104 uint64 generation_counter_; | 104 uint64 generation_counter_; |
| 105 | 105 |
| 106 // proof_verify_callback_ contains the callback object that we passed to an | 106 // proof_verify_callback_ contains the callback object that we passed to an |
| 107 // asynchronous proof verification. The ProofVerifier owns this object. | 107 // asynchronous proof verification. The ProofVerifier owns this object. |
| 108 ProofVerifierCallbackImpl* proof_verify_callback_; | 108 ProofVerifierCallbackImpl* proof_verify_callback_; |
| 109 | 109 |
| 110 // These members are used to store the result of an asynchronous proof | 110 // These members are used to store the result of an asynchronous proof |
| 111 // verification. These members must not be used after | 111 // verification. These members must not be used after |
| 112 // STATE_VERIFY_PROOF_COMPLETE. | 112 // STATE_VERIFY_PROOF_COMPLETE. |
| 113 bool verify_ok_; | 113 bool verify_ok_; |
| 114 string verify_error_details_; | 114 string verify_error_details_; |
| 115 scoped_ptr<ProofVerifyDetails> verify_details_; | 115 scoped_ptr<ProofVerifyDetails> verify_details_; |
| 116 scoped_ptr<ProofVerifyContext> verify_context_; | 116 scoped_ptr<ProofVerifyContext> verify_context_; |
| 117 | 117 |
| 118 DISALLOW_COPY_AND_ASSIGN(QuicCryptoClientStream); | 118 DISALLOW_COPY_AND_ASSIGN(QuicCryptoClientStream); |
| 119 }; | 119 }; |
| 120 | 120 |
| 121 } // namespace net | 121 } // namespace net |
| 122 | 122 |
| 123 #endif // NET_QUIC_QUIC_CRYPTO_CLIENT_STREAM_H_ | 123 #endif // NET_QUIC_QUIC_CRYPTO_CLIENT_STREAM_H_ |
| OLD | NEW |