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 #include "net/websockets/websocket_channel.h" | 5 #include "net/websockets/websocket_channel.h" |
6 | 6 |
7 #include <limits.h> // for INT_MAX | 7 #include <limits.h> // for INT_MAX |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 | 9 |
10 #include <algorithm> | 10 #include <algorithm> |
11 #include <deque> | 11 #include <deque> |
12 #include <utility> | 12 #include <utility> |
13 #include <vector> | 13 #include <vector> |
14 | 14 |
15 #include "base/big_endian.h" | 15 #include "base/big_endian.h" |
16 #include "base/bind.h" | 16 #include "base/bind.h" |
17 #include "base/location.h" | 17 #include "base/location.h" |
18 #include "base/macros.h" | 18 #include "base/macros.h" |
19 #include "base/memory/ref_counted.h" | 19 #include "base/memory/ref_counted.h" |
20 #include "base/memory/weak_ptr.h" | 20 #include "base/memory/weak_ptr.h" |
21 #include "base/metrics/histogram_macros.h" | 21 #include "base/metrics/histogram_macros.h" |
22 #include "base/numerics/safe_conversions.h" | 22 #include "base/numerics/safe_conversions.h" |
23 #include "base/single_thread_task_runner.h" | 23 #include "base/single_thread_task_runner.h" |
24 #include "base/strings/stringprintf.h" | 24 #include "base/strings/stringprintf.h" |
25 #include "base/threading/thread_task_runner_handle.h" | 25 #include "base/threading/thread_task_runner_handle.h" |
26 #include "base/time/time.h" | 26 #include "base/time/time.h" |
27 #include "net/base/io_buffer.h" | 27 #include "net/base/io_buffer.h" |
| 28 #include "net/http/http_network_session.h" // TODO(ricea): Remove |
28 #include "net/http/http_request_headers.h" | 29 #include "net/http/http_request_headers.h" |
29 #include "net/http/http_response_headers.h" | 30 #include "net/http/http_response_headers.h" |
| 31 #include "net/http/http_transaction_factory.h" // TODO(ricea): Remove |
30 #include "net/http/http_util.h" | 32 #include "net/http/http_util.h" |
31 #include "net/log/net_log.h" | 33 #include "net/log/net_log.h" |
| 34 #include "net/url_request/url_request_context.h" // TODO(ricea): Remove |
32 #include "net/websockets/websocket_errors.h" | 35 #include "net/websockets/websocket_errors.h" |
33 #include "net/websockets/websocket_event_interface.h" | 36 #include "net/websockets/websocket_event_interface.h" |
34 #include "net/websockets/websocket_frame.h" | 37 #include "net/websockets/websocket_frame.h" |
35 #include "net/websockets/websocket_handshake_request_info.h" | 38 #include "net/websockets/websocket_handshake_request_info.h" |
36 #include "net/websockets/websocket_handshake_response_info.h" | 39 #include "net/websockets/websocket_handshake_response_info.h" |
37 #include "net/websockets/websocket_handshake_stream_create_helper.h" | 40 #include "net/websockets/websocket_handshake_stream_create_helper.h" |
38 #include "net/websockets/websocket_mux.h" | 41 #include "net/websockets/websocket_mux.h" |
39 #include "net/websockets/websocket_stream.h" | 42 #include "net/websockets/websocket_stream.h" |
40 #include "url/origin.h" | 43 #include "url/origin.h" |
41 | 44 |
(...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
320 has_received_close_frame_(false), | 323 has_received_close_frame_(false), |
321 received_close_code_(0), | 324 received_close_code_(0), |
322 state_(FRESHLY_CONSTRUCTED), | 325 state_(FRESHLY_CONSTRUCTED), |
323 notification_sender_(new HandshakeNotificationSender(this)), | 326 notification_sender_(new HandshakeNotificationSender(this)), |
324 sending_text_message_(false), | 327 sending_text_message_(false), |
325 receiving_text_message_(false), | 328 receiving_text_message_(false), |
326 expecting_to_handle_continuation_(false), | 329 expecting_to_handle_continuation_(false), |
327 initial_frame_forwarded_(false) {} | 330 initial_frame_forwarded_(false) {} |
328 | 331 |
329 WebSocketChannel::~WebSocketChannel() { | 332 WebSocketChannel::~WebSocketChannel() { |
| 333 // TODO(ricea): Remove this by October 2017. See bug 641013. |
| 334 if (stream_) { |
| 335 HttpTransactionFactory* http_transaction_factory = |
| 336 url_request_context_->http_transaction_factory(); |
| 337 if (http_transaction_factory) |
| 338 http_transaction_factory->GetSession()->DecrementActiveWebSockets(); |
| 339 } |
| 340 |
330 // The stream may hold a pointer to read_frames_, and so it needs to be | 341 // The stream may hold a pointer to read_frames_, and so it needs to be |
331 // destroyed first. | 342 // destroyed first. |
332 stream_.reset(); | 343 stream_.reset(); |
333 // The timer may have a callback pointing back to us, so stop it just in case | 344 // The timer may have a callback pointing back to us, so stop it just in case |
334 // someone decides to run the event loop from their destructor. | 345 // someone decides to run the event loop from their destructor. |
335 close_timer_.Stop(); | 346 close_timer_.Stop(); |
336 } | 347 } |
337 | 348 |
338 void WebSocketChannel::SendAddChannelRequest( | 349 void WebSocketChannel::SendAddChannelRequest( |
339 const GURL& socket_url, | 350 const GURL& socket_url, |
(...skipping 251 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
591 SetState(CONNECTING); | 602 SetState(CONNECTING); |
592 } | 603 } |
593 | 604 |
594 void WebSocketChannel::OnConnectSuccess( | 605 void WebSocketChannel::OnConnectSuccess( |
595 std::unique_ptr<WebSocketStream> stream) { | 606 std::unique_ptr<WebSocketStream> stream) { |
596 DCHECK(stream); | 607 DCHECK(stream); |
597 DCHECK_EQ(CONNECTING, state_); | 608 DCHECK_EQ(CONNECTING, state_); |
598 | 609 |
599 stream_ = std::move(stream); | 610 stream_ = std::move(stream); |
600 | 611 |
| 612 // TODO(ricea): Remove this before October 2017 |
| 613 HttpTransactionFactory* http_transaction_factory = |
| 614 url_request_context_->http_transaction_factory(); |
| 615 if (http_transaction_factory) |
| 616 http_transaction_factory->GetSession()->IncrementActiveWebSockets(); |
| 617 |
601 SetState(CONNECTED); | 618 SetState(CONNECTED); |
602 | 619 |
603 if (event_interface_->OnAddChannelResponse(stream_->GetSubProtocol(), | 620 if (event_interface_->OnAddChannelResponse(stream_->GetSubProtocol(), |
604 stream_->GetExtensions()) == | 621 stream_->GetExtensions()) == |
605 CHANNEL_DELETED) | 622 CHANNEL_DELETED) |
606 return; | 623 return; |
607 | 624 |
608 // TODO(ricea): Get flow control information from the WebSocketStream once we | 625 // TODO(ricea): Get flow control information from the WebSocketStream once we |
609 // have a multiplexing WebSocketStream. | 626 // have a multiplexing WebSocketStream. |
610 current_send_quota_ = send_quota_high_water_mark_; | 627 current_send_quota_ = send_quota_high_water_mark_; |
(...skipping 570 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1181 } | 1198 } |
1182 | 1199 |
1183 void WebSocketChannel::CloseTimeout() { | 1200 void WebSocketChannel::CloseTimeout() { |
1184 stream_->Close(); | 1201 stream_->Close(); |
1185 SetState(CLOSED); | 1202 SetState(CLOSED); |
1186 DoDropChannel(false, kWebSocketErrorAbnormalClosure, ""); | 1203 DoDropChannel(false, kWebSocketErrorAbnormalClosure, ""); |
1187 // |this| has been deleted. | 1204 // |this| has been deleted. |
1188 } | 1205 } |
1189 | 1206 |
1190 } // namespace net | 1207 } // namespace net |
OLD | NEW |