Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(124)

Side by Side Diff: content/browser/service_worker/service_worker_context_core.cc

Issue 2638313002: Manage ServiceWorkerDispatcherHost in ServiceWorkerContextCore (Closed)
Patch Set: Add a newline Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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_context_core.h" 5 #include "content/browser/service_worker/service_worker_context_core.h"
6 6
7 #include <limits> 7 #include <limits>
8 #include <set> 8 #include <set>
9 #include <utility> 9 #include <utility>
10 10
11 #include "base/barrier_closure.h" 11 #include "base/barrier_closure.h"
12 #include "base/bind.h" 12 #include "base/bind.h"
13 #include "base/bind_helpers.h" 13 #include "base/bind_helpers.h"
14 #include "base/files/file_path.h" 14 #include "base/files/file_path.h"
15 #include "base/location.h" 15 #include "base/location.h"
16 #include "base/macros.h" 16 #include "base/macros.h"
17 #include "base/memory/ptr_util.h" 17 #include "base/memory/ptr_util.h"
18 #include "base/single_thread_task_runner.h" 18 #include "base/single_thread_task_runner.h"
19 #include "base/strings/string_util.h" 19 #include "base/strings/string_util.h"
20 #include "base/threading/thread_task_runner_handle.h" 20 #include "base/threading/thread_task_runner_handle.h"
21 #include "content/browser/frame_host/render_frame_host_impl.h" 21 #include "content/browser/frame_host/render_frame_host_impl.h"
22 #include "content/browser/service_worker/embedded_worker_registry.h" 22 #include "content/browser/service_worker/embedded_worker_registry.h"
23 #include "content/browser/service_worker/embedded_worker_status.h" 23 #include "content/browser/service_worker/embedded_worker_status.h"
24 #include "content/browser/service_worker/service_worker_context_observer.h" 24 #include "content/browser/service_worker/service_worker_context_observer.h"
25 #include "content/browser/service_worker/service_worker_context_wrapper.h" 25 #include "content/browser/service_worker/service_worker_context_wrapper.h"
26 #include "content/browser/service_worker/service_worker_database_task_manager.h" 26 #include "content/browser/service_worker/service_worker_database_task_manager.h"
27 #include "content/browser/service_worker/service_worker_dispatcher_host.h"
27 #include "content/browser/service_worker/service_worker_info.h" 28 #include "content/browser/service_worker/service_worker_info.h"
28 #include "content/browser/service_worker/service_worker_job_coordinator.h" 29 #include "content/browser/service_worker/service_worker_job_coordinator.h"
29 #include "content/browser/service_worker/service_worker_process_manager.h" 30 #include "content/browser/service_worker/service_worker_process_manager.h"
30 #include "content/browser/service_worker/service_worker_provider_host.h" 31 #include "content/browser/service_worker/service_worker_provider_host.h"
31 #include "content/browser/service_worker/service_worker_register_job.h" 32 #include "content/browser/service_worker/service_worker_register_job.h"
32 #include "content/browser/service_worker/service_worker_registration.h" 33 #include "content/browser/service_worker/service_worker_registration.h"
33 #include "content/browser/service_worker/service_worker_storage.h" 34 #include "content/browser/service_worker/service_worker_storage.h"
34 #include "content/common/service_worker/service_worker_utils.h" 35 #include "content/common/service_worker/service_worker_utils.h"
35 #include "content/public/browser/browser_thread.h" 36 #include "content/public/browser/browser_thread.h"
36 #include "ipc/ipc_message.h" 37 #include "ipc/ipc_message.h"
(...skipping 176 matching lines...) Expand 10 before | Expand all | Expand 10 after
213 214
214 ServiceWorkerContextCore::ServiceWorkerContextCore( 215 ServiceWorkerContextCore::ServiceWorkerContextCore(
215 const base::FilePath& path, 216 const base::FilePath& path,
216 std::unique_ptr<ServiceWorkerDatabaseTaskManager> database_task_manager, 217 std::unique_ptr<ServiceWorkerDatabaseTaskManager> database_task_manager,
217 const scoped_refptr<base::SingleThreadTaskRunner>& disk_cache_thread, 218 const scoped_refptr<base::SingleThreadTaskRunner>& disk_cache_thread,
218 storage::QuotaManagerProxy* quota_manager_proxy, 219 storage::QuotaManagerProxy* quota_manager_proxy,
219 storage::SpecialStoragePolicy* special_storage_policy, 220 storage::SpecialStoragePolicy* special_storage_policy,
220 base::ObserverListThreadSafe<ServiceWorkerContextObserver>* observer_list, 221 base::ObserverListThreadSafe<ServiceWorkerContextObserver>* observer_list,
221 ServiceWorkerContextWrapper* wrapper) 222 ServiceWorkerContextWrapper* wrapper)
222 : wrapper_(wrapper), 223 : wrapper_(wrapper),
223 providers_(new ProcessToProviderMap), 224 dispatcher_hosts_(base::MakeUnique<DispatcherHostMap>()),
224 provider_by_uuid_(new ProviderByClientUUIDMap), 225 providers_(base::MakeUnique<ProcessToProviderMap>()),
226 provider_by_uuid_(base::MakeUnique<ProviderByClientUUIDMap>()),
225 force_update_on_page_load_(false), 227 force_update_on_page_load_(false),
226 next_handle_id_(0), 228 next_handle_id_(0),
227 next_registration_handle_id_(0), 229 next_registration_handle_id_(0),
228 was_service_worker_registered_(false), 230 was_service_worker_registered_(false),
229 observer_list_(observer_list), 231 observer_list_(observer_list),
230 weak_factory_(this) { 232 weak_factory_(this) {
231 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_ 233 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_
232 // is initialized. 234 // is initialized.
233 storage_ = ServiceWorkerStorage::Create( 235 storage_ = ServiceWorkerStorage::Create(
234 path, AsWeakPtr(), std::move(database_task_manager), disk_cache_thread, 236 path, AsWeakPtr(), std::move(database_task_manager), disk_cache_thread,
235 quota_manager_proxy, special_storage_policy); 237 quota_manager_proxy, special_storage_policy);
236 embedded_worker_registry_ = EmbeddedWorkerRegistry::Create(AsWeakPtr()); 238 embedded_worker_registry_ = EmbeddedWorkerRegistry::Create(AsWeakPtr());
237 job_coordinator_.reset(new ServiceWorkerJobCoordinator(AsWeakPtr())); 239 job_coordinator_.reset(new ServiceWorkerJobCoordinator(AsWeakPtr()));
238 } 240 }
239 241
240 ServiceWorkerContextCore::ServiceWorkerContextCore( 242 ServiceWorkerContextCore::ServiceWorkerContextCore(
241 ServiceWorkerContextCore* old_context, 243 ServiceWorkerContextCore* old_context,
242 ServiceWorkerContextWrapper* wrapper) 244 ServiceWorkerContextWrapper* wrapper)
243 : wrapper_(wrapper), 245 : wrapper_(wrapper),
246 dispatcher_hosts_(old_context->dispatcher_hosts_.release()),
244 providers_(old_context->providers_.release()), 247 providers_(old_context->providers_.release()),
245 provider_by_uuid_(old_context->provider_by_uuid_.release()), 248 provider_by_uuid_(old_context->provider_by_uuid_.release()),
246 next_handle_id_(old_context->next_handle_id_), 249 next_handle_id_(old_context->next_handle_id_),
247 next_registration_handle_id_(old_context->next_registration_handle_id_), 250 next_registration_handle_id_(old_context->next_registration_handle_id_),
248 was_service_worker_registered_( 251 was_service_worker_registered_(
249 old_context->was_service_worker_registered_), 252 old_context->was_service_worker_registered_),
250 observer_list_(old_context->observer_list_), 253 observer_list_(old_context->observer_list_),
251 weak_factory_(this) { 254 weak_factory_(this) {
252 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_ 255 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_
253 // is initialized. 256 // is initialized.
254 storage_ = ServiceWorkerStorage::Create(AsWeakPtr(), old_context->storage()); 257 storage_ = ServiceWorkerStorage::Create(AsWeakPtr(), old_context->storage());
255 embedded_worker_registry_ = EmbeddedWorkerRegistry::Create( 258 embedded_worker_registry_ = EmbeddedWorkerRegistry::Create(
256 AsWeakPtr(), 259 AsWeakPtr(),
257 old_context->embedded_worker_registry()); 260 old_context->embedded_worker_registry());
258 job_coordinator_.reset(new ServiceWorkerJobCoordinator(AsWeakPtr())); 261 job_coordinator_.reset(new ServiceWorkerJobCoordinator(AsWeakPtr()));
259 } 262 }
260 263
261 ServiceWorkerContextCore::~ServiceWorkerContextCore() { 264 ServiceWorkerContextCore::~ServiceWorkerContextCore() {
262 DCHECK(storage_); 265 DCHECK(storage_);
263 for (VersionMap::iterator it = live_versions_.begin(); 266 for (VersionMap::iterator it = live_versions_.begin();
264 it != live_versions_.end(); 267 it != live_versions_.end();
265 ++it) { 268 ++it) {
266 it->second->RemoveListener(this); 269 it->second->RemoveListener(this);
267 } 270 }
268 weak_factory_.InvalidateWeakPtrs(); 271 weak_factory_.InvalidateWeakPtrs();
269 } 272 }
270 273
271 ServiceWorkerProviderHost* ServiceWorkerContextCore::GetProviderHost( 274 void ServiceWorkerContextCore::AddDispatcherHost(
272 int process_id, int provider_id) { 275 int process_id,
273 ProviderMap* map = GetProviderMapForProcess(process_id); 276 content::ServiceWorkerDispatcherHost* dispatcher_host) {
274 if (!map) 277 DCHECK(!dispatcher_hosts_->Lookup(process_id));
275 return NULL; 278 dispatcher_hosts_->AddWithID(dispatcher_host, process_id);
276 return map->Lookup(provider_id); 279 embedded_worker_registry()->AddChildProcessSender(
280 process_id, dispatcher_host,
281 dispatcher_host->message_port_message_filter());
falken 2017/01/26 05:15:42 Why does ServiceWorkerContextCore need dispatcher_
shimazu 2017/01/26 09:27:22 It's because I'm planning to use SWDispatcherHost
282 }
283
284 void ServiceWorkerContextCore::RemoveDispatcherHost(int process_id) {
285 DCHECK(dispatcher_hosts_->Lookup(process_id));
286 RemoveAllProviderHostsForProcess(process_id);
287 embedded_worker_registry_->RemoveChildProcessSender(process_id);
288 dispatcher_hosts_->Remove(process_id);
277 } 289 }
278 290
279 void ServiceWorkerContextCore::AddProviderHost( 291 void ServiceWorkerContextCore::AddProviderHost(
280 std::unique_ptr<ServiceWorkerProviderHost> host) { 292 std::unique_ptr<ServiceWorkerProviderHost> host) {
281 int process_id = host->process_id(); 293 int process_id = host->process_id();
282 int provider_id = host->provider_id(); 294 int provider_id = host->provider_id();
283 ProviderMap* map = GetProviderMapForProcess(process_id); 295 ProviderMap* map = GetProviderMapForProcess(process_id);
284 if (!map) { 296 if (!map) {
285 providers_->AddWithID(base::MakeUnique<ProviderMap>(), process_id); 297 providers_->AddWithID(base::MakeUnique<ProviderMap>(), process_id);
286 map = GetProviderMapForProcess(process_id); 298 map = GetProviderMapForProcess(process_id);
287 } 299 }
288 map->AddWithID(std::move(host), provider_id); 300 map->AddWithID(std::move(host), provider_id);
289 } 301 }
290 302
303 void ServiceWorkerContextCore::AddProviderHost(
304 int process_id,
305 content::ServiceWorkerProviderHostInfo provider_host_info) {
306 ServiceWorkerDispatcherHost* dispatcher_host =
307 dispatcher_hosts_->Lookup(process_id);
308 DCHECK(dispatcher_host);
309 AddProviderHost(ServiceWorkerProviderHost::Create(
310 process_id, std::move(provider_host_info), AsWeakPtr(), dispatcher_host));
311 }
312
313 ServiceWorkerProviderHost* ServiceWorkerContextCore::GetProviderHost(
314 int process_id,
315 int provider_id) {
316 ProviderMap* map = GetProviderMapForProcess(process_id);
317 if (!map)
318 return NULL;
319 return map->Lookup(provider_id);
320 }
321
291 void ServiceWorkerContextCore::RemoveProviderHost( 322 void ServiceWorkerContextCore::RemoveProviderHost(
292 int process_id, int provider_id) { 323 int process_id, int provider_id) {
293 ProviderMap* map = GetProviderMapForProcess(process_id); 324 ProviderMap* map = GetProviderMapForProcess(process_id);
294 DCHECK(map); 325 DCHECK(map);
295 map->Remove(provider_id); 326 map->Remove(provider_id);
296 } 327 }
297 328
298 void ServiceWorkerContextCore::RemoveAllProviderHostsForProcess( 329 void ServiceWorkerContextCore::RemoveAllProviderHostsForProcess(
299 int process_id) { 330 int process_id) {
300 if (providers_->Lookup(process_id)) 331 if (providers_->Lookup(process_id))
(...skipping 328 matching lines...) Expand 10 before | Expand all | Expand 10 after
629 job_coordinator_->AbortAll(); 660 job_coordinator_->AbortAll();
630 storage_->DeleteAndStartOver(callback); 661 storage_->DeleteAndStartOver(callback);
631 } 662 }
632 663
633 std::unique_ptr<ServiceWorkerProviderHost> 664 std::unique_ptr<ServiceWorkerProviderHost>
634 ServiceWorkerContextCore::TransferProviderHostOut(int process_id, 665 ServiceWorkerContextCore::TransferProviderHostOut(int process_id,
635 int provider_id) { 666 int provider_id) {
636 ProviderMap* map = GetProviderMapForProcess(process_id); 667 ProviderMap* map = GetProviderMapForProcess(process_id);
637 ServiceWorkerProviderHost* transferee = map->Lookup(provider_id); 668 ServiceWorkerProviderHost* transferee = map->Lookup(provider_id);
638 std::unique_ptr<ServiceWorkerProviderHost> replacement = 669 std::unique_ptr<ServiceWorkerProviderHost> replacement =
639 base::MakeUnique<ServiceWorkerProviderHost>( 670 transferee->PrepareForCrossSiteTransfer();
640 process_id, transferee->frame_id(), provider_id,
641 transferee->provider_type(),
642 transferee->is_parent_frame_secure()
643 ? ServiceWorkerProviderHost::FrameSecurityLevel::SECURE
644 : ServiceWorkerProviderHost::FrameSecurityLevel::INSECURE,
645 AsWeakPtr(), transferee->dispatcher_host());
646 transferee->PrepareForCrossSiteTransfer();
647 return map->Replace(provider_id, std::move(replacement)); 671 return map->Replace(provider_id, std::move(replacement));
648 } 672 }
649 673
650 void ServiceWorkerContextCore::TransferProviderHostIn( 674 void ServiceWorkerContextCore::TransferProviderHostIn(
651 int new_process_id, 675 int new_process_id,
652 int new_provider_id, 676 int new_provider_id,
653 std::unique_ptr<ServiceWorkerProviderHost> transferee) { 677 std::unique_ptr<ServiceWorkerProviderHost> transferee) {
654 ProviderMap* map = GetProviderMapForProcess(new_process_id); 678 ProviderMap* map = GetProviderMapForProcess(new_process_id);
655 ServiceWorkerProviderHost* temp = map->Lookup(new_provider_id); 679 ServiceWorkerProviderHost* temp = map->Lookup(new_provider_id);
656 if (!temp) 680 if (!temp)
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after
864 } 888 }
865 889
866 void ServiceWorkerContextCore::OnRegistrationFinishedForCheckHasServiceWorker( 890 void ServiceWorkerContextCore::OnRegistrationFinishedForCheckHasServiceWorker(
867 const ServiceWorkerContext::CheckHasServiceWorkerCallback callback, 891 const ServiceWorkerContext::CheckHasServiceWorkerCallback callback,
868 scoped_refptr<ServiceWorkerRegistration> registration) { 892 scoped_refptr<ServiceWorkerRegistration> registration) {
869 callback.Run(registration->active_version() || 893 callback.Run(registration->active_version() ||
870 registration->waiting_version()); 894 registration->waiting_version());
871 } 895 }
872 896
873 } // namespace content 897 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698