OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/browser/service_worker/service_worker_fetch_dispatcher.h" | 5 #include "content/browser/service_worker/service_worker_fetch_dispatcher.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 263 matching lines...) Loading... |
274 net_log_.EndEvent( | 274 net_log_.EndEvent( |
275 net::NetLogEventType::SERVICE_WORKER_DISPATCH_FETCH_EVENT, | 275 net::NetLogEventType::SERVICE_WORKER_DISPATCH_FETCH_EVENT, |
276 base::Bind(&NetLogFetchEventCallback, status, fetch_result)); | 276 base::Bind(&NetLogFetchEventCallback, status, fetch_result)); |
277 | 277 |
278 FetchCallback fetch_callback = fetch_callback_; | 278 FetchCallback fetch_callback = fetch_callback_; |
279 scoped_refptr<ServiceWorkerVersion> version = version_; | 279 scoped_refptr<ServiceWorkerVersion> version = version_; |
280 fetch_callback.Run(status, fetch_result, response, version); | 280 fetch_callback.Run(status, fetch_result, response, version); |
281 } | 281 } |
282 | 282 |
283 void ServiceWorkerFetchDispatcher::MaybeStartNavigationPreload( | 283 void ServiceWorkerFetchDispatcher::MaybeStartNavigationPreload( |
284 net::URLRequest* original_request) { | 284 net::URLRequest* original_request, |
| 285 base::WeakPtr<ServiceWorkerProviderHost> provider_host) { |
285 if (resource_type_ != RESOURCE_TYPE_MAIN_FRAME && | 286 if (resource_type_ != RESOURCE_TYPE_MAIN_FRAME && |
286 resource_type_ != RESOURCE_TYPE_SUB_FRAME) { | 287 resource_type_ != RESOURCE_TYPE_SUB_FRAME) { |
287 return; | 288 return; |
288 } | 289 } |
289 if (!version_->navigation_preload_state().enabled) | 290 if (!version_->navigation_preload_state().enabled) |
290 return; | 291 return; |
291 // TODO(horo): Currently NavigationPreload doesn't support request body. | 292 // TODO(horo): Currently NavigationPreload doesn't support request body. |
292 if (!request_->blob_uuid.empty()) | 293 if (!request_->blob_uuid.empty()) |
293 return; | 294 return; |
294 if (!base::FeatureList::IsEnabled( | 295 if (!base::FeatureList::IsEnabled( |
295 features::kServiceWorkerNavigationPreload)) { | 296 features::kServiceWorkerNavigationPreload)) { |
296 // TODO(horo): Check |version_|'s origin_trial_tokens() here if we use | 297 // TODO(horo): Check |version_|'s origin_trial_tokens() here if we use |
297 // Origin-Trial for NavigationPreload. | 298 // Origin-Trial for NavigationPreload. |
298 return; | 299 return; |
299 } | 300 } |
300 if (IsBrowserSideNavigationEnabled()) { | |
301 // TODO(horo): Support NavigationPreload with PlzNavigate. | |
302 NOTIMPLEMENTED(); | |
303 return; | |
304 } | |
305 | 301 |
306 const ResourceRequestInfoImpl* original_info = | 302 const ResourceRequestInfoImpl* original_info = |
307 ResourceRequestInfoImpl::ForRequest(original_request); | 303 ResourceRequestInfoImpl::ForRequest(original_request); |
308 if (!original_info->filter()) | 304 ResourceMessageFilter* filter = original_info->filter(); |
309 return; | 305 if (!filter) { |
| 306 DCHECK(IsBrowserSideNavigationEnabled()); |
| 307 if (!provider_host) |
| 308 return; |
| 309 filter = provider_host->resource_filter_for_navigation_preload(); |
| 310 } |
| 311 DCHECK(filter); |
| 312 |
310 mojom::URLLoaderFactoryPtr factory; | 313 mojom::URLLoaderFactoryPtr factory; |
311 URLLoaderFactoryImpl::Create(original_info->filter(), | 314 URLLoaderFactoryImpl::Create(filter, mojo::GetProxy(&factory)); |
312 mojo::GetProxy(&factory)); | |
313 | 315 |
314 preload_handle_ = mojom::FetchEventPreloadHandle::New(); | 316 preload_handle_ = mojom::FetchEventPreloadHandle::New(); |
315 | 317 |
316 mojom::URLLoaderClientPtr url_loader_client; | 318 mojom::URLLoaderClientPtr url_loader_client; |
317 preload_handle_->url_loader_client_request = GetProxy(&url_loader_client); | 319 preload_handle_->url_loader_client_request = GetProxy(&url_loader_client); |
318 | 320 |
319 ResourceRequest request; | 321 ResourceRequest request; |
320 request.method = original_request->method(); | 322 request.method = original_request->method(); |
321 request.url = original_request->url(); | 323 request.url = original_request->url(); |
322 request.referrer = GURL(original_request->referrer()); | 324 request.referrer = GURL(original_request->referrer()); |
(...skipping 19 matching lines...) Loading... |
342 } | 344 } |
343 | 345 |
344 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() | 346 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() |
345 const { | 347 const { |
346 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) | 348 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) |
347 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; | 349 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; |
348 return ResourceTypeToEventType(resource_type_); | 350 return ResourceTypeToEventType(resource_type_); |
349 } | 351 } |
350 | 352 |
351 } // namespace content | 353 } // namespace content |
OLD | NEW |