Chromium Code Reviews| 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" |
| 11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
| 12 #include "base/time/time.h" | 12 #include "base/time/time.h" |
| 13 #include "base/trace_event/trace_event.h" | 13 #include "base/trace_event/trace_event.h" |
| 14 #include "content/browser/loader/resource_dispatcher_host_impl.h" | |
| 15 #include "content/browser/loader/resource_request_info_impl.h" | |
| 14 #include "content/browser/service_worker/embedded_worker_status.h" | 16 #include "content/browser/service_worker/embedded_worker_status.h" |
| 15 #include "content/browser/service_worker/service_worker_version.h" | 17 #include "content/browser/service_worker/service_worker_version.h" |
| 16 #include "content/common/service_worker/fetch_event_dispatcher.mojom.h" | 18 #include "content/common/service_worker/fetch_event_dispatcher.mojom.h" |
| 17 #include "content/common/service_worker/service_worker_messages.h" | 19 #include "content/common/service_worker/service_worker_messages.h" |
| 18 #include "content/common/service_worker/service_worker_status_code.h" | 20 #include "content/common/service_worker/service_worker_status_code.h" |
| 19 #include "content/common/service_worker/service_worker_utils.h" | 21 #include "content/common/service_worker/service_worker_utils.h" |
| 22 #include "content/common/url_loader.mojom.h" | |
| 23 #include "content/common/url_loader_factory.mojom.h" | |
| 20 #include "net/log/net_log.h" | 24 #include "net/log/net_log.h" |
| 21 #include "net/log/net_log_capture_mode.h" | 25 #include "net/log/net_log_capture_mode.h" |
| 22 | |
| 23 #include "net/log/net_log_event_type.h" | 26 #include "net/log/net_log_event_type.h" |
| 27 #include "net/url_request/url_request.h" | |
| 24 | 28 |
| 25 namespace content { | 29 namespace content { |
| 26 | 30 |
| 27 namespace { | 31 namespace { |
| 28 | 32 |
| 29 using EventType = ServiceWorkerMetrics::EventType; | 33 using EventType = ServiceWorkerMetrics::EventType; |
| 30 EventType ResourceTypeToEventType(ResourceType resource_type) { | 34 EventType ResourceTypeToEventType(ResourceType resource_type) { |
| 31 switch (resource_type) { | 35 switch (resource_type) { |
| 32 case RESOURCE_TYPE_MAIN_FRAME: | 36 case RESOURCE_TYPE_MAIN_FRAME: |
| 33 return EventType::FETCH_MAIN_FRAME; | 37 return EventType::FETCH_MAIN_FRAME; |
| (...skipping 231 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 265 net_log_.EndEvent( | 269 net_log_.EndEvent( |
| 266 net::NetLogEventType::SERVICE_WORKER_DISPATCH_FETCH_EVENT, | 270 net::NetLogEventType::SERVICE_WORKER_DISPATCH_FETCH_EVENT, |
| 267 base::Bind(&NetLogFetchEventCallback, status, fetch_result)); | 271 base::Bind(&NetLogFetchEventCallback, status, fetch_result)); |
| 268 | 272 |
| 269 FetchCallback fetch_callback = fetch_callback_; | 273 FetchCallback fetch_callback = fetch_callback_; |
| 270 scoped_refptr<ServiceWorkerVersion> version = version_; | 274 scoped_refptr<ServiceWorkerVersion> version = version_; |
| 271 fetch_callback.Run(status, fetch_result, response, version); | 275 fetch_callback.Run(status, fetch_result, response, version); |
| 272 } | 276 } |
| 273 | 277 |
| 274 void ServiceWorkerFetchDispatcher::MaybeStartNavigationPreload( | 278 void ServiceWorkerFetchDispatcher::MaybeStartNavigationPreload( |
| 275 net::URLRequest* original_request) { | 279 net::URLRequest* original_request, |
| 280 const URLLoaderFactoryCallback& url_loader_factory_callback) { | |
| 276 if (resource_type_ != RESOURCE_TYPE_MAIN_FRAME && | 281 if (resource_type_ != RESOURCE_TYPE_MAIN_FRAME && |
| 277 resource_type_ != RESOURCE_TYPE_SUB_FRAME) { | 282 resource_type_ != RESOURCE_TYPE_SUB_FRAME) { |
| 278 return; | 283 return; |
| 279 } | 284 } |
| 280 if (!version_->navigation_preload_enabled()) | 285 if (!version_->navigation_preload_enabled()) |
| 281 return; | 286 return; |
| 282 // TODO(horo): Implement this to start the preload request for the navigation | 287 // TODO(horo): Currently NavigationPreload doesn't support request body. |
| 283 // request and set |preload_handle_|. | 288 if (!request_->blob_uuid.empty()) |
| 284 NOTIMPLEMENTED(); | 289 return; |
| 290 // TODO(horo): Introduce kEnableServiceWorkerNavigationPreload switch, and use | |
| 291 // it instead of kEnableExperimentalWebPlatformFeatures. | |
| 292 if (!base::CommandLine::ForCurrentProcess()->HasSwitch( | |
| 293 switches::kEnableExperimentalWebPlatformFeatures)) { | |
| 294 // TODO(horo): Check |version_|'s origin_trial_tokens() here if we use | |
| 295 // Origin-Trial for NavigationPreload. | |
| 296 return; | |
| 297 } | |
| 298 DCHECK(!url_loader_factory_callback.is_null()); | |
| 299 mojom::URLLoaderFactoryPtr factory; | |
| 300 if (!url_loader_factory_callback.Run(mojo::GetProxy(&factory))) | |
| 301 return; | |
| 302 | |
| 303 preload_handle_ = mojom::FetchEventPreloadHandle::New(); | |
| 304 const ResourceRequestInfoImpl* original_info = | |
| 305 ResourceRequestInfoImpl::ForRequest(original_request); | |
| 306 | |
| 307 mojom::URLLoaderClientPtr url_loader_client; | |
| 308 preload_handle_->url_loader_client_request = GetProxy(&url_loader_client); | |
| 309 | |
| 310 ResourceRequest request; | |
| 311 request.method = original_request->method(); | |
| 312 request.url = original_request->url(); | |
| 313 request.referrer = GURL(original_request->referrer()); | |
| 314 request.referrer_policy = original_info->GetReferrerPolicy(); | |
| 315 request.visibility_state = original_info->GetVisibilityState(); | |
| 316 request.load_flags = original_request->load_flags(); | |
| 317 request.resource_type = RESOURCE_TYPE_SUB_RESOURCE; | |
|
falken
2016/10/19 05:11:27
Why SUB_RESOURCE instead of resource_type_?
horo
2016/10/19 06:22:52
It is because we shouldn't trigger NavigationResou
| |
| 318 request.priority = original_request->priority(); | |
| 319 request.skip_service_worker = SkipServiceWorker::ALL; | |
| 320 request.do_not_prompt_for_login = true; | |
| 321 request.render_frame_id = original_info->GetRenderFrameID(); | |
| 322 request.is_main_frame = original_info->IsMainFrame(); | |
| 323 request.parent_is_main_frame = original_info->ParentIsMainFrame(); | |
| 324 const int request_id = ResourceDispatcherHostImpl::Get()->MakeRequestID(); | |
| 325 DCHECK(request_id <= -2); | |
|
falken
2016/10/19 05:11:28
nit: DCHECK_LT -1?
horo
2016/10/19 06:22:52
Done.
| |
| 326 // TODO(horo): Add "Service-Worker-Navigation-Preload" header. | |
| 327 // See: https://github.com/w3c/ServiceWorker/issues/920#issuecomment-251150270 | |
| 328 factory->CreateLoaderAndStart(GetProxy(&preload_handle_->url_loader), | |
| 329 original_info->GetRouteID(), request_id, | |
| 330 request, std::move(url_loader_client)); | |
| 285 } | 331 } |
| 286 | 332 |
| 287 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() | 333 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() |
| 288 const { | 334 const { |
| 289 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) | 335 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) |
| 290 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; | 336 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; |
| 291 return ResourceTypeToEventType(resource_type_); | 337 return ResourceTypeToEventType(resource_type_); |
| 292 } | 338 } |
| 293 | 339 |
| 294 } // namespace content | 340 } // namespace content |
| OLD | NEW |