| 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/tools/quic/quic_spdy_client_stream.h" | 5 #include "net/tools/quic/quic_spdy_client_stream.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
| 10 #include "net/quic/quic_alarm.h" | 10 #include "net/quic/quic_alarm.h" |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 48 DCHECK(headers_decompressed()); | 48 DCHECK(headers_decompressed()); |
| 49 header_bytes_read_ += frame_len; | 49 header_bytes_read_ += frame_len; |
| 50 if (!SpdyUtils::ParseHeaders(decompressed_headers().data(), | 50 if (!SpdyUtils::ParseHeaders(decompressed_headers().data(), |
| 51 decompressed_headers().length(), | 51 decompressed_headers().length(), |
| 52 &content_length_, &response_headers_)) { | 52 &content_length_, &response_headers_)) { |
| 53 DLOG(ERROR) << "Failed to parse headers: " << decompressed_headers(); | 53 DLOG(ERROR) << "Failed to parse headers: " << decompressed_headers(); |
| 54 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 54 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 55 return; | 55 return; |
| 56 } | 56 } |
| 57 | 57 |
| 58 if (!ParseHeaderStatusCode(&response_headers_, &response_code_)) { | 58 if (!ParseHeaderStatusCode(response_headers_, &response_code_)) { |
| 59 DLOG(ERROR) << "Received invalid response code: " | 59 DLOG(ERROR) << "Received invalid response code: " |
| 60 << response_headers_[":status"].as_string(); | 60 << response_headers_[":status"].as_string(); |
| 61 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 61 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 62 return; | 62 return; |
| 63 } | 63 } |
| 64 | 64 |
| 65 MarkHeadersConsumed(decompressed_headers().length()); | 65 MarkHeadersConsumed(decompressed_headers().length()); |
| 66 DVLOG(1) << "headers complete for stream " << id(); | 66 DVLOG(1) << "headers complete for stream " << id(); |
| 67 | 67 |
| 68 session_->OnInitialHeadersComplete(id(), response_headers_); | 68 session_->OnInitialHeadersComplete(id(), response_headers_); |
| 69 } | 69 } |
| 70 | 70 |
| 71 void QuicSpdyClientStream::OnInitialHeadersComplete( | 71 void QuicSpdyClientStream::OnInitialHeadersComplete( |
| 72 bool fin, | 72 bool fin, |
| 73 size_t frame_len, | 73 size_t frame_len, |
| 74 const QuicHeaderList& header_list) { | 74 const QuicHeaderList& header_list) { |
| 75 QuicSpdyStream::OnInitialHeadersComplete(fin, frame_len, header_list); | 75 QuicSpdyStream::OnInitialHeadersComplete(fin, frame_len, header_list); |
| 76 | 76 |
| 77 DCHECK(headers_decompressed()); | 77 DCHECK(headers_decompressed()); |
| 78 header_bytes_read_ += frame_len; | 78 header_bytes_read_ += frame_len; |
| 79 if (!SpdyUtils::CopyAndValidateHeaders(header_list, &content_length_, | 79 if (!SpdyUtils::CopyAndValidateHeaders(header_list, &content_length_, |
| 80 &response_headers_)) { | 80 &response_headers_)) { |
| 81 DLOG(ERROR) << "Failed to parse header list: " << header_list.DebugString(); | 81 DLOG(ERROR) << "Failed to parse header list: " << header_list.DebugString(); |
| 82 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 82 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 83 return; | 83 return; |
| 84 } | 84 } |
| 85 | 85 |
| 86 if (!ParseHeaderStatusCode(&response_headers_, &response_code_)) { | 86 if (!ParseHeaderStatusCode(response_headers_, &response_code_)) { |
| 87 DLOG(ERROR) << "Received invalid response code: " | 87 DLOG(ERROR) << "Received invalid response code: " |
| 88 << response_headers_[":status"].as_string(); | 88 << response_headers_[":status"].as_string(); |
| 89 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 89 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 90 return; | 90 return; |
| 91 } | 91 } |
| 92 | 92 |
| 93 ConsumeHeaderList(); | 93 ConsumeHeaderList(); |
| 94 DVLOG(1) << "headers complete for stream " << id(); | 94 DVLOG(1) << "headers complete for stream " << id(); |
| 95 | 95 |
| 96 session_->OnInitialHeadersComplete(id(), response_headers_); | 96 session_->OnInitialHeadersComplete(id(), response_headers_); |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 189 bytes_sent += header_bytes_written_; | 189 bytes_sent += header_bytes_written_; |
| 190 | 190 |
| 191 if (!body.empty()) { | 191 if (!body.empty()) { |
| 192 WriteOrBufferData(body, fin, nullptr); | 192 WriteOrBufferData(body, fin, nullptr); |
| 193 } | 193 } |
| 194 | 194 |
| 195 return bytes_sent; | 195 return bytes_sent; |
| 196 } | 196 } |
| 197 | 197 |
| 198 } // namespace net | 198 } // namespace net |
| OLD | NEW |