| 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 #ifndef CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ | 5 #ifndef CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ |
| 6 #define CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ | 6 #define CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ |
| 7 | 7 |
| 8 #include <map> | 8 #include <map> |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/macros.h" | 12 #include "base/macros.h" |
| 13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
| 14 #include "base/memory/weak_ptr.h" |
| 14 #include "content/common/content_export.h" | 15 #include "content/common/content_export.h" |
| 15 #include "content/public/browser/browser_thread.h" | 16 #include "content/public/browser/browser_thread.h" |
| 16 #include "third_party/WebKit/public/platform/modules/background_fetch/background
_fetch.mojom.h" | 17 #include "third_party/WebKit/public/platform/modules/background_fetch/background
_fetch.mojom.h" |
| 17 | 18 |
| 18 namespace net { | 19 namespace net { |
| 19 class URLRequestContextGetter; | 20 class URLRequestContextGetter; |
| 20 } | 21 } |
| 21 | 22 |
| 22 namespace url { | 23 namespace url { |
| 23 class Origin; | 24 class Origin; |
| 24 } | 25 } |
| 25 | 26 |
| 26 namespace content { | 27 namespace content { |
| 27 | 28 |
| 28 class BackgroundFetchDataManager; | 29 class BackgroundFetchDataManager; |
| 29 class BackgroundFetchEventDispatcher; | 30 class BackgroundFetchEventDispatcher; |
| 30 class BackgroundFetchJobController; | 31 class BackgroundFetchJobController; |
| 31 struct BackgroundFetchOptions; | 32 struct BackgroundFetchOptions; |
| 32 class BackgroundFetchRegistrationId; | 33 class BackgroundFetchRegistrationId; |
| 33 class BackgroundFetchRequestInfo; | 34 class BackgroundFetchRequestInfo; |
| 34 class BlobHandle; | 35 class BlobHandle; |
| 35 class BrowserContext; | 36 class BrowserContext; |
| 36 class ServiceWorkerContextWrapper; | 37 class ServiceWorkerContextWrapper; |
| 37 struct ServiceWorkerFetchRequest; | 38 struct ServiceWorkerFetchRequest; |
| 38 class StoragePartitionImpl; | |
| 39 | 39 |
| 40 // The BackgroundFetchContext is the central moderator of ongoing background | 40 // The BackgroundFetchContext is the central moderator of ongoing background |
| 41 // fetch requests from the Mojo service and from other callers. | 41 // fetch requests from the Mojo service and from other callers. |
| 42 // Background Fetch requests function similar to normal fetches except that | 42 // Background Fetch requests function similarly to normal fetches except that |
| 43 // they are persistent across Chromium or service worker shutdown. | 43 // they are persistent across Chromium or service worker shutdown. |
| 44 class CONTENT_EXPORT BackgroundFetchContext | 44 class CONTENT_EXPORT BackgroundFetchContext |
| 45 : public base::RefCountedThreadSafe<BackgroundFetchContext, | 45 : public base::RefCountedThreadSafe<BackgroundFetchContext, |
| 46 BrowserThread::DeleteOnUIThread> { | 46 BrowserThread::DeleteOnIOThread> { |
| 47 public: | 47 public: |
| 48 // The BackgroundFetchContext will watch the ServiceWorkerContextWrapper so | 48 // The BackgroundFetchContext will watch the ServiceWorkerContextWrapper so |
| 49 // that it can respond to service worker events such as unregister. | 49 // that it can respond to service worker events such as unregister. |
| 50 BackgroundFetchContext(BrowserContext* browser_context, | 50 BackgroundFetchContext(BrowserContext* browser_context, |
| 51 StoragePartitionImpl* storage_partition, | |
| 52 scoped_refptr<ServiceWorkerContextWrapper> context); | 51 scoped_refptr<ServiceWorkerContextWrapper> context); |
| 53 | 52 |
| 54 // Finishes initializing the Background Fetch context on the IO thread by | 53 // Finishes initializing the Background Fetch context on the IO thread by |
| 55 // setting the |request_context_getter|. | 54 // setting the |request_context_getter|. |
| 56 void InitializeOnIOThread( | 55 void InitializeOnIOThread( |
| 57 scoped_refptr<net::URLRequestContextGetter> request_context_getter); | 56 scoped_refptr<net::URLRequestContextGetter> request_context_getter); |
| 58 | 57 |
| 59 // Shutdown must be called before deleting this. Call on the UI thread. | |
| 60 void Shutdown(); | |
| 61 | |
| 62 // Starts a Background Fetch for the |registration_id|. The |requests| will be | 58 // Starts a Background Fetch for the |registration_id|. The |requests| will be |
| 63 // asynchronously fetched. The |callback| will be invoked when the fetch has | 59 // asynchronously fetched. The |callback| will be invoked when the fetch has |
| 64 // been registered, or an error occurred that avoids it from doing so. | 60 // been registered, or an error occurred that avoids it from doing so. |
| 65 void StartFetch(const BackgroundFetchRegistrationId& registration_id, | 61 void StartFetch(const BackgroundFetchRegistrationId& registration_id, |
| 66 const std::vector<ServiceWorkerFetchRequest>& requests, | 62 const std::vector<ServiceWorkerFetchRequest>& requests, |
| 67 const BackgroundFetchOptions& options, | 63 const BackgroundFetchOptions& options, |
| 68 blink::mojom::BackgroundFetchService::FetchCallback callback); | 64 blink::mojom::BackgroundFetchService::FetchCallback callback); |
| 69 | 65 |
| 70 // Returns a vector with the tags of the active fetches for the given |origin| | 66 // Returns a vector with the tags of the active fetches for the given |origin| |
| 71 // and |service_worker_registration_id|. | 67 // and |service_worker_registration_id|. |
| 72 std::vector<std::string> GetActiveTagsForServiceWorkerRegistration( | 68 std::vector<std::string> GetActiveTagsForServiceWorkerRegistration( |
| 73 int64_t service_worker_registration_id, | 69 int64_t service_worker_registration_id, |
| 74 const url::Origin& origin) const; | 70 const url::Origin& origin) const; |
| 75 | 71 |
| 76 // Returns the JobController that is handling the |registration_id|, or a | 72 // Returns the JobController that is handling the |registration_id|, or a |
| 77 // nullptr if it does not exist. Must be immediately used by the caller. | 73 // nullptr if it does not exist. Must be immediately used by the caller. |
| 78 BackgroundFetchJobController* GetActiveFetch( | 74 BackgroundFetchJobController* GetActiveFetch( |
| 79 const BackgroundFetchRegistrationId& registration_id) const; | 75 const BackgroundFetchRegistrationId& registration_id) const; |
| 80 | 76 |
| 81 private: | 77 private: |
| 82 friend class base::DeleteHelper<BackgroundFetchContext>; | 78 friend class base::DeleteHelper<BackgroundFetchContext>; |
| 83 friend struct BrowserThread::DeleteOnThread<BrowserThread::UI>; | 79 friend struct BrowserThread::DeleteOnThread<BrowserThread::IO>; |
| 84 friend class base::RefCountedThreadSafe<BackgroundFetchContext, | 80 friend class base::RefCountedThreadSafe<BackgroundFetchContext, |
| 85 BrowserThread::DeleteOnUIThread>; | 81 BrowserThread::DeleteOnIOThread>; |
| 86 | 82 |
| 87 ~BackgroundFetchContext(); | 83 ~BackgroundFetchContext(); |
| 88 | 84 |
| 89 // Shuts down the active Job Controllers on the IO thread. | |
| 90 void ShutdownOnIO(); | |
| 91 | |
| 92 // Creates a new Job Controller for the given |registration_id| and |options|, | 85 // Creates a new Job Controller for the given |registration_id| and |options|, |
| 93 // which will start fetching the files that are part of the registration. | 86 // which will start fetching the files that are part of the registration. |
| 94 void CreateController( | 87 void CreateController( |
| 95 const BackgroundFetchRegistrationId& registration_id, | 88 const BackgroundFetchRegistrationId& registration_id, |
| 96 const BackgroundFetchOptions& options, | 89 const BackgroundFetchOptions& options, |
| 97 std::vector<scoped_refptr<BackgroundFetchRequestInfo>> initial_requests); | 90 std::vector<scoped_refptr<BackgroundFetchRequestInfo>> initial_requests); |
| 98 | 91 |
| 99 // Called when a new registration has been created by the data manager. | 92 // Called when a new registration has been created by the data manager. |
| 100 void DidCreateRegistration( | 93 void DidCreateRegistration( |
| 101 const BackgroundFetchRegistrationId& registration_id, | 94 const BackgroundFetchRegistrationId& registration_id, |
| (...skipping 26 matching lines...) Expand all Loading... |
| 128 scoped_refptr<net::URLRequestContextGetter> request_context_getter_; | 121 scoped_refptr<net::URLRequestContextGetter> request_context_getter_; |
| 129 | 122 |
| 130 std::unique_ptr<BackgroundFetchDataManager> data_manager_; | 123 std::unique_ptr<BackgroundFetchDataManager> data_manager_; |
| 131 std::unique_ptr<BackgroundFetchEventDispatcher> event_dispatcher_; | 124 std::unique_ptr<BackgroundFetchEventDispatcher> event_dispatcher_; |
| 132 | 125 |
| 133 // Map of the Background Fetch fetches that are currently in-progress. | 126 // Map of the Background Fetch fetches that are currently in-progress. |
| 134 std::map<BackgroundFetchRegistrationId, | 127 std::map<BackgroundFetchRegistrationId, |
| 135 std::unique_ptr<BackgroundFetchJobController>> | 128 std::unique_ptr<BackgroundFetchJobController>> |
| 136 active_fetches_; | 129 active_fetches_; |
| 137 | 130 |
| 131 base::WeakPtrFactory<BackgroundFetchContext> weak_factory_; // Must be last. |
| 132 |
| 138 DISALLOW_COPY_AND_ASSIGN(BackgroundFetchContext); | 133 DISALLOW_COPY_AND_ASSIGN(BackgroundFetchContext); |
| 139 }; | 134 }; |
| 140 | 135 |
| 141 } // namespace content | 136 } // namespace content |
| 142 | 137 |
| 143 #endif // CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ | 138 #endif // CONTENT_BROWSER_BACKGROUND_FETCH_BACKGROUND_FETCH_CONTEXT_H_ |
| OLD | NEW |