| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "content/network/url_loader_impl.h" | 5 #include "content/network/url_loader_impl.h" |
| 6 | 6 |
| 7 #include "base/task_scheduler/post_task.h" | 7 #include "base/task_scheduler/post_task.h" |
| 8 #include "base/threading/thread_task_runner_handle.h" | 8 #include "base/threading/thread_task_runner_handle.h" |
| 9 #include "base/time/time.h" | 9 #include "base/time/time.h" |
| 10 #include "content/common/net_adapters.h" | 10 #include "content/common/net_adapters.h" |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 66 response->head.effective_connection_type = | 66 response->head.effective_connection_type = |
| 67 net::EFFECTIVE_CONNECTION_TYPE_UNKNOWN; | 67 net::EFFECTIVE_CONNECTION_TYPE_UNKNOWN; |
| 68 | 68 |
| 69 request->GetLoadTimingInfo(&response->head.load_timing); | 69 request->GetLoadTimingInfo(&response->head.load_timing); |
| 70 | 70 |
| 71 response->head.request_start = request->creation_time(); | 71 response->head.request_start = request->creation_time(); |
| 72 response->head.response_start = base::TimeTicks::Now(); | 72 response->head.response_start = base::TimeTicks::Now(); |
| 73 } | 73 } |
| 74 | 74 |
| 75 // A subclass of net::UploadBytesElementReader which owns | 75 // A subclass of net::UploadBytesElementReader which owns |
| 76 // ResourceRequestBodyImpl. | 76 // ResourceRequestBody. |
| 77 class BytesElementReader : public net::UploadBytesElementReader { | 77 class BytesElementReader : public net::UploadBytesElementReader { |
| 78 public: | 78 public: |
| 79 BytesElementReader(ResourceRequestBodyImpl* resource_request_body, | 79 BytesElementReader(ResourceRequestBody* resource_request_body, |
| 80 const ResourceRequestBodyImpl::Element& element) | 80 const ResourceRequestBody::Element& element) |
| 81 : net::UploadBytesElementReader(element.bytes(), element.length()), | 81 : net::UploadBytesElementReader(element.bytes(), element.length()), |
| 82 resource_request_body_(resource_request_body) { | 82 resource_request_body_(resource_request_body) { |
| 83 DCHECK_EQ(ResourceRequestBodyImpl::Element::TYPE_BYTES, element.type()); | 83 DCHECK_EQ(ResourceRequestBody::Element::TYPE_BYTES, element.type()); |
| 84 } | 84 } |
| 85 | 85 |
| 86 ~BytesElementReader() override {} | 86 ~BytesElementReader() override {} |
| 87 | 87 |
| 88 private: | 88 private: |
| 89 scoped_refptr<ResourceRequestBodyImpl> resource_request_body_; | 89 scoped_refptr<ResourceRequestBody> resource_request_body_; |
| 90 | 90 |
| 91 DISALLOW_COPY_AND_ASSIGN(BytesElementReader); | 91 DISALLOW_COPY_AND_ASSIGN(BytesElementReader); |
| 92 }; | 92 }; |
| 93 | 93 |
| 94 // A subclass of net::UploadFileElementReader which owns | 94 // A subclass of net::UploadFileElementReader which owns |
| 95 // ResourceRequestBodyImpl. | 95 // ResourceRequestBody. |
| 96 // This class is necessary to ensure the BlobData and any attached shareable | 96 // This class is necessary to ensure the BlobData and any attached shareable |
| 97 // files survive until upload completion. | 97 // files survive until upload completion. |
| 98 class FileElementReader : public net::UploadFileElementReader { | 98 class FileElementReader : public net::UploadFileElementReader { |
| 99 public: | 99 public: |
| 100 FileElementReader(ResourceRequestBodyImpl* resource_request_body, | 100 FileElementReader(ResourceRequestBody* resource_request_body, |
| 101 base::TaskRunner* task_runner, | 101 base::TaskRunner* task_runner, |
| 102 const ResourceRequestBodyImpl::Element& element) | 102 const ResourceRequestBody::Element& element) |
| 103 : net::UploadFileElementReader(task_runner, | 103 : net::UploadFileElementReader(task_runner, |
| 104 element.path(), | 104 element.path(), |
| 105 element.offset(), | 105 element.offset(), |
| 106 element.length(), | 106 element.length(), |
| 107 element.expected_modification_time()), | 107 element.expected_modification_time()), |
| 108 resource_request_body_(resource_request_body) { | 108 resource_request_body_(resource_request_body) { |
| 109 DCHECK_EQ(ResourceRequestBodyImpl::Element::TYPE_FILE, element.type()); | 109 DCHECK_EQ(ResourceRequestBody::Element::TYPE_FILE, element.type()); |
| 110 } | 110 } |
| 111 | 111 |
| 112 ~FileElementReader() override {} | 112 ~FileElementReader() override {} |
| 113 | 113 |
| 114 private: | 114 private: |
| 115 scoped_refptr<ResourceRequestBodyImpl> resource_request_body_; | 115 scoped_refptr<ResourceRequestBody> resource_request_body_; |
| 116 | 116 |
| 117 DISALLOW_COPY_AND_ASSIGN(FileElementReader); | 117 DISALLOW_COPY_AND_ASSIGN(FileElementReader); |
| 118 }; | 118 }; |
| 119 | 119 |
| 120 // TODO: copied from content/browser/loader/upload_data_stream_builder.cc. | 120 // TODO: copied from content/browser/loader/upload_data_stream_builder.cc. |
| 121 std::unique_ptr<net::UploadDataStream> CreateUploadDataStream( | 121 std::unique_ptr<net::UploadDataStream> CreateUploadDataStream( |
| 122 ResourceRequestBodyImpl* body, | 122 ResourceRequestBody* body, |
| 123 base::SequencedTaskRunner* file_task_runner) { | 123 base::SequencedTaskRunner* file_task_runner) { |
| 124 std::vector<std::unique_ptr<net::UploadElementReader>> element_readers; | 124 std::vector<std::unique_ptr<net::UploadElementReader>> element_readers; |
| 125 for (const auto& element : *body->elements()) { | 125 for (const auto& element : *body->elements()) { |
| 126 switch (element.type()) { | 126 switch (element.type()) { |
| 127 case ResourceRequestBodyImpl::Element::TYPE_BYTES: | 127 case ResourceRequestBody::Element::TYPE_BYTES: |
| 128 element_readers.push_back( | 128 element_readers.push_back( |
| 129 base::MakeUnique<BytesElementReader>(body, element)); | 129 base::MakeUnique<BytesElementReader>(body, element)); |
| 130 break; | 130 break; |
| 131 case ResourceRequestBodyImpl::Element::TYPE_FILE: | 131 case ResourceRequestBody::Element::TYPE_FILE: |
| 132 element_readers.push_back(base::MakeUnique<FileElementReader>( | 132 element_readers.push_back(base::MakeUnique<FileElementReader>( |
| 133 body, file_task_runner, element)); | 133 body, file_task_runner, element)); |
| 134 break; | 134 break; |
| 135 case ResourceRequestBodyImpl::Element::TYPE_FILE_FILESYSTEM: | 135 case ResourceRequestBody::Element::TYPE_FILE_FILESYSTEM: |
| 136 NOTIMPLEMENTED(); | 136 NOTIMPLEMENTED(); |
| 137 break; | 137 break; |
| 138 case ResourceRequestBodyImpl::Element::TYPE_BLOB: { | 138 case ResourceRequestBody::Element::TYPE_BLOB: { |
| 139 NOTIMPLEMENTED(); | 139 NOTIMPLEMENTED(); |
| 140 break; | 140 break; |
| 141 } | 141 } |
| 142 case ResourceRequestBodyImpl::Element::TYPE_DISK_CACHE_ENTRY: | 142 case ResourceRequestBody::Element::TYPE_DISK_CACHE_ENTRY: |
| 143 case ResourceRequestBodyImpl::Element::TYPE_BYTES_DESCRIPTION: | 143 case ResourceRequestBody::Element::TYPE_BYTES_DESCRIPTION: |
| 144 case ResourceRequestBodyImpl::Element::TYPE_UNKNOWN: | 144 case ResourceRequestBody::Element::TYPE_UNKNOWN: |
| 145 NOTREACHED(); | 145 NOTREACHED(); |
| 146 break; | 146 break; |
| 147 } | 147 } |
| 148 } | 148 } |
| 149 | 149 |
| 150 return base::MakeUnique<net::ElementsUploadDataStream>( | 150 return base::MakeUnique<net::ElementsUploadDataStream>( |
| 151 std::move(element_readers), body->identifier()); | 151 std::move(element_readers), body->identifier()); |
| 152 } | 152 } |
| 153 | 153 |
| 154 } // namespace | 154 } // namespace |
| (...skipping 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 393 ReadMore(); | 393 ReadMore(); |
| 394 } | 394 } |
| 395 | 395 |
| 396 void URLLoaderImpl::DeleteIfNeeded() { | 396 void URLLoaderImpl::DeleteIfNeeded() { |
| 397 bool has_data_pipe = pending_write_.get() || response_body_stream_.is_valid(); | 397 bool has_data_pipe = pending_write_.get() || response_body_stream_.is_valid(); |
| 398 if (!connected_ && !has_data_pipe) | 398 if (!connected_ && !has_data_pipe) |
| 399 delete this; | 399 delete this; |
| 400 } | 400 } |
| 401 | 401 |
| 402 } // namespace content | 402 } // namespace content |
| OLD | NEW |