| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/renderer/service_worker/service_worker_context_client.h" | 5 #include "content/renderer/service_worker/service_worker_context_client.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| (...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 279 const bool report_security_info = false; | 279 const bool report_security_info = false; |
| 280 WebURLLoaderImpl::PopulateURLResponse(url_, response_head, response_.get(), | 280 WebURLLoaderImpl::PopulateURLResponse(url_, response_head, response_.get(), |
| 281 report_security_info); | 281 report_security_info); |
| 282 MaybeReportResponseToClient(); | 282 MaybeReportResponseToClient(); |
| 283 } | 283 } |
| 284 | 284 |
| 285 void OnReceiveRedirect(const net::RedirectInfo& redirect_info, | 285 void OnReceiveRedirect(const net::RedirectInfo& redirect_info, |
| 286 const ResourceResponseHead& response_head) override { | 286 const ResourceResponseHead& response_head) override { |
| 287 // This will delete |this|. | 287 // This will delete |this|. |
| 288 ReportErrorToClient( | 288 ReportErrorToClient( |
| 289 "Service Worker navigation preload doesn't suport redirect."); | 289 "Service Worker navigation preload doesn't support redirects."); |
| 290 } | 290 } |
| 291 | 291 |
| 292 void OnDataDownloaded(int64_t data_length, | 292 void OnDataDownloaded(int64_t data_length, |
| 293 int64_t encoded_data_length) override { | 293 int64_t encoded_data_length) override { |
| 294 NOTREACHED(); | 294 NOTREACHED(); |
| 295 } | 295 } |
| 296 | 296 |
| 297 void OnReceiveCachedMetadata(const std::vector<uint8_t>& data) override {} | 297 void OnReceiveCachedMetadata(const std::vector<uint8_t>& data) override {} |
| 298 | 298 |
| 299 void OnTransferSizeUpdated(int32_t transfer_size_diff) override { | 299 void OnTransferSizeUpdated(int32_t transfer_size_diff) override { |
| 300 NOTREACHED(); | 300 // TODO(horo): Send this transfer size update notification to DevTools. |
| 301 } | 301 } |
| 302 | 302 |
| 303 void OnStartLoadingResponseBody( | 303 void OnStartLoadingResponseBody( |
| 304 mojo::ScopedDataPipeConsumerHandle body) override { | 304 mojo::ScopedDataPipeConsumerHandle body) override { |
| 305 DCHECK(!body_.is_valid()); | 305 DCHECK(!body_.is_valid()); |
| 306 body_ = std::move(body); | 306 body_ = std::move(body); |
| 307 MaybeReportResponseToClient(); | 307 MaybeReportResponseToClient(); |
| 308 } | 308 } |
| 309 | 309 |
| 310 void OnComplete(const ResourceRequestCompletionStatus& status) override { | 310 void OnComplete(const ResourceRequestCompletionStatus& status) override { |
| (...skipping 634 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 945 TRACE_EVENT0("ServiceWorker", | 945 TRACE_EVENT0("ServiceWorker", |
| 946 "ServiceWorkerContextClient::OnInstallEvent"); | 946 "ServiceWorkerContextClient::OnInstallEvent"); |
| 947 proxy_->dispatchInstallEvent(request_id); | 947 proxy_->dispatchInstallEvent(request_id); |
| 948 } | 948 } |
| 949 | 949 |
| 950 void ServiceWorkerContextClient::DispatchFetchEvent( | 950 void ServiceWorkerContextClient::DispatchFetchEvent( |
| 951 int fetch_event_id, | 951 int fetch_event_id, |
| 952 const ServiceWorkerFetchRequest& request, | 952 const ServiceWorkerFetchRequest& request, |
| 953 mojom::FetchEventPreloadHandlePtr preload_handle, | 953 mojom::FetchEventPreloadHandlePtr preload_handle, |
| 954 const DispatchFetchEventCallback& callback) { | 954 const DispatchFetchEventCallback& callback) { |
| 955 std::unique_ptr<NavigationPreloadRequest> preload_request = | 955 std::unique_ptr<NavigationPreloadRequest> preload_request; |
| 956 preload_handle | 956 if (preload_handle) { |
| 957 ? base::MakeUnique<NavigationPreloadRequest>( | 957 proxy_->onNavigationPreloadSent(fetch_event_id, request.url, |
| 958 fetch_event_id, request.url, std::move(preload_handle)) | 958 preload_handle->sent_timestamp, |
| 959 : nullptr; | 959 preload_handle->sent_wall_time); |
| 960 preload_request = base::MakeUnique<NavigationPreloadRequest>( |
| 961 fetch_event_id, request.url, std::move(preload_handle)); |
| 962 } |
| 960 const bool navigation_preload_sent = !!preload_request; | 963 const bool navigation_preload_sent = !!preload_request; |
| 961 blink::WebServiceWorkerRequest webRequest; | 964 blink::WebServiceWorkerRequest webRequest; |
| 962 TRACE_EVENT0("ServiceWorker", | 965 TRACE_EVENT0("ServiceWorker", |
| 963 "ServiceWorkerContextClient::DispatchFetchEvent"); | 966 "ServiceWorkerContextClient::DispatchFetchEvent"); |
| 964 context_->fetch_event_callbacks.AddWithID( | 967 context_->fetch_event_callbacks.AddWithID( |
| 965 base::MakeUnique<FetchCallback>(callback), fetch_event_id); | 968 base::MakeUnique<FetchCallback>(callback), fetch_event_id); |
| 966 if (preload_request) { | 969 if (preload_request) { |
| 967 context_->preload_requests.AddWithID(std::move(preload_request), | 970 context_->preload_requests.AddWithID(std::move(preload_request), |
| 968 fetch_event_id); | 971 fetch_event_id); |
| 969 } | 972 } |
| (...skipping 269 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1239 | 1242 |
| 1240 void ServiceWorkerContextClient::OnNavigationPreloadError( | 1243 void ServiceWorkerContextClient::OnNavigationPreloadError( |
| 1241 int fetch_event_id, | 1244 int fetch_event_id, |
| 1242 std::unique_ptr<blink::WebServiceWorkerError> error) { | 1245 std::unique_ptr<blink::WebServiceWorkerError> error) { |
| 1243 proxy_->onNavigationPreloadError(fetch_event_id, std::move(error)); | 1246 proxy_->onNavigationPreloadError(fetch_event_id, std::move(error)); |
| 1244 context_->preload_requests.Remove(fetch_event_id); | 1247 context_->preload_requests.Remove(fetch_event_id); |
| 1245 } | 1248 } |
| 1246 | 1249 |
| 1247 void ServiceWorkerContextClient::OnNavigationPreloadComplete( | 1250 void ServiceWorkerContextClient::OnNavigationPreloadComplete( |
| 1248 int fetch_event_id) { | 1251 int fetch_event_id) { |
| 1252 proxy_->onNavigationPreloadCompleted(fetch_event_id); |
| 1249 context_->preload_requests.Remove(fetch_event_id); | 1253 context_->preload_requests.Remove(fetch_event_id); |
| 1250 } | 1254 } |
| 1251 | 1255 |
| 1252 base::WeakPtr<ServiceWorkerContextClient> | 1256 base::WeakPtr<ServiceWorkerContextClient> |
| 1253 ServiceWorkerContextClient::GetWeakPtr() { | 1257 ServiceWorkerContextClient::GetWeakPtr() { |
| 1254 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); | 1258 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); |
| 1255 DCHECK(context_); | 1259 DCHECK(context_); |
| 1256 return context_->weak_factory.GetWeakPtr(); | 1260 return context_->weak_factory.GetWeakPtr(); |
| 1257 } | 1261 } |
| 1258 | 1262 |
| 1259 } // namespace content | 1263 } // namespace content |
| OLD | NEW |