Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/background_fetch/background_fetch_context.h" | 5 #include "content/browser/background_fetch/background_fetch_context.h" |
| 6 | 6 |
| 7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
| 8 #include "content/browser/background_fetch/background_fetch_data_manager.h" | 8 #include "content/browser/background_fetch/background_fetch_data_manager.h" |
| 9 #include "content/browser/background_fetch/background_fetch_event_dispatcher.h" | |
| 9 #include "content/browser/background_fetch/background_fetch_job_controller.h" | 10 #include "content/browser/background_fetch/background_fetch_job_controller.h" |
| 10 #include "content/browser/background_fetch/background_fetch_registration_id.h" | 11 #include "content/browser/background_fetch/background_fetch_registration_id.h" |
| 11 #include "content/browser/service_worker/service_worker_context_wrapper.h" | 12 #include "content/browser/service_worker/service_worker_context_wrapper.h" |
| 12 #include "content/browser/storage_partition_impl.h" | 13 #include "content/browser/storage_partition_impl.h" |
| 14 #include "content/public/browser/blob_handle.h" | |
| 13 #include "content/public/browser/browser_context.h" | 15 #include "content/public/browser/browser_context.h" |
| 14 #include "net/url_request/url_request_context_getter.h" | 16 #include "net/url_request/url_request_context_getter.h" |
| 15 #include "url/origin.h" | 17 #include "url/origin.h" |
| 16 | 18 |
| 17 namespace content { | 19 namespace content { |
| 18 | 20 |
| 21 namespace { | |
| 22 | |
| 23 // Records the |error| status issued by the DataManager after it was requested | |
| 24 // to create and store a new Background Fetch registration. | |
| 25 void RecordRegistrationCreatedError(blink::mojom::BackgroundFetchError error) { | |
| 26 // TODO(peter): Add UMA. | |
| 27 } | |
| 28 | |
| 29 // Records the |error| status issued by the DataManager after the storage | |
| 30 // associated with a registration has been completely deleted. | |
| 31 void RecordRegistrationDeletedError(blink::mojom::BackgroundFetchError error) { | |
| 32 // TODO(peter): Add UMA. | |
| 33 } | |
| 34 | |
| 35 } // namespace | |
| 36 | |
| 19 BackgroundFetchContext::BackgroundFetchContext( | 37 BackgroundFetchContext::BackgroundFetchContext( |
| 20 BrowserContext* browser_context, | 38 BrowserContext* browser_context, |
| 21 StoragePartitionImpl* storage_partition, | 39 StoragePartitionImpl* storage_partition, |
| 22 const scoped_refptr<ServiceWorkerContextWrapper>& service_worker_context) | 40 scoped_refptr<ServiceWorkerContextWrapper> service_worker_context) |
| 23 : browser_context_(browser_context), | 41 : browser_context_(browser_context), |
| 24 service_worker_context_(service_worker_context), | 42 data_manager_( |
| 25 background_fetch_data_manager_( | 43 base::MakeUnique<BackgroundFetchDataManager>(browser_context)), |
| 26 base::MakeUnique<BackgroundFetchDataManager>(browser_context)) { | 44 event_dispatcher_(base::MakeUnique<BackgroundFetchEventDispatcher>( |
| 45 std::move(service_worker_context))) { | |
| 27 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 46 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 28 download_manager_ = BrowserContext::GetDownloadManager(browser_context_); | 47 download_manager_ = BrowserContext::GetDownloadManager(browser_context_); |
| 29 request_context_ = | 48 request_context_ = |
| 30 make_scoped_refptr(storage_partition->GetURLRequestContext()); | 49 make_scoped_refptr(storage_partition->GetURLRequestContext()); |
| 31 } | 50 } |
| 32 | 51 |
| 33 BackgroundFetchContext::~BackgroundFetchContext() { | 52 BackgroundFetchContext::~BackgroundFetchContext() { |
| 34 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 53 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 35 } | 54 } |
| 36 | 55 |
| 37 void BackgroundFetchContext::Shutdown() { | 56 void BackgroundFetchContext::Shutdown() { |
| 38 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 57 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 39 BrowserThread::PostTask( | 58 BrowserThread::PostTask( |
| 40 BrowserThread::IO, FROM_HERE, | 59 BrowserThread::IO, FROM_HERE, |
| 41 base::Bind(&BackgroundFetchContext::ShutdownOnIO, this)); | 60 base::Bind(&BackgroundFetchContext::ShutdownOnIO, this)); |
| 42 } | 61 } |
| 43 | 62 |
| 44 void BackgroundFetchContext::ShutdownOnIO() { | 63 void BackgroundFetchContext::ShutdownOnIO() { |
| 45 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 64 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 46 active_fetches_.clear(); | 65 active_fetches_.clear(); |
| 47 } | 66 } |
| 48 | 67 |
| 49 void BackgroundFetchContext::StartFetch( | 68 void BackgroundFetchContext::StartFetch( |
| 50 const BackgroundFetchRegistrationId& registration_id, | 69 const BackgroundFetchRegistrationId& registration_id, |
| 51 const std::vector<ServiceWorkerFetchRequest>& requests, | 70 const std::vector<ServiceWorkerFetchRequest>& requests, |
| 52 const BackgroundFetchOptions& options, | 71 const BackgroundFetchOptions& options, |
| 53 const blink::mojom::BackgroundFetchService::FetchCallback& callback) { | 72 const blink::mojom::BackgroundFetchService::FetchCallback& callback) { |
| 54 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 73 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 55 background_fetch_data_manager_->CreateRegistration( | 74 data_manager_->CreateRegistration( |
| 56 registration_id, requests, options, | 75 registration_id, requests, options, |
| 57 base::BindOnce(&BackgroundFetchContext::DidCreateRegistration, this, | 76 base::BindOnce(&BackgroundFetchContext::DidCreateRegistration, this, |
| 58 registration_id, options, callback)); | 77 registration_id, options, callback)); |
| 59 } | 78 } |
| 60 | 79 |
| 61 void BackgroundFetchContext::DidCreateRegistration( | 80 void BackgroundFetchContext::DidCreateRegistration( |
| 62 const BackgroundFetchRegistrationId& registration_id, | 81 const BackgroundFetchRegistrationId& registration_id, |
| 63 const BackgroundFetchOptions& options, | 82 const BackgroundFetchOptions& options, |
| 64 const blink::mojom::BackgroundFetchService::FetchCallback& callback, | 83 const blink::mojom::BackgroundFetchService::FetchCallback& callback, |
| 65 blink::mojom::BackgroundFetchError error, | 84 blink::mojom::BackgroundFetchError error, |
| 66 std::vector<BackgroundFetchRequestInfo> initial_requests) { | 85 std::vector<BackgroundFetchRequestInfo> initial_requests) { |
| 86 RecordRegistrationCreatedError(error); | |
| 67 if (error != blink::mojom::BackgroundFetchError::NONE) { | 87 if (error != blink::mojom::BackgroundFetchError::NONE) { |
| 68 callback.Run(error, base::nullopt /* registration */); | 88 callback.Run(error, base::nullopt /* registration */); |
| 69 return; | 89 return; |
| 70 } | 90 } |
| 71 | 91 |
| 72 // Create the BackgroundFetchJobController, which will do the actual fetching. | 92 // Create the BackgroundFetchJobController, which will do the actual fetching. |
| 73 CreateController(registration_id, options, std::move(initial_requests)); | 93 CreateController(registration_id, options, std::move(initial_requests)); |
| 74 | 94 |
| 75 // Create the BackgroundFetchRegistration the renderer process will receive, | 95 // Create the BackgroundFetchRegistration the renderer process will receive, |
| 76 // which enables it to resolve the promise telling the developer it worked. | 96 // which enables it to resolve the promise telling the developer it worked. |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 119 | 139 |
| 120 return controller; | 140 return controller; |
| 121 } | 141 } |
| 122 | 142 |
| 123 void BackgroundFetchContext::CreateController( | 143 void BackgroundFetchContext::CreateController( |
| 124 const BackgroundFetchRegistrationId& registration_id, | 144 const BackgroundFetchRegistrationId& registration_id, |
| 125 const BackgroundFetchOptions& options, | 145 const BackgroundFetchOptions& options, |
| 126 std::vector<BackgroundFetchRequestInfo> initial_requests) { | 146 std::vector<BackgroundFetchRequestInfo> initial_requests) { |
| 127 std::unique_ptr<BackgroundFetchJobController> controller = | 147 std::unique_ptr<BackgroundFetchJobController> controller = |
| 128 base::MakeUnique<BackgroundFetchJobController>( | 148 base::MakeUnique<BackgroundFetchJobController>( |
| 129 registration_id, options, background_fetch_data_manager_.get(), | 149 registration_id, options, data_manager_.get(), download_manager_, |
| 130 download_manager_, request_context_, | 150 request_context_, |
| 131 base::BindOnce(&BackgroundFetchContext::DidCompleteJob, this)); | 151 base::BindOnce(&BackgroundFetchContext::DidCompleteJob, this)); |
| 132 | 152 |
| 133 // TODO(peter): We should actually be able to use Background Fetch in layout | 153 // TODO(peter): We should actually be able to use Background Fetch in layout |
| 134 // tests. That requires a download manager and a request context. | 154 // tests. That requires a download manager and a request context. |
| 135 if (download_manager_ && request_context_) { | 155 if (download_manager_ && request_context_) { |
| 136 // Start fetching the |initial_requests| immediately. At some point in the | 156 // Start fetching the |initial_requests| immediately. At some point in the |
| 137 // future we may want a more elaborate scheduling mechanism here. | 157 // future we may want a more elaborate scheduling mechanism here. |
| 138 controller->Start(std::move(initial_requests)); | 158 controller->Start(std::move(initial_requests)); |
| 139 } | 159 } |
| 140 | 160 |
| 141 active_fetches_.insert( | 161 active_fetches_.insert( |
| 142 std::make_pair(registration_id, std::move(controller))); | 162 std::make_pair(registration_id, std::move(controller))); |
| 143 } | 163 } |
| 144 | 164 |
| 145 void BackgroundFetchContext::DidCompleteJob( | 165 void BackgroundFetchContext::DidCompleteJob( |
| 146 BackgroundFetchJobController* controller) { | 166 BackgroundFetchJobController* controller) { |
| 147 const BackgroundFetchRegistrationId& registration_id = | 167 const BackgroundFetchRegistrationId& registration_id = |
| 148 controller->registration_id(); | 168 controller->registration_id(); |
| 149 | 169 |
| 150 DCHECK_GT(active_fetches_.count(registration_id), 0u); | 170 DCHECK_GT(active_fetches_.count(registration_id), 0u); |
| 151 | 171 |
| 152 if (controller->state() == BackgroundFetchJobController::State::COMPLETED) { | 172 // The `backgroundfetched` and/or `backgroundfetchfail` event will only be |
| 153 // TODO(peter): Dispatch the `backgroundfetched` or `backgroundfetchfail` | 173 // invoked for Background Fetch jobs which have been completed. |
| 154 // event to the Service Worker to inform the developer. | 174 if (controller->state() != BackgroundFetchJobController::State::COMPLETED) { |
|
harkness
2017/03/29 22:12:33
We need to call the aborted event if that's the st
Peter Beverloo
2017/03/29 22:20:28
As I understand it, `backgroundfetchabort` is for
Peter Beverloo
2017/03/30 10:19:37
https://github.com/WICG/background-fetch#reacting-
harkness
2017/03/30 14:15:28
Acknowledged.
| |
| 175 DeleteRegistration(registration_id); | |
| 176 return; | |
| 155 } | 177 } |
| 156 | 178 |
| 179 // Get the sequence of settled fetches from the data manager. | |
| 180 data_manager_->GetSettledFetchesForRegistration( | |
| 181 registration_id, | |
| 182 base::BindOnce(&BackgroundFetchContext::DidGetSettledFetches, this, | |
| 183 registration_id)); | |
| 184 } | |
| 185 | |
| 186 void BackgroundFetchContext::DidGetSettledFetches( | |
| 187 const BackgroundFetchRegistrationId& registration_id, | |
| 188 blink::mojom::BackgroundFetchError error, | |
| 189 std::vector<BackgroundFetchSettledFetch> settled_fetches, | |
| 190 std::vector<std::unique_ptr<BlobHandle>> blob_handles) { | |
| 191 if (error != blink::mojom::BackgroundFetchError::NONE) { | |
| 192 DeleteRegistration(registration_id); | |
| 193 return; | |
| 194 } | |
| 195 | |
| 196 // TODO(peter): Distinguish between the `backgroundfetched` and | |
| 197 // `backgroundfetchfail` events based on the status code of all fetches. We | |
| 198 // don't populate that field yet, so always assume it's successful for now. | |
| 199 | |
| 200 event_dispatcher_->DispatchBackgroundFetchedEvent( | |
| 201 registration_id, std::move(settled_fetches), | |
| 202 base::Bind(&BackgroundFetchContext::DeleteRegistration, this, | |
| 203 registration_id)); | |
| 204 } | |
| 205 | |
| 206 void BackgroundFetchContext::DeleteRegistration( | |
| 207 const BackgroundFetchRegistrationId& registration_id) { | |
| 208 DCHECK_GT(active_fetches_.count(registration_id), 0u); | |
| 209 | |
| 210 // Delete all persistent information associated with the |registration_id|. | |
| 211 data_manager_->DeleteRegistration( | |
| 212 registration_id, base::BindOnce(&RecordRegistrationDeletedError)); | |
| 213 | |
| 214 // Delete the local state associated with the |registration_id|. | |
| 157 active_fetches_.erase(registration_id); | 215 active_fetches_.erase(registration_id); |
| 158 } | 216 } |
| 159 | 217 |
| 160 } // namespace content | 218 } // namespace content |
| OLD | NEW |