Chromium Code Reviews| 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 #include "net/quic/chromium/quic_http_stream.h" | 5 #include "net/quic/chromium/quic_http_stream.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/auto_reset.h" | 9 #include "base/auto_reset.h" |
| 10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 39 dict->SetString("url", url->spec()); | 39 dict->SetString("url", url->spec()); |
| 40 return std::move(dict); | 40 return std::move(dict); |
| 41 } | 41 } |
| 42 | 42 |
| 43 } // namespace | 43 } // namespace |
| 44 | 44 |
| 45 QuicHttpStream::QuicHttpStream( | 45 QuicHttpStream::QuicHttpStream( |
| 46 const base::WeakPtr<QuicChromiumClientSession>& session) | 46 const base::WeakPtr<QuicChromiumClientSession>& session) |
| 47 : next_state_(STATE_NONE), | 47 : next_state_(STATE_NONE), |
| 48 session_(session), | 48 session_(session), |
| 49 quic_version_(session->GetQuicVersion()), | |
| 49 session_error_(OK), | 50 session_error_(OK), |
| 50 was_handshake_confirmed_(session->IsCryptoHandshakeConfirmed()), | 51 was_handshake_confirmed_(session->IsCryptoHandshakeConfirmed()), |
| 51 stream_(nullptr), | 52 stream_(nullptr), |
| 52 request_info_(nullptr), | 53 request_info_(nullptr), |
| 53 request_body_stream_(nullptr), | 54 request_body_stream_(nullptr), |
| 54 priority_(MINIMUM_PRIORITY), | 55 priority_(MINIMUM_PRIORITY), |
| 55 response_info_(nullptr), | 56 response_info_(nullptr), |
| 56 response_status_(OK), | 57 response_status_(OK), |
| 57 response_headers_received_(false), | 58 response_headers_received_(false), |
| 58 headers_bytes_received_(0), | 59 headers_bytes_received_(0), |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 120 | 121 |
| 121 DCHECK_EQ(STATE_HANDLE_PROMISE_COMPLETE, next_state_); | 122 DCHECK_EQ(STATE_HANDLE_PROMISE_COMPLETE, next_state_); |
| 122 if (!stream) { | 123 if (!stream) { |
| 123 // rendezvous has failed so proceed as with a non-push request. | 124 // rendezvous has failed so proceed as with a non-push request. |
| 124 next_state_ = STATE_REQUEST_STREAM; | 125 next_state_ = STATE_REQUEST_STREAM; |
| 125 } | 126 } |
| 126 | 127 |
| 127 OnIOComplete(OK); | 128 OnIOComplete(OK); |
| 128 } | 129 } |
| 129 | 130 |
| 131 HttpResponseInfo::ConnectionInfo QuicHttpStream::ConnectionInfoFromQuicVersion( | |
| 132 QuicVersion quic_version) { | |
| 133 switch (quic_version) { | |
| 134 case QUIC_VERSION_UNSUPPORTED: | |
| 135 return HttpResponseInfo::CONNECTION_INFO_QUIC_UNKNOWN_VERSION; | |
| 136 case QUIC_VERSION_32: | |
| 137 return HttpResponseInfo::CONNECTION_INFO_QUIC_32; | |
| 138 case QUIC_VERSION_33: | |
| 139 return HttpResponseInfo::CONNECTION_INFO_QUIC_33; | |
| 140 case QUIC_VERSION_34: | |
| 141 return HttpResponseInfo::CONNECTION_INFO_QUIC_34; | |
| 142 case QUIC_VERSION_35: | |
| 143 return HttpResponseInfo::CONNECTION_INFO_QUIC_35; | |
| 144 case QUIC_VERSION_36: | |
| 145 return HttpResponseInfo::CONNECTION_INFO_QUIC_36; | |
| 146 } | |
| 147 NOTREACHED(); | |
| 148 return HttpResponseInfo::CONNECTION_INFO_QUIC_UNKNOWN_VERSION; | |
| 149 } | |
| 150 | |
| 130 int QuicHttpStream::InitializeStream(const HttpRequestInfo* request_info, | 151 int QuicHttpStream::InitializeStream(const HttpRequestInfo* request_info, |
| 131 RequestPriority priority, | 152 RequestPriority priority, |
| 132 const NetLogWithSource& stream_net_log, | 153 const NetLogWithSource& stream_net_log, |
| 133 const CompletionCallback& callback) { | 154 const CompletionCallback& callback) { |
| 134 CHECK(callback_.is_null()); | 155 CHECK(callback_.is_null()); |
| 135 DCHECK(!stream_); | 156 DCHECK(!stream_); |
| 136 if (!session_) | 157 if (!session_) |
| 137 return was_handshake_confirmed_ ? ERR_CONNECTION_CLOSED | 158 return was_handshake_confirmed_ ? ERR_CONNECTION_CLOSED |
| 138 : ERR_QUIC_HANDSHAKE_FAILED; | 159 : ERR_QUIC_HANDSHAKE_FAILED; |
| 139 | 160 |
| (...skipping 283 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 423 return session_->GetTokenBindingSignature(key, tb_type, out); | 444 return session_->GetTokenBindingSignature(key, tb_type, out); |
| 424 } | 445 } |
| 425 | 446 |
| 426 void QuicHttpStream::Drain(HttpNetworkSession* session) { | 447 void QuicHttpStream::Drain(HttpNetworkSession* session) { |
| 427 NOTREACHED(); | 448 NOTREACHED(); |
| 428 Close(false); | 449 Close(false); |
| 429 delete this; | 450 delete this; |
| 430 } | 451 } |
| 431 | 452 |
| 432 void QuicHttpStream::PopulateNetErrorDetails(NetErrorDetails* details) { | 453 void QuicHttpStream::PopulateNetErrorDetails(NetErrorDetails* details) { |
| 433 details->connection_info = HttpResponseInfo::CONNECTION_INFO_QUIC; | 454 details->connection_info = ConnectionInfoFromQuicVersion(quic_version_); |
| 434 if (was_handshake_confirmed_) | 455 if (was_handshake_confirmed_) |
| 435 details->quic_connection_error = quic_connection_error_; | 456 details->quic_connection_error = quic_connection_error_; |
| 436 if (session_) { | 457 if (session_) { |
| 437 session_->PopulateNetErrorDetails(details); | 458 session_->PopulateNetErrorDetails(details); |
| 438 } else { | 459 } else { |
| 439 details->quic_port_migration_detected = port_migration_detected_; | 460 details->quic_port_migration_detected = port_migration_detected_; |
| 440 } | 461 } |
| 441 } | 462 } |
| 442 | 463 |
| 443 void QuicHttpStream::SetPriority(RequestPriority priority) { | 464 void QuicHttpStream::SetPriority(RequestPriority priority) { |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 524 was_handshake_confirmed_ = true; | 545 was_handshake_confirmed_ = true; |
| 525 if (next_state_ == STATE_WAIT_FOR_CONFIRMATION_COMPLETE) { | 546 if (next_state_ == STATE_WAIT_FOR_CONFIRMATION_COMPLETE) { |
| 526 int rv = DoLoop(OK); | 547 int rv = DoLoop(OK); |
| 527 | 548 |
| 528 if (rv != ERR_IO_PENDING && !callback_.is_null()) { | 549 if (rv != ERR_IO_PENDING && !callback_.is_null()) { |
| 529 DoCallback(rv); | 550 DoCallback(rv); |
| 530 } | 551 } |
| 531 } | 552 } |
| 532 } | 553 } |
| 533 | 554 |
| 555 void QuicHttpStream::OnSuccessfulVersionNegotiation( | |
| 556 const QuicVersion& version) { | |
| 557 quic_version_ = version; | |
| 558 } | |
| 559 | |
| 534 void QuicHttpStream::OnSessionClosed(int error, bool port_migration_detected) { | 560 void QuicHttpStream::OnSessionClosed(int error, bool port_migration_detected) { |
| 535 Close(false); | 561 Close(false); |
| 536 session_error_ = error; | 562 session_error_ = error; |
| 537 port_migration_detected_ = port_migration_detected; | 563 port_migration_detected_ = port_migration_detected; |
| 538 session_.reset(); | 564 session_.reset(); |
| 539 } | 565 } |
| 540 | 566 |
| 541 void QuicHttpStream::OnIOComplete(int rv) { | 567 void QuicHttpStream::OnIOComplete(int rv) { |
| 542 rv = DoLoop(rv); | 568 rv = DoLoop(rv); |
| 543 | 569 |
| (...skipping 237 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 781 } | 807 } |
| 782 | 808 |
| 783 int QuicHttpStream::ProcessResponseHeaders(const SpdyHeaderBlock& headers) { | 809 int QuicHttpStream::ProcessResponseHeaders(const SpdyHeaderBlock& headers) { |
| 784 if (!SpdyHeadersToHttpResponse(headers, response_info_)) { | 810 if (!SpdyHeadersToHttpResponse(headers, response_info_)) { |
| 785 DLOG(WARNING) << "Invalid headers"; | 811 DLOG(WARNING) << "Invalid headers"; |
| 786 return ERR_QUIC_PROTOCOL_ERROR; | 812 return ERR_QUIC_PROTOCOL_ERROR; |
| 787 } | 813 } |
| 788 // Put the peer's IP address and port into the response. | 814 // Put the peer's IP address and port into the response. |
| 789 IPEndPoint address = session_->peer_address(); | 815 IPEndPoint address = session_->peer_address(); |
| 790 response_info_->socket_address = HostPortPair::FromIPEndPoint(address); | 816 response_info_->socket_address = HostPortPair::FromIPEndPoint(address); |
| 791 response_info_->connection_info = HttpResponseInfo::CONNECTION_INFO_QUIC; | 817 response_info_->connection_info = |
| 818 ConnectionInfoFromQuicVersion(quic_version_); | |
| 792 response_info_->vary_data.Init(*request_info_, | 819 response_info_->vary_data.Init(*request_info_, |
| 793 *response_info_->headers.get()); | 820 *response_info_->headers.get()); |
| 794 response_info_->was_alpn_negotiated = true; | 821 response_info_->was_alpn_negotiated = true; |
| 795 response_info_->alpn_negotiated_protocol = "quic/1+spdy/3"; | 822 response_info_->alpn_negotiated_protocol = |
|
sunjian
2016/11/03 18:55:03
Does that mean alpn_negotiated_protocol will alway
Bence
2016/11/08 17:58:56
Discussed offline. We'll work together on assessi
| |
| 823 HttpResponseInfo::ConnectionInfoToString(response_info_->connection_info); | |
| 796 response_info_->response_time = base::Time::Now(); | 824 response_info_->response_time = base::Time::Now(); |
| 797 response_info_->request_time = request_time_; | 825 response_info_->request_time = request_time_; |
| 798 response_headers_received_ = true; | 826 response_headers_received_ = true; |
| 799 | 827 |
| 800 // Populate |connect_timing_| when response headers are received. This should | 828 // Populate |connect_timing_| when response headers are received. This should |
| 801 // take care of 0-RTT where request is sent before handshake is confirmed. | 829 // take care of 0-RTT where request is sent before handshake is confirmed. |
| 802 connect_timing_ = session_->GetConnectTiming(); | 830 connect_timing_ = session_->GetConnectTiming(); |
| 803 return OK; | 831 return OK; |
| 804 } | 832 } |
| 805 | 833 |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 832 closed_is_first_stream_ = stream_->IsFirstStream(); | 860 closed_is_first_stream_ = stream_->IsFirstStream(); |
| 833 stream_ = nullptr; | 861 stream_ = nullptr; |
| 834 | 862 |
| 835 // If |request_body_stream_| is non-NULL, Reset it, to abort any in progress | 863 // If |request_body_stream_| is non-NULL, Reset it, to abort any in progress |
| 836 // read. | 864 // read. |
| 837 if (request_body_stream_) | 865 if (request_body_stream_) |
| 838 request_body_stream_->Reset(); | 866 request_body_stream_->Reset(); |
| 839 } | 867 } |
| 840 | 868 |
| 841 } // namespace net | 869 } // namespace net |
| OLD | NEW |