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 QuicSession, which demuxes a single connection to individual streams. | 5 // A QuicSession, which demuxes a single connection to individual streams. |
6 | 6 |
7 #ifndef NET_QUIC_QUIC_SESSION_H_ | 7 #ifndef NET_QUIC_QUIC_SESSION_H_ |
8 #define NET_QUIC_QUIC_SESSION_H_ | 8 #define NET_QUIC_QUIC_SESSION_H_ |
9 | 9 |
10 #include <vector> | 10 #include <vector> |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
47 // connection should resend any packets that were sent under | 47 // connection should resend any packets that were sent under |
48 // ENCRYPTION_INITIAL. (Client only.) | 48 // ENCRYPTION_INITIAL. (Client only.) |
49 ENCRYPTION_REESTABLISHED, | 49 ENCRYPTION_REESTABLISHED, |
50 // HANDSHAKE_CONFIRMED, in a client, indicates the the server has accepted | 50 // HANDSHAKE_CONFIRMED, in a client, indicates the the server has accepted |
51 // our handshake. In a server it indicates that a full, valid client hello | 51 // our handshake. In a server it indicates that a full, valid client hello |
52 // has been received. (Client and server.) | 52 // has been received. (Client and server.) |
53 HANDSHAKE_CONFIRMED, | 53 HANDSHAKE_CONFIRMED, |
54 }; | 54 }; |
55 | 55 |
56 QuicSession(QuicConnection* connection, | 56 QuicSession(QuicConnection* connection, |
57 uint32 max_flow_control_receive_window_bytes, | |
58 const QuicConfig& config); | 57 const QuicConfig& config); |
wtc
2014/06/16 19:35:56
Nit: this may fit on the previous line now.
ramant (doing other things)
2014/06/16 21:13:53
Done.
| |
59 | 58 |
60 virtual ~QuicSession(); | 59 virtual ~QuicSession(); |
61 | 60 |
62 // QuicConnectionVisitorInterface methods: | 61 // QuicConnectionVisitorInterface methods: |
63 virtual void OnStreamFrames( | 62 virtual void OnStreamFrames( |
64 const std::vector<QuicStreamFrame>& frames) OVERRIDE; | 63 const std::vector<QuicStreamFrame>& frames) OVERRIDE; |
65 virtual void OnRstStream(const QuicRstStreamFrame& frame) OVERRIDE; | 64 virtual void OnRstStream(const QuicRstStreamFrame& frame) OVERRIDE; |
66 virtual void OnGoAway(const QuicGoAwayFrame& frame) OVERRIDE; | 65 virtual void OnGoAway(const QuicGoAwayFrame& frame) OVERRIDE; |
67 virtual void OnWindowUpdateFrames( | 66 virtual void OnWindowUpdateFrames( |
68 const std::vector<QuicWindowUpdateFrame>& frames) OVERRIDE; | 67 const std::vector<QuicWindowUpdateFrame>& frames) OVERRIDE; |
(...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
198 return goaway_sent_; | 197 return goaway_sent_; |
199 } | 198 } |
200 | 199 |
201 // Gets the SSL connection information. | 200 // Gets the SSL connection information. |
202 virtual bool GetSSLInfo(SSLInfo* ssl_info) const; | 201 virtual bool GetSSLInfo(SSLInfo* ssl_info) const; |
203 | 202 |
204 QuicErrorCode error() const { return error_; } | 203 QuicErrorCode error() const { return error_; } |
205 | 204 |
206 bool is_server() const { return connection_->is_server(); } | 205 bool is_server() const { return connection_->is_server(); } |
207 | 206 |
208 uint32 max_flow_control_receive_window_bytes() { | |
209 return max_flow_control_receive_window_bytes_; | |
210 } | |
211 | |
212 QuicFlowController* flow_controller() { return flow_controller_.get(); } | 207 QuicFlowController* flow_controller() { return flow_controller_.get(); } |
213 | 208 |
214 protected: | 209 protected: |
215 typedef base::hash_map<QuicStreamId, QuicDataStream*> DataStreamMap; | 210 typedef base::hash_map<QuicStreamId, QuicDataStream*> DataStreamMap; |
216 | 211 |
217 // Creates a new stream, owned by the caller, to handle a peer-initiated | 212 // Creates a new stream, owned by the caller, to handle a peer-initiated |
218 // stream. Returns NULL and does error handling if the stream can not be | 213 // stream. Returns NULL and does error handling if the stream can not be |
219 // created. | 214 // created. |
220 virtual QuicDataStream* CreateIncomingDataStream(QuicStreamId id) = 0; | 215 virtual QuicDataStream* CreateIncomingDataStream(QuicStreamId id) = 0; |
221 | 216 |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
266 // then the stream has been reset by this endpoint, not by the peer. | 261 // then the stream has been reset by this endpoint, not by the peer. |
267 void CloseStreamInner(QuicStreamId stream_id, bool locally_reset); | 262 void CloseStreamInner(QuicStreamId stream_id, bool locally_reset); |
268 | 263 |
269 // When a stream is closed locally, it may not yet know how many bytes the | 264 // When a stream is closed locally, it may not yet know how many bytes the |
270 // peer sent on that stream. | 265 // peer sent on that stream. |
271 // When this data arrives (via stream frame w. FIN, or RST) this method | 266 // When this data arrives (via stream frame w. FIN, or RST) this method |
272 // is called, and correctly updates the connection level flow controller. | 267 // is called, and correctly updates the connection level flow controller. |
273 void UpdateFlowControlOnFinalReceivedByteOffset( | 268 void UpdateFlowControlOnFinalReceivedByteOffset( |
274 QuicStreamId id, QuicStreamOffset final_byte_offset); | 269 QuicStreamId id, QuicStreamOffset final_byte_offset); |
275 | 270 |
271 // Called in OnConfigNegotiated when we receive a new stream level flow | |
272 // control window in a negotiated config. Closes the connection if invalid. | |
273 void OnNewStreamFlowControlWindow(uint32 new_window); | |
274 | |
275 // Called in OnConfigNegotiated when we receive a new session level flow | |
276 // control window in a negotiated config. Closes the connection if invalid. | |
277 void OnNewSessionFlowControlWindow(uint32 new_window); | |
278 | |
276 // Keep track of highest received byte offset of locally closed streams, while | 279 // Keep track of highest received byte offset of locally closed streams, while |
277 // waiting for a definitive final highest offset from the peer. | 280 // waiting for a definitive final highest offset from the peer. |
278 std::map<QuicStreamId, QuicStreamOffset> | 281 std::map<QuicStreamId, QuicStreamOffset> |
279 locally_closed_streams_highest_offset_; | 282 locally_closed_streams_highest_offset_; |
280 | 283 |
281 scoped_ptr<QuicConnection> connection_; | 284 scoped_ptr<QuicConnection> connection_; |
282 | 285 |
283 scoped_ptr<QuicHeadersStream> headers_stream_; | 286 scoped_ptr<QuicHeadersStream> headers_stream_; |
284 | 287 |
285 // A shim to stand between the connection and the session, to handle stream | 288 // A shim to stand between the connection and the session, to handle stream |
(...skipping 27 matching lines...) Expand all Loading... | |
313 bool goaway_received_; | 316 bool goaway_received_; |
314 // Whether a GoAway has been sent. | 317 // Whether a GoAway has been sent. |
315 bool goaway_sent_; | 318 bool goaway_sent_; |
316 | 319 |
317 // Indicate if there is pending data for the crypto stream. | 320 // Indicate if there is pending data for the crypto stream. |
318 bool has_pending_handshake_; | 321 bool has_pending_handshake_; |
319 | 322 |
320 // Used for session level flow control. | 323 // Used for session level flow control. |
321 scoped_ptr<QuicFlowController> flow_controller_; | 324 scoped_ptr<QuicFlowController> flow_controller_; |
322 | 325 |
323 // Initial flow control receive window size for new streams. | |
324 uint32 max_flow_control_receive_window_bytes_; | |
325 | |
326 DISALLOW_COPY_AND_ASSIGN(QuicSession); | 326 DISALLOW_COPY_AND_ASSIGN(QuicSession); |
327 }; | 327 }; |
328 | 328 |
329 } // namespace net | 329 } // namespace net |
330 | 330 |
331 #endif // NET_QUIC_QUIC_SESSION_H_ | 331 #endif // NET_QUIC_QUIC_SESSION_H_ |
OLD | NEW |