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/feature_list.h" | 11 #include "base/feature_list.h" |
12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
13 #include "base/time/time.h" | 13 #include "base/time/time.h" |
14 #include "base/trace_event/trace_event.h" | 14 #include "base/trace_event/trace_event.h" |
15 #include "content/browser/loader/resource_dispatcher_host_impl.h" | 15 #include "content/browser/loader/resource_dispatcher_host_impl.h" |
16 #include "content/browser/loader/resource_request_info_impl.h" | 16 #include "content/browser/loader/resource_request_info_impl.h" |
17 #include "content/browser/loader/resource_requester_info.h" | 17 #include "content/browser/loader/resource_requester_info.h" |
18 #include "content/browser/loader/url_loader_factory_impl.h" | 18 #include "content/browser/loader/url_loader_factory_impl.h" |
19 #include "content/browser/service_worker/embedded_worker_status.h" | 19 #include "content/browser/service_worker/embedded_worker_status.h" |
20 #include "content/browser/service_worker/service_worker_metrics.h" | |
20 #include "content/browser/service_worker/service_worker_version.h" | 21 #include "content/browser/service_worker/service_worker_version.h" |
21 #include "content/common/service_worker/service_worker_event_dispatcher.mojom.h" | 22 #include "content/common/service_worker/service_worker_event_dispatcher.mojom.h" |
22 #include "content/common/service_worker/service_worker_messages.h" | 23 #include "content/common/service_worker/service_worker_messages.h" |
23 #include "content/common/service_worker/service_worker_status_code.h" | 24 #include "content/common/service_worker/service_worker_status_code.h" |
24 #include "content/common/service_worker/service_worker_types.h" | 25 #include "content/common/service_worker/service_worker_types.h" |
25 #include "content/common/service_worker/service_worker_utils.h" | 26 #include "content/common/service_worker/service_worker_utils.h" |
26 #include "content/public/common/browser_side_navigation_policy.h" | 27 #include "content/public/common/browser_side_navigation_policy.h" |
27 #include "content/public/common/content_features.h" | 28 #include "content/public/common/content_features.h" |
28 #include "mojo/public/cpp/bindings/associated_binding.h" | 29 #include "mojo/public/cpp/bindings/associated_binding.h" |
29 #include "mojo/public/cpp/bindings/binding.h" | 30 #include "mojo/public/cpp/bindings/binding.h" |
(...skipping 409 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
439 // Set to SUB_RESOURCE because we shouldn't trigger NavigationResourceThrottle | 440 // Set to SUB_RESOURCE because we shouldn't trigger NavigationResourceThrottle |
440 // for the service worker navigation preload request. | 441 // for the service worker navigation preload request. |
441 request.resource_type = RESOURCE_TYPE_SUB_RESOURCE; | 442 request.resource_type = RESOURCE_TYPE_SUB_RESOURCE; |
442 request.priority = original_request->priority(); | 443 request.priority = original_request->priority(); |
443 request.skip_service_worker = SkipServiceWorker::ALL; | 444 request.skip_service_worker = SkipServiceWorker::ALL; |
444 request.do_not_prompt_for_login = true; | 445 request.do_not_prompt_for_login = true; |
445 request.render_frame_id = original_info->GetRenderFrameID(); | 446 request.render_frame_id = original_info->GetRenderFrameID(); |
446 request.is_main_frame = original_info->IsMainFrame(); | 447 request.is_main_frame = original_info->IsMainFrame(); |
447 request.parent_is_main_frame = original_info->ParentIsMainFrame(); | 448 request.parent_is_main_frame = original_info->ParentIsMainFrame(); |
448 | 449 |
450 ServiceWorkerMetrics::RecordNavigationPreloadRequestHeaderSize( | |
451 version_->navigation_preload_state().header.length()); | |
falken
2017/01/11 05:28:05
nit: seems better to put this below line 452 or ev
horo
2017/01/11 06:13:07
Done.
| |
449 DCHECK(net::HttpUtil::IsValidHeaderValue( | 452 DCHECK(net::HttpUtil::IsValidHeaderValue( |
450 version_->navigation_preload_state().header)); | 453 version_->navigation_preload_state().header)); |
451 request.headers = "Service-Worker-Navigation-Preload: " + | 454 request.headers = "Service-Worker-Navigation-Preload: " + |
452 version_->navigation_preload_state().header; | 455 version_->navigation_preload_state().header; |
453 | 456 |
454 const int request_id = ResourceDispatcherHostImpl::Get()->MakeRequestID(); | 457 const int request_id = ResourceDispatcherHostImpl::Get()->MakeRequestID(); |
455 DCHECK_LT(request_id, -1); | 458 DCHECK_LT(request_id, -1); |
456 | 459 |
457 preload_handle_ = mojom::FetchEventPreloadHandle::New(); | 460 preload_handle_ = mojom::FetchEventPreloadHandle::New(); |
458 mojom::URLLoaderClientPtr url_loader_client_ptr; | 461 mojom::URLLoaderClientPtr url_loader_client_ptr; |
(...skipping 20 matching lines...) Expand all Loading... | |
479 } | 482 } |
480 | 483 |
481 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() | 484 ServiceWorkerMetrics::EventType ServiceWorkerFetchDispatcher::GetEventType() |
482 const { | 485 const { |
483 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) | 486 if (request_->fetch_type == ServiceWorkerFetchType::FOREIGN_FETCH) |
484 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; | 487 return ServiceWorkerMetrics::EventType::FOREIGN_FETCH; |
485 return ResourceTypeToEventType(resource_type_); | 488 return ResourceTypeToEventType(resource_type_); |
486 } | 489 } |
487 | 490 |
488 } // namespace content | 491 } // namespace content |
OLD | NEW |