| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_provider_host.h" | 5 #include "content/browser/service_worker/service_worker_provider_host.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" |
| 7 #include "base/guid.h" | 8 #include "base/guid.h" |
| 8 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
| 9 #include "content/browser/frame_host/frame_tree.h" | 10 #include "content/browser/frame_host/frame_tree.h" |
| 10 #include "content/browser/frame_host/frame_tree_node.h" | 11 #include "content/browser/frame_host/frame_tree_node.h" |
| 11 #include "content/browser/frame_host/render_frame_host_impl.h" | 12 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 12 #include "content/browser/message_port_message_filter.h" | 13 #include "content/browser/message_port_message_filter.h" |
| 13 #include "content/browser/service_worker/service_worker_context_core.h" | 14 #include "content/browser/service_worker/service_worker_context_core.h" |
| 14 #include "content/browser/service_worker/service_worker_context_request_handler.
h" | 15 #include "content/browser/service_worker/service_worker_context_request_handler.
h" |
| 15 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" | 16 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" |
| 16 #include "content/browser/service_worker/service_worker_dispatcher_host.h" | 17 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
| 17 #include "content/browser/service_worker/service_worker_handle.h" | 18 #include "content/browser/service_worker/service_worker_handle.h" |
| 18 #include "content/browser/service_worker/service_worker_registration_handle.h" | 19 #include "content/browser/service_worker/service_worker_registration_handle.h" |
| 19 #include "content/browser/service_worker/service_worker_utils.h" | 20 #include "content/browser/service_worker/service_worker_utils.h" |
| 20 #include "content/browser/service_worker/service_worker_version.h" | 21 #include "content/browser/service_worker/service_worker_version.h" |
| 21 #include "content/browser/web_contents/web_contents_impl.h" | 22 #include "content/browser/web_contents/web_contents_impl.h" |
| 22 #include "content/common/resource_request_body.h" | 23 #include "content/common/resource_request_body.h" |
| 23 #include "content/common/service_worker/service_worker_messages.h" | 24 #include "content/common/service_worker/service_worker_messages.h" |
| 24 #include "content/common/service_worker/service_worker_types.h" | 25 #include "content/common/service_worker/service_worker_types.h" |
| 25 #include "content/public/browser/render_frame_host.h" | 26 #include "content/public/browser/render_frame_host.h" |
| 26 #include "content/public/browser/render_widget_host_view.h" | 27 #include "content/public/browser/render_widget_host_view.h" |
| 27 #include "content/public/browser/web_contents.h" | 28 #include "content/public/browser/web_contents.h" |
| 28 #include "content/public/common/child_process_host.h" | 29 #include "content/public/common/child_process_host.h" |
| 30 #include "content/public/common/content_switches.h" |
| 29 | 31 |
| 30 namespace content { | 32 namespace content { |
| 31 | 33 |
| 32 namespace { | 34 namespace { |
| 33 | 35 |
| 34 ServiceWorkerClientInfo FocusOnUIThread(int render_process_id, | 36 ServiceWorkerClientInfo FocusOnUIThread(int render_process_id, |
| 35 int render_frame_id) { | 37 int render_frame_id) { |
| 36 RenderFrameHostImpl* render_frame_host = | 38 RenderFrameHostImpl* render_frame_host = |
| 37 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); | 39 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
| 38 WebContentsImpl* web_contents = static_cast<WebContentsImpl*>( | 40 WebContentsImpl* web_contents = static_cast<WebContentsImpl*>( |
| (...skipping 12 matching lines...) Expand all Loading... |
| 51 | 53 |
| 52 // Move the web contents to the foreground. | 54 // Move the web contents to the foreground. |
| 53 web_contents->Activate(); | 55 web_contents->Activate(); |
| 54 | 56 |
| 55 return ServiceWorkerProviderHost::GetWindowClientInfoOnUI(render_process_id, | 57 return ServiceWorkerProviderHost::GetWindowClientInfoOnUI(render_process_id, |
| 56 render_frame_id); | 58 render_frame_id); |
| 57 } | 59 } |
| 58 | 60 |
| 59 } // anonymous namespace | 61 } // anonymous namespace |
| 60 | 62 |
| 63 // PlzNavigate: |
| 64 int ServiceWorkerProviderHost::kVirtualProcessIDForNavigationRequest = -2; |
| 65 |
| 61 ServiceWorkerProviderHost::OneShotGetReadyCallback::OneShotGetReadyCallback( | 66 ServiceWorkerProviderHost::OneShotGetReadyCallback::OneShotGetReadyCallback( |
| 62 const GetRegistrationForReadyCallback& callback) | 67 const GetRegistrationForReadyCallback& callback) |
| 63 : callback(callback), | 68 : callback(callback), |
| 64 called(false) { | 69 called(false) { |
| 65 } | 70 } |
| 66 | 71 |
| 67 ServiceWorkerProviderHost::OneShotGetReadyCallback::~OneShotGetReadyCallback() { | 72 ServiceWorkerProviderHost::OneShotGetReadyCallback::~OneShotGetReadyCallback() { |
| 68 } | 73 } |
| 69 | 74 |
| 70 ServiceWorkerProviderHost::ServiceWorkerProviderHost( | 75 ServiceWorkerProviderHost::ServiceWorkerProviderHost( |
| 71 int render_process_id, | 76 int render_process_id, |
| 72 int route_id, | 77 int route_id, |
| 73 int provider_id, | 78 int provider_id, |
| 74 ServiceWorkerProviderType provider_type, | 79 ServiceWorkerProviderType provider_type, |
| 75 base::WeakPtr<ServiceWorkerContextCore> context, | 80 base::WeakPtr<ServiceWorkerContextCore> context, |
| 76 ServiceWorkerDispatcherHost* dispatcher_host) | 81 ServiceWorkerDispatcherHost* dispatcher_host) |
| 77 : client_uuid_(base::GenerateGUID()), | 82 : client_uuid_(base::GenerateGUID()), |
| 78 render_process_id_(render_process_id), | 83 render_process_id_(render_process_id), |
| 79 route_id_(route_id), | 84 route_id_(route_id), |
| 80 render_thread_id_(kDocumentMainThreadId), | 85 render_thread_id_(kDocumentMainThreadId), |
| 81 provider_id_(provider_id), | 86 provider_id_(provider_id), |
| 82 provider_type_(provider_type), | 87 provider_type_(provider_type), |
| 83 context_(context), | 88 context_(context), |
| 84 dispatcher_host_(dispatcher_host), | 89 dispatcher_host_(dispatcher_host), |
| 85 allow_association_(true) { | 90 allow_association_(true) { |
| 86 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, render_process_id_); | 91 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, render_process_id_); |
| 87 DCHECK_NE(SERVICE_WORKER_PROVIDER_UNKNOWN, provider_type_); | 92 DCHECK_NE(SERVICE_WORKER_PROVIDER_UNKNOWN, provider_type_); |
| 88 DCHECK_NE(SERVICE_WORKER_PROVIDER_FOR_SANDBOXED_FRAME, provider_type_); | 93 DCHECK_NE(SERVICE_WORKER_PROVIDER_FOR_SANDBOXED_FRAME, provider_type_); |
| 94 |
| 95 // PlzNavigate: |
| 96 if (render_process_id == kVirtualProcessIDForNavigationRequest) { |
| 97 CHECK(base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 98 switches::kEnableBrowserSideNavigation)); |
| 99 } |
| 89 if (provider_type_ == SERVICE_WORKER_PROVIDER_FOR_CONTROLLER) { | 100 if (provider_type_ == SERVICE_WORKER_PROVIDER_FOR_CONTROLLER) { |
| 90 // Actual thread id is set when the service worker context gets started. | 101 // Actual thread id is set when the service worker context gets started. |
| 91 render_thread_id_ = kInvalidEmbeddedWorkerThreadId; | 102 render_thread_id_ = kInvalidEmbeddedWorkerThreadId; |
| 92 } | 103 } |
| 93 context_->RegisterProviderHostByClientID(client_uuid_, this); | 104 context_->RegisterProviderHostByClientID(client_uuid_, this); |
| 94 } | 105 } |
| 95 | 106 |
| 96 ServiceWorkerProviderHost::~ServiceWorkerProviderHost() { | 107 ServiceWorkerProviderHost::~ServiceWorkerProviderHost() { |
| 97 if (context_) | 108 if (context_) |
| 98 context_->UnregisterProviderHostByClientID(client_uuid_); | 109 context_->UnregisterProviderHostByClientID(client_uuid_); |
| (...skipping 409 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 508 provider_type_ = SERVICE_WORKER_PROVIDER_UNKNOWN; | 519 provider_type_ = SERVICE_WORKER_PROVIDER_UNKNOWN; |
| 509 dispatcher_host_ = nullptr; | 520 dispatcher_host_ = nullptr; |
| 510 } | 521 } |
| 511 | 522 |
| 512 void ServiceWorkerProviderHost::CompleteCrossSiteTransfer( | 523 void ServiceWorkerProviderHost::CompleteCrossSiteTransfer( |
| 513 int new_process_id, | 524 int new_process_id, |
| 514 int new_frame_id, | 525 int new_frame_id, |
| 515 int new_provider_id, | 526 int new_provider_id, |
| 516 ServiceWorkerProviderType new_provider_type, | 527 ServiceWorkerProviderType new_provider_type, |
| 517 ServiceWorkerDispatcherHost* new_dispatcher_host) { | 528 ServiceWorkerDispatcherHost* new_dispatcher_host) { |
| 518 DCHECK_EQ(ChildProcessHost::kInvalidUniqueID, render_process_id_); | 529 DCHECK(render_process_id_ == ChildProcessHost::kInvalidUniqueID || |
| 530 render_process_id_ == kVirtualProcessIDForNavigationRequest); |
| 519 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, new_process_id); | 531 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, new_process_id); |
| 520 DCHECK_NE(MSG_ROUTING_NONE, new_frame_id); | 532 DCHECK_NE(MSG_ROUTING_NONE, new_frame_id); |
| 521 | 533 |
| 522 render_process_id_ = new_process_id; | 534 render_process_id_ = new_process_id; |
| 523 route_id_ = new_frame_id; | 535 route_id_ = new_frame_id; |
| 524 render_thread_id_ = kDocumentMainThreadId; | 536 render_thread_id_ = kDocumentMainThreadId; |
| 525 provider_id_ = new_provider_id; | 537 provider_id_ = new_provider_id; |
| 526 provider_type_ = new_provider_type; | 538 provider_type_ = new_provider_type; |
| 527 dispatcher_host_ = new_dispatcher_host; | 539 dispatcher_host_ = new_dispatcher_host; |
| 528 | 540 |
| (...skipping 152 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 681 return context_ != NULL; | 693 return context_ != NULL; |
| 682 } | 694 } |
| 683 | 695 |
| 684 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { | 696 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { |
| 685 DCHECK(dispatcher_host_); | 697 DCHECK(dispatcher_host_); |
| 686 DCHECK(IsReadyToSendMessages()); | 698 DCHECK(IsReadyToSendMessages()); |
| 687 dispatcher_host_->Send(message); | 699 dispatcher_host_->Send(message); |
| 688 } | 700 } |
| 689 | 701 |
| 690 } // namespace content | 702 } // namespace content |
| OLD | NEW |