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/quic_chromium_client_stream.h" | 5 #include "net/quic/quic_chromium_client_stream.h" |
6 | 6 |
7 #include "base/callback_helpers.h" | 7 #include "base/callback_helpers.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/threading/thread_task_runner_handle.h" | 9 #include "base/threading/thread_task_runner_handle.h" |
10 #include "net/base/io_buffer.h" | 10 #include "net/base/io_buffer.h" |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
53 return; | 53 return; |
54 } | 54 } |
55 MarkHeadersConsumed(headers_len); | 55 MarkHeadersConsumed(headers_len); |
56 session_->OnInitialHeadersComplete(id(), headers); | 56 session_->OnInitialHeadersComplete(id(), headers); |
57 | 57 |
58 // The delegate will read the headers via a posted task. | 58 // The delegate will read the headers via a posted task. |
59 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); | 59 NotifyDelegateOfHeadersCompleteLater(headers, frame_len); |
60 } | 60 } |
61 } | 61 } |
62 | 62 |
| 63 void QuicChromiumClientStream::OnInitialHeadersComplete( |
| 64 bool fin, |
| 65 size_t frame_len, |
| 66 const QuicHeaderList& header_list) { |
| 67 QuicSpdyStream::OnInitialHeadersComplete(fin, frame_len, header_list); |
| 68 |
| 69 SpdyHeaderBlock header_block; |
| 70 int64_t length = -1; |
| 71 if (!SpdyUtils::CopyAndValidateHeaders(header_list, &length, &header_block)) { |
| 72 DLOG(ERROR) << "Failed to parse header list: " << header_list.DebugString(); |
| 73 ConsumeHeaderList(); |
| 74 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
| 75 return; |
| 76 } |
| 77 |
| 78 ConsumeHeaderList(); |
| 79 session_->OnInitialHeadersComplete(id(), header_block); |
| 80 |
| 81 // The delegate will read the headers via a posted task. |
| 82 NotifyDelegateOfHeadersCompleteLater(header_block, frame_len); |
| 83 } |
| 84 |
| 85 void QuicChromiumClientStream::OnTrailingHeadersComplete( |
| 86 bool fin, |
| 87 size_t frame_len, |
| 88 const QuicHeaderList& header_list) { |
| 89 QuicSpdyStream::OnTrailingHeadersComplete(fin, frame_len, header_list); |
| 90 NotifyDelegateOfHeadersCompleteLater(received_trailers(), frame_len); |
| 91 } |
| 92 |
63 void QuicChromiumClientStream::OnPromiseHeadersComplete( | 93 void QuicChromiumClientStream::OnPromiseHeadersComplete( |
64 QuicStreamId promised_id, | 94 QuicStreamId promised_id, |
65 size_t frame_len) { | 95 size_t frame_len) { |
66 size_t headers_len = decompressed_headers().length(); | 96 size_t headers_len = decompressed_headers().length(); |
67 SpdyHeaderBlock headers; | 97 SpdyHeaderBlock headers; |
68 SpdyFramer framer(HTTP2); | 98 SpdyFramer framer(HTTP2); |
69 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), | 99 if (!framer.ParseHeaderBlockInBuffer(decompressed_headers().data(), |
70 headers_len, &headers)) { | 100 headers_len, &headers)) { |
71 DLOG(WARNING) << "Invalid headers"; | 101 DLOG(WARNING) << "Invalid headers"; |
72 Reset(QUIC_BAD_APPLICATION_PAYLOAD); | 102 Reset(QUIC_BAD_APPLICATION_PAYLOAD); |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
215 } | 245 } |
216 | 246 |
217 void QuicChromiumClientStream::NotifyDelegateOfHeadersComplete( | 247 void QuicChromiumClientStream::NotifyDelegateOfHeadersComplete( |
218 SpdyHeaderBlock headers, | 248 SpdyHeaderBlock headers, |
219 size_t frame_len) { | 249 size_t frame_len) { |
220 if (!delegate_) | 250 if (!delegate_) |
221 return; | 251 return; |
222 // Only mark trailers consumed when we are about to notify delegate. | 252 // Only mark trailers consumed when we are about to notify delegate. |
223 if (headers_delivered_) { | 253 if (headers_delivered_) { |
224 MarkTrailersConsumed(decompressed_trailers().length()); | 254 MarkTrailersConsumed(decompressed_trailers().length()); |
| 255 MarkTrailersDelivered(); |
225 net_log_.AddEvent( | 256 net_log_.AddEvent( |
226 NetLog::TYPE_QUIC_CHROMIUM_CLIENT_STREAM_READ_RESPONSE_TRAILERS, | 257 NetLog::TYPE_QUIC_CHROMIUM_CLIENT_STREAM_READ_RESPONSE_TRAILERS, |
227 base::Bind(&SpdyHeaderBlockNetLogCallback, &headers)); | 258 base::Bind(&SpdyHeaderBlockNetLogCallback, &headers)); |
228 } else { | 259 } else { |
229 headers_delivered_ = true; | 260 headers_delivered_ = true; |
230 net_log_.AddEvent( | 261 net_log_.AddEvent( |
231 NetLog::TYPE_QUIC_CHROMIUM_CLIENT_STREAM_READ_RESPONSE_HEADERS, | 262 NetLog::TYPE_QUIC_CHROMIUM_CLIENT_STREAM_READ_RESPONSE_HEADERS, |
232 base::Bind(&SpdyHeaderBlockNetLogCallback, &headers)); | 263 base::Bind(&SpdyHeaderBlockNetLogCallback, &headers)); |
233 } | 264 } |
234 | 265 |
(...skipping 17 matching lines...) Expand all Loading... |
252 } else { | 283 } else { |
253 delegate_tasks_.push_back(closure); | 284 delegate_tasks_.push_back(closure); |
254 } | 285 } |
255 } | 286 } |
256 | 287 |
257 void QuicChromiumClientStream::DisableConnectionMigration() { | 288 void QuicChromiumClientStream::DisableConnectionMigration() { |
258 can_migrate_ = false; | 289 can_migrate_ = false; |
259 } | 290 } |
260 | 291 |
261 } // namespace net | 292 } // namespace net |
OLD | NEW |