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

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

Issue 2943463002: Implement dumb URLLoader{Factory} for ServiceWorker script loading (Closed)
Patch Set: rebased Created 3 years, 6 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
(...skipping 15 matching lines...) Expand all
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_dispatcher_host.h"
28 #include "content/browser/service_worker/service_worker_info.h" 28 #include "content/browser/service_worker/service_worker_info.h"
29 #include "content/browser/service_worker/service_worker_job_coordinator.h" 29 #include "content/browser/service_worker/service_worker_job_coordinator.h"
30 #include "content/browser/service_worker/service_worker_process_manager.h" 30 #include "content/browser/service_worker/service_worker_process_manager.h"
31 #include "content/browser/service_worker/service_worker_provider_host.h" 31 #include "content/browser/service_worker/service_worker_provider_host.h"
32 #include "content/browser/service_worker/service_worker_register_job.h" 32 #include "content/browser/service_worker/service_worker_register_job.h"
33 #include "content/browser/service_worker/service_worker_registration.h" 33 #include "content/browser/service_worker/service_worker_registration.h"
34 #include "content/browser/service_worker/service_worker_storage.h" 34 #include "content/browser/service_worker/service_worker_storage.h"
35 #include "content/browser/service_worker/service_worker_version.h" 35 #include "content/browser/service_worker/service_worker_version.h"
36 #include "content/browser/url_loader_factory_getter.h"
36 #include "content/common/service_worker/service_worker_utils.h" 37 #include "content/common/service_worker/service_worker_utils.h"
37 #include "content/public/browser/browser_thread.h" 38 #include "content/public/browser/browser_thread.h"
38 #include "ipc/ipc_message.h" 39 #include "ipc/ipc_message.h"
39 #include "net/http/http_response_headers.h" 40 #include "net/http/http_response_headers.h"
40 #include "net/http/http_response_info.h" 41 #include "net/http/http_response_info.h"
42 #include "storage/browser/blob/blob_storage_context.h"
41 #include "storage/browser/quota/quota_manager_proxy.h" 43 #include "storage/browser/quota/quota_manager_proxy.h"
42 #include "url/gurl.h" 44 #include "url/gurl.h"
43 45
44 namespace content { 46 namespace content {
45 namespace { 47 namespace {
46 48
47 void CheckFetchHandlerOfInstalledServiceWorker( 49 void CheckFetchHandlerOfInstalledServiceWorker(
48 const ServiceWorkerContext::CheckHasServiceWorkerCallback callback, 50 const ServiceWorkerContext::CheckHasServiceWorkerCallback callback,
49 scoped_refptr<ServiceWorkerRegistration> registration) { 51 scoped_refptr<ServiceWorkerRegistration> registration) {
50 // Waiting Service Worker is a newer version, prefer that if available. 52 // Waiting Service Worker is a newer version, prefer that if available.
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after
232 } 234 }
233 return false; 235 return false;
234 } 236 }
235 237
236 ServiceWorkerContextCore::ServiceWorkerContextCore( 238 ServiceWorkerContextCore::ServiceWorkerContextCore(
237 const base::FilePath& path, 239 const base::FilePath& path,
238 std::unique_ptr<ServiceWorkerDatabaseTaskManager> database_task_manager, 240 std::unique_ptr<ServiceWorkerDatabaseTaskManager> database_task_manager,
239 const scoped_refptr<base::SingleThreadTaskRunner>& disk_cache_thread, 241 const scoped_refptr<base::SingleThreadTaskRunner>& disk_cache_thread,
240 storage::QuotaManagerProxy* quota_manager_proxy, 242 storage::QuotaManagerProxy* quota_manager_proxy,
241 storage::SpecialStoragePolicy* special_storage_policy, 243 storage::SpecialStoragePolicy* special_storage_policy,
244 base::WeakPtr<storage::BlobStorageContext> blob_storage_context,
245 URLLoaderFactoryGetter* url_loader_factory_getter,
242 base::ObserverListThreadSafe<ServiceWorkerContextCoreObserver>* 246 base::ObserverListThreadSafe<ServiceWorkerContextCoreObserver>*
243 observer_list, 247 observer_list,
244 ServiceWorkerContextWrapper* wrapper) 248 ServiceWorkerContextWrapper* wrapper)
245 : wrapper_(wrapper), 249 : wrapper_(wrapper),
246 providers_(base::MakeUnique<ProcessToProviderMap>()), 250 providers_(base::MakeUnique<ProcessToProviderMap>()),
247 provider_by_uuid_(base::MakeUnique<ProviderByClientUUIDMap>()), 251 provider_by_uuid_(base::MakeUnique<ProviderByClientUUIDMap>()),
252 blob_storage_context_(std::move(blob_storage_context)),
253 loader_factory_getter_(url_loader_factory_getter),
248 force_update_on_page_load_(false), 254 force_update_on_page_load_(false),
249 next_handle_id_(0), 255 next_handle_id_(0),
250 next_registration_handle_id_(0), 256 next_registration_handle_id_(0),
251 was_service_worker_registered_(false), 257 was_service_worker_registered_(false),
252 observer_list_(observer_list), 258 observer_list_(observer_list),
253 weak_factory_(this) { 259 weak_factory_(this) {
254 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_ 260 // These get a WeakPtr from weak_factory_, so must be set after weak_factory_
255 // is initialized. 261 // is initialized.
256 storage_ = ServiceWorkerStorage::Create( 262 storage_ = ServiceWorkerStorage::Create(
257 path, AsWeakPtr(), std::move(database_task_manager), disk_cache_thread, 263 path, AsWeakPtr(), std::move(database_task_manager), disk_cache_thread,
(...skipping 663 matching lines...) Expand 10 before | Expand all | Expand 10 after
921 int service_worker_provider_id, 927 int service_worker_provider_id,
922 mojom::ServiceWorkerWorkerClientAssociatedPtrInfo client_ptr_info) { 928 mojom::ServiceWorkerWorkerClientAssociatedPtrInfo client_ptr_info) {
923 ServiceWorkerProviderHost* provider_host = 929 ServiceWorkerProviderHost* provider_host =
924 GetProviderHost(render_process_id, service_worker_provider_id); 930 GetProviderHost(render_process_id, service_worker_provider_id);
925 if (!provider_host) 931 if (!provider_host)
926 return; 932 return;
927 provider_host->BindWorkerFetchContext(std::move(client_ptr_info)); 933 provider_host->BindWorkerFetchContext(std::move(client_ptr_info));
928 } 934 }
929 935
930 } // namespace content 936 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698