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 support redirects."); | 289 "Service Worker navigation preload doesn't suport redirect."); |
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 // TODO(horo): Send this transfer size update notification to DevTools. | 300 NOTREACHED(); |
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 { |
311 if (status.error_code != net::OK) { | 311 if (status.error_code != net::OK) { |
312 // This will delete |this|. | 312 // This will delete |this|. |
313 ReportErrorToClient("Service Worker navigation preload network error."); | 313 ReportErrorToClient("Service Worker navigation preload network error."); |
314 return; | 314 return; |
315 } | 315 } |
316 | 316 |
317 ServiceWorkerContextClient* client = | 317 ServiceWorkerContextClient* client = |
318 ServiceWorkerContextClient::ThreadSpecificInstance(); | 318 ServiceWorkerContextClient::ThreadSpecificInstance(); |
319 if (!client) | 319 if (!client) |
320 return; | 320 return; |
321 // This will delete |this|. | 321 // This will delete |this|. |
322 client->OnNavigationPreloadComplete(fetch_event_id_, | 322 client->OnNavigationPreloadComplete(fetch_event_id_); |
323 status.encoded_data_length); | |
324 } | 323 } |
325 | 324 |
326 private: | 325 private: |
327 void MaybeReportResponseToClient() { | 326 void MaybeReportResponseToClient() { |
328 if (!response_ || !body_.is_valid()) | 327 if (!response_ || !body_.is_valid()) |
329 return; | 328 return; |
330 ServiceWorkerContextClient* client = | 329 ServiceWorkerContextClient* client = |
331 ServiceWorkerContextClient::ThreadSpecificInstance(); | 330 ServiceWorkerContextClient::ThreadSpecificInstance(); |
332 if (!client) | 331 if (!client) |
333 return; | 332 return; |
(...skipping 612 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
946 TRACE_EVENT0("ServiceWorker", | 945 TRACE_EVENT0("ServiceWorker", |
947 "ServiceWorkerContextClient::OnInstallEvent"); | 946 "ServiceWorkerContextClient::OnInstallEvent"); |
948 proxy_->dispatchInstallEvent(request_id); | 947 proxy_->dispatchInstallEvent(request_id); |
949 } | 948 } |
950 | 949 |
951 void ServiceWorkerContextClient::DispatchFetchEvent( | 950 void ServiceWorkerContextClient::DispatchFetchEvent( |
952 int fetch_event_id, | 951 int fetch_event_id, |
953 const ServiceWorkerFetchRequest& request, | 952 const ServiceWorkerFetchRequest& request, |
954 mojom::FetchEventPreloadHandlePtr preload_handle, | 953 mojom::FetchEventPreloadHandlePtr preload_handle, |
955 const DispatchFetchEventCallback& callback) { | 954 const DispatchFetchEventCallback& callback) { |
956 std::unique_ptr<NavigationPreloadRequest> preload_request; | 955 std::unique_ptr<NavigationPreloadRequest> preload_request = |
957 if (preload_handle) { | 956 preload_handle |
958 proxy_->onNavigationPreloadSent(fetch_event_id, request.url); | 957 ? base::MakeUnique<NavigationPreloadRequest>( |
959 preload_request = base::MakeUnique<NavigationPreloadRequest>( | 958 fetch_event_id, request.url, std::move(preload_handle)) |
960 fetch_event_id, request.url, std::move(preload_handle)); | 959 : nullptr; |
961 } | |
962 const bool navigation_preload_sent = !!preload_request; | 960 const bool navigation_preload_sent = !!preload_request; |
963 blink::WebServiceWorkerRequest webRequest; | 961 blink::WebServiceWorkerRequest webRequest; |
964 TRACE_EVENT0("ServiceWorker", | 962 TRACE_EVENT0("ServiceWorker", |
965 "ServiceWorkerContextClient::DispatchFetchEvent"); | 963 "ServiceWorkerContextClient::DispatchFetchEvent"); |
966 context_->fetch_event_callbacks.AddWithID( | 964 context_->fetch_event_callbacks.AddWithID( |
967 base::MakeUnique<FetchCallback>(callback), fetch_event_id); | 965 base::MakeUnique<FetchCallback>(callback), fetch_event_id); |
968 if (preload_request) { | 966 if (preload_request) { |
969 context_->preload_requests.AddWithID(std::move(preload_request), | 967 context_->preload_requests.AddWithID(std::move(preload_request), |
970 fetch_event_id); | 968 fetch_event_id); |
971 } | 969 } |
(...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1240 } | 1238 } |
1241 | 1239 |
1242 void ServiceWorkerContextClient::OnNavigationPreloadError( | 1240 void ServiceWorkerContextClient::OnNavigationPreloadError( |
1243 int fetch_event_id, | 1241 int fetch_event_id, |
1244 std::unique_ptr<blink::WebServiceWorkerError> error) { | 1242 std::unique_ptr<blink::WebServiceWorkerError> error) { |
1245 proxy_->onNavigationPreloadError(fetch_event_id, std::move(error)); | 1243 proxy_->onNavigationPreloadError(fetch_event_id, std::move(error)); |
1246 context_->preload_requests.Remove(fetch_event_id); | 1244 context_->preload_requests.Remove(fetch_event_id); |
1247 } | 1245 } |
1248 | 1246 |
1249 void ServiceWorkerContextClient::OnNavigationPreloadComplete( | 1247 void ServiceWorkerContextClient::OnNavigationPreloadComplete( |
1250 int fetch_event_id, | 1248 int fetch_event_id) { |
1251 int64_t encoded_data_length) { | |
1252 proxy_->onNavigationPreloadCompleted(fetch_event_id, encoded_data_length); | |
1253 context_->preload_requests.Remove(fetch_event_id); | 1249 context_->preload_requests.Remove(fetch_event_id); |
1254 } | 1250 } |
1255 | 1251 |
1256 base::WeakPtr<ServiceWorkerContextClient> | 1252 base::WeakPtr<ServiceWorkerContextClient> |
1257 ServiceWorkerContextClient::GetWeakPtr() { | 1253 ServiceWorkerContextClient::GetWeakPtr() { |
1258 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); | 1254 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); |
1259 DCHECK(context_); | 1255 DCHECK(context_); |
1260 return context_->weak_factory.GetWeakPtr(); | 1256 return context_->weak_factory.GetWeakPtr(); |
1261 } | 1257 } |
1262 | 1258 |
1263 } // namespace content | 1259 } // namespace content |
OLD | NEW |