| 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 // A client specific QuicSession subclass. This class owns the underlying | 5 // A client specific QuicSession subclass. This class owns the underlying |
| 6 // QuicConnection and QuicConnectionHelper objects. The connection stores | 6 // QuicConnection and QuicConnectionHelper objects. The connection stores |
| 7 // a non-owning pointer to the helper so this session needs to ensure that | 7 // a non-owning pointer to the helper so this session needs to ensure that |
| 8 // the helper outlives the connection. | 8 // the helper outlives the connection. |
| 9 | 9 |
| 10 #ifndef NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ | 10 #ifndef NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ |
| (...skipping 174 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 185 // Gets the SSL connection information. | 185 // Gets the SSL connection information. |
| 186 bool GetSSLInfo(SSLInfo* ssl_info) const; | 186 bool GetSSLInfo(SSLInfo* ssl_info) const; |
| 187 | 187 |
| 188 // Performs a crypto handshake with the server. | 188 // Performs a crypto handshake with the server. |
| 189 int CryptoConnect(bool require_confirmation, | 189 int CryptoConnect(bool require_confirmation, |
| 190 const CompletionCallback& callback); | 190 const CompletionCallback& callback); |
| 191 | 191 |
| 192 // Resumes a crypto handshake with the server after a timeout. | 192 // Resumes a crypto handshake with the server after a timeout. |
| 193 int ResumeCryptoConnect(const CompletionCallback& callback); | 193 int ResumeCryptoConnect(const CompletionCallback& callback); |
| 194 | 194 |
| 195 // Causes the QuicConnectionHelper to start reading from the socket | 195 // Causes the QuicConnectionHelper to start reading from all sockets |
| 196 // and passing the data along to the QuicConnection. | 196 // and passing the data along to the QuicConnection. |
| 197 void StartReading(); | 197 void StartReading(); |
| 198 | 198 |
| 199 // Close the session because of |error| and notifies the factory | 199 // Close the session because of |error| and notifies the factory |
| 200 // that this session has been closed, which will delete the session. | 200 // that this session has been closed, which will delete the session. |
| 201 void CloseSessionOnError(int error, QuicErrorCode quic_error); | 201 void CloseSessionOnError(int error, QuicErrorCode quic_error); |
| 202 | 202 |
| 203 // Close the session because of |error| and notifies the factory later that | 203 // Close the session because of |error| and notifies the factory later that |
| 204 // this session has been closed, which will delete the session. | 204 // this session has been closed, which will delete the session. |
| 205 void CloseSessionOnErrorAndNotifyFactoryLater(int error, | 205 void CloseSessionOnErrorAndNotifyFactoryLater(int error, |
| (...skipping 12 matching lines...) Expand all Loading... |
| 218 | 218 |
| 219 // Returns true if |hostname| may be pooled onto this session. If this | 219 // Returns true if |hostname| may be pooled onto this session. If this |
| 220 // is a secure QUIC session, then |hostname| must match the certificate | 220 // is a secure QUIC session, then |hostname| must match the certificate |
| 221 // presented during the handshake. | 221 // presented during the handshake. |
| 222 bool CanPool(const std::string& hostname, PrivacyMode privacy_mode) const; | 222 bool CanPool(const std::string& hostname, PrivacyMode privacy_mode) const; |
| 223 | 223 |
| 224 const QuicServerId& server_id() const { return server_id_; } | 224 const QuicServerId& server_id() const { return server_id_; } |
| 225 | 225 |
| 226 QuicDisabledReason disabled_reason() const { return disabled_reason_; } | 226 QuicDisabledReason disabled_reason() const { return disabled_reason_; } |
| 227 | 227 |
| 228 // Migrates session onto new socket, i.e., starts reading from |socket| |
| 229 // in addition to any previous sockets, and sets |writer| to be the new |
| 230 // default writer. Returns true if socket was successfully added to the |
| 231 // session and the session was successfully migrated to using the new socket. |
| 232 // Returns false if number of migrations exceeds kMaxReadersPerQuicSession. |
| 233 // Takes ownership of |socket|, |reader|, and |writer|. |
| 234 bool MigrateToSocket(scoped_ptr<DatagramClientSocket> socket, |
| 235 scoped_ptr<QuicPacketReader> reader, |
| 236 scoped_ptr<QuicPacketWriter> writer); |
| 237 |
| 238 // Returns current default socket. This is the socket over which all |
| 239 // QUIC packets are sent. This default socket can change, so do not store the |
| 240 // returned socket. |
| 241 const DatagramClientSocket* GetDefaultSocket() const; |
| 242 |
| 228 protected: | 243 protected: |
| 229 // QuicSession methods: | 244 // QuicSession methods: |
| 230 QuicSpdyStream* CreateIncomingDynamicStream(QuicStreamId id) override; | 245 QuicSpdyStream* CreateIncomingDynamicStream(QuicStreamId id) override; |
| 231 | 246 |
| 232 private: | 247 private: |
| 233 friend class test::QuicChromiumClientSessionPeer; | 248 friend class test::QuicChromiumClientSessionPeer; |
| 234 | 249 |
| 235 typedef std::set<Observer*> ObserverSet; | 250 typedef std::set<Observer*> ObserverSet; |
| 236 typedef std::list<StreamRequest*> StreamRequestQueue; | 251 typedef std::list<StreamRequest*> StreamRequestQueue; |
| 237 | 252 |
| (...skipping 29 matching lines...) Expand all Loading... |
| 267 // Notifies the factory that this session has been closed which will | 282 // Notifies the factory that this session has been closed which will |
| 268 // delete |this|. | 283 // delete |this|. |
| 269 void NotifyFactoryOfSessionClosed(); | 284 void NotifyFactoryOfSessionClosed(); |
| 270 | 285 |
| 271 void OnConnectTimeout(); | 286 void OnConnectTimeout(); |
| 272 | 287 |
| 273 QuicServerId server_id_; | 288 QuicServerId server_id_; |
| 274 bool require_confirmation_; | 289 bool require_confirmation_; |
| 275 scoped_ptr<QuicCryptoClientStream> crypto_stream_; | 290 scoped_ptr<QuicCryptoClientStream> crypto_stream_; |
| 276 QuicStreamFactory* stream_factory_; | 291 QuicStreamFactory* stream_factory_; |
| 277 scoped_ptr<DatagramClientSocket> socket_; | 292 std::vector<scoped_ptr<DatagramClientSocket>> sockets_; |
| 278 TransportSecurityState* transport_security_state_; | 293 TransportSecurityState* transport_security_state_; |
| 279 scoped_ptr<QuicServerInfo> server_info_; | 294 scoped_ptr<QuicServerInfo> server_info_; |
| 280 scoped_ptr<CertVerifyResult> cert_verify_result_; | 295 scoped_ptr<CertVerifyResult> cert_verify_result_; |
| 281 scoped_ptr<ct::CTVerifyResult> ct_verify_result_; | 296 scoped_ptr<ct::CTVerifyResult> ct_verify_result_; |
| 282 std::string pinning_failure_log_; | 297 std::string pinning_failure_log_; |
| 283 ObserverSet observers_; | 298 ObserverSet observers_; |
| 284 StreamRequestQueue stream_requests_; | 299 StreamRequestQueue stream_requests_; |
| 285 CompletionCallback callback_; | 300 CompletionCallback callback_; |
| 286 size_t num_total_streams_; | 301 size_t num_total_streams_; |
| 287 base::TaskRunner* task_runner_; | 302 base::TaskRunner* task_runner_; |
| 288 BoundNetLog net_log_; | 303 BoundNetLog net_log_; |
| 289 QuicPacketReader packet_reader_; | 304 std::vector<scoped_ptr<QuicPacketReader>> packet_readers_; |
| 290 base::TimeTicks dns_resolution_end_time_; | 305 base::TimeTicks dns_resolution_end_time_; |
| 291 base::TimeTicks handshake_start_; // Time the handshake was started. | 306 base::TimeTicks handshake_start_; // Time the handshake was started. |
| 292 scoped_ptr<QuicConnectionLogger> logger_; | 307 scoped_ptr<QuicConnectionLogger> logger_; |
| 293 // True when the session is going away, and streams may no longer be created | 308 // True when the session is going away, and streams may no longer be created |
| 294 // on this session. Existing stream will continue to be processed. | 309 // on this session. Existing stream will continue to be processed. |
| 295 bool going_away_; | 310 bool going_away_; |
| 296 QuicDisabledReason disabled_reason_; | 311 QuicDisabledReason disabled_reason_; |
| 297 base::WeakPtrFactory<QuicChromiumClientSession> weak_factory_; | 312 base::WeakPtrFactory<QuicChromiumClientSession> weak_factory_; |
| 298 | 313 |
| 299 DISALLOW_COPY_AND_ASSIGN(QuicChromiumClientSession); | 314 DISALLOW_COPY_AND_ASSIGN(QuicChromiumClientSession); |
| 300 }; | 315 }; |
| 301 | 316 |
| 302 } // namespace net | 317 } // namespace net |
| 303 | 318 |
| 304 #endif // NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ | 319 #endif // NET_QUIC_QUIC_CHROMIUM_CLIENT_SESSION_H_ |
| OLD | NEW |