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

Unified Diff: content/browser/background_fetch/background_fetch_data_manager.h

Issue 2774343002: Hook up BackgroundFetchServiceImpl::Fetch() to start a fetch (Closed)
Patch Set: Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: content/browser/background_fetch/background_fetch_data_manager.h
diff --git a/content/browser/background_fetch/background_fetch_data_manager.h b/content/browser/background_fetch/background_fetch_data_manager.h
index eb51afaabe00cdaeee2467577dfa38ed9eeed60c..65262b8e0de9d1a555ff0374850d176aa62ba960 100644
--- a/content/browser/background_fetch/background_fetch_data_manager.h
+++ b/content/browser/background_fetch/background_fetch_data_manager.h
@@ -14,9 +14,10 @@
#include "base/macros.h"
#include "content/browser/background_fetch/background_fetch_job_info.h"
#include "content/browser/background_fetch/background_fetch_job_response_data.h"
-#include "content/browser/background_fetch/background_fetch_request_info.h"
#include "content/browser/background_fetch/background_fetch_registration_id.h"
+#include "content/browser/background_fetch/background_fetch_request_info.h"
#include "content/common/content_export.h"
+#include "third_party/WebKit/public/platform/modules/background_fetch/background_fetch.mojom.h"
#include "url/origin.h"
namespace content {
@@ -30,13 +31,27 @@ class BlobHandle;
// which will keep the metadata up to date.
class CONTENT_EXPORT BackgroundFetchDataManager {
public:
+ using CreateRegistrationCallback =
+ base::OnceCallback<void(blink::mojom::BackgroundFetchError)>;
+ using DeleteRegistrationCallback =
+ base::OnceCallback<void(blink::mojom::BackgroundFetchError)>;
+
explicit BackgroundFetchDataManager(BrowserContext* browser_context);
~BackgroundFetchDataManager();
- // Called by BackgroundFetchContext when a new request is started, this will
- // store all of the necessary metadata to track the request.
- void CreateRequest(std::unique_ptr<BackgroundFetchJobInfo> job_info,
- BackgroundFetchRequestInfos request_infos);
+ // Creates and stores a new registration with the given properties. Will
+ // invoke the |callback| when the registration has been created, which may
+ // fail due to invalid input or storage errors.
+ void CreateRegistration(
+ const BackgroundFetchRegistrationId& registration_id,
+ const std::vector<ServiceWorkerFetchRequest>& requests,
+ const BackgroundFetchOptions& options,
+ CreateRegistrationCallback callback);
+
+ // Deletes the registration identified by |registration_id|. Will invoke the
+ // |callback| when the registration has been deleted from storage.
+ void DeleteRegistration(const BackgroundFetchRegistrationId& registration_id,
+ DeleteRegistrationCallback callback);
// TODO(harkness): Replace the OnceClosure with a callback to return the
// response object once it is decided whether lifetime should be passed to the
@@ -70,6 +85,11 @@ class CONTENT_EXPORT BackgroundFetchDataManager {
virtual bool IsComplete(const std::string& job_guid) const;
private:
+ friend class BackgroundFetchDataManagerTest;
+
+ void CreateRequestForTests(std::unique_ptr<BackgroundFetchJobInfo> job_info,
harkness 2017/03/27 15:35:12 I don't see a definition of this? It looks like yo
Peter Beverloo 2017/03/27 15:42:55 Oops, removed.
+ BackgroundFetchRequestInfos request_infos);
+
// Storage interface.
void WriteJobToStorage(std::unique_ptr<BackgroundFetchJobInfo> job_info,
BackgroundFetchRequestInfos request_infos);
@@ -87,7 +107,7 @@ class CONTENT_EXPORT BackgroundFetchDataManager {
BrowserContext* browser_context_;
// Set of known background fetch registration ids.
- std::set<BackgroundFetchRegistrationId> known_registrations_;
+ std::set<BackgroundFetchRegistrationId> registrations_;
// Map from job_guid to JobInfo.
std::unordered_map<std::string, std::unique_ptr<BackgroundFetchJobInfo>>

Powered by Google App Engine
This is Rietveld 408576698