| Index: content/browser/background_sync/background_sync_manager.h
|
| diff --git a/content/browser/background_sync/background_sync_manager.h b/content/browser/background_sync/background_sync_manager.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..674186c8712c25b831a195b32438a63ada1fe660
|
| --- /dev/null
|
| +++ b/content/browser/background_sync/background_sync_manager.h
|
| @@ -0,0 +1,221 @@
|
| +// Copyright 2015 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef CONTENT_BROWSER_BACKGROUND_SYNC_BACKGROUND_SYNC_MANAGER_H_
|
| +#define CONTENT_BROWSER_BACKGROUND_SYNC_BACKGROUND_SYNC_MANAGER_H_
|
| +
|
| +#include <list>
|
| +#include <map>
|
| +
|
| +#include "base/callback_forward.h"
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/memory/weak_ptr.h"
|
| +#include "content/browser/service_worker/service_worker_cache_scheduler.h"
|
| +#include "content/browser/service_worker/service_worker_storage.h"
|
| +#include "content/common/content_export.h"
|
| +#include "content/common/service_worker/service_worker_status_code.h"
|
| +#include "url/gurl.h"
|
| +
|
| +namespace content {
|
| +
|
| +class ServiceWorkerContextWrapper;
|
| +
|
| +// BackgroundSyncManager manages and stores the set of background sync
|
| +// registrations across all registered service workers for a profile.
|
| +// Registrations are stored along with their associated Service Worker
|
| +// registration in ServiceWorkerStorage. If the ServiceWorker is unregistered,
|
| +// the sync registrations are removed. This class expects to be run on the IO
|
| +// thread. The asynchronous methods are executed sequentially.
|
| +
|
| +// TODO(jkarlin): Check permissions when registering, scheduling, and firing
|
| +// background sync. In the meantime, --enable-service-worker-sync is required to
|
| +// fire a sync event.
|
| +// TODO(jkarlin): Unregister syncs when permission is revoked.
|
| +// TODO(jkarlin): Create a background sync scheduler to actually run the
|
| +// registered events.
|
| +// TODO(jkarlin): Keep the browser alive if "Let Google Chrome Run in the
|
| +// Background" is true and a sync is registered.
|
| +// TODO(jkarlin): Unregister syncs when storage for an origin is cleared.
|
| +// TODO(jkarlin): Detect and handle a corrupt or broken backend.
|
| +class CONTENT_EXPORT BackgroundSyncManager {
|
| + public:
|
| + enum ErrorType {
|
| + ERROR_TYPE_OK = 0,
|
| + ERROR_TYPE_STORAGE,
|
| + ERROR_TYPE_NOT_FOUND
|
| + };
|
| +
|
| + // TODO(jkarlin): Remove this and use the struct from IPC messages once it
|
| + // lands.
|
| + struct CONTENT_EXPORT BackgroundSyncRegistration {
|
| + using RegistrationId = int64;
|
| + static const RegistrationId kInvalidRegistrationId;
|
| +
|
| + BackgroundSyncRegistration()
|
| + : BackgroundSyncRegistration(kInvalidRegistrationId, "") {}
|
| + explicit BackgroundSyncRegistration(const std::string& name)
|
| + : BackgroundSyncRegistration(kInvalidRegistrationId, name) {}
|
| + BackgroundSyncRegistration(int64 id, const std::string& name)
|
| + : id(id), min_period(0), name(name) {}
|
| +
|
| + bool Equals(const BackgroundSyncRegistration& other) {
|
| + return this->name == other.name && this->min_period == other.min_period;
|
| + }
|
| +
|
| + RegistrationId id;
|
| + int64 min_period;
|
| + std::string name;
|
| + };
|
| +
|
| + struct CONTENT_EXPORT BackgroundSyncRegistrations {
|
| + using NameToRegistrationMap =
|
| + std::map<std::string, BackgroundSyncRegistration>;
|
| + static const BackgroundSyncRegistration::RegistrationId kInitialId;
|
| +
|
| + BackgroundSyncRegistrations();
|
| + explicit BackgroundSyncRegistrations(
|
| + BackgroundSyncRegistration::RegistrationId next_id);
|
| + ~BackgroundSyncRegistrations();
|
| +
|
| + NameToRegistrationMap name_to_registration_map;
|
| + BackgroundSyncRegistration::RegistrationId next_id;
|
| + };
|
| +
|
| + using StatusCallback = base::Callback<void(ErrorType)>;
|
| + using StatusAndRegistrationCallback =
|
| + base::Callback<void(ErrorType, const BackgroundSyncRegistration&)>;
|
| +
|
| + static scoped_ptr<BackgroundSyncManager> Create(
|
| + const scoped_refptr<ServiceWorkerContextWrapper>& service_worker_context);
|
| + virtual ~BackgroundSyncManager();
|
| +
|
| + // Stores the given background sync registration and adds it to the scheduling
|
| + // queue. Overwrites any existing registration with the same name but
|
| + // different parameters (other than the id). Calls |callback| with ErrorTypeOK
|
| + // and the accepted registration on success. The accepted registration will
|
| + // have a unique id. It may also have altered parameters if the user or UA
|
| + // chose different parameters than those supplied.
|
| + void Register(const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const BackgroundSyncRegistration& sync_registration,
|
| + const StatusAndRegistrationCallback& callback);
|
| +
|
| + // Removes the background sync registration with |sync_registration_name| if
|
| + // the |sync_registration_id| matches. |sync_registration_id| will not match
|
| + // if, for instance, a new registration with the same name has replaced it.
|
| + // Calls |callback| with ErrorTypeNotFound if no match is found. Calls
|
| + // |callback| with ErrorTypeOK on success.
|
| + void Unregister(
|
| + const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const std::string& sync_registration_name,
|
| + BackgroundSyncRegistration::RegistrationId sync_registration_id,
|
| + const StatusCallback& callback);
|
| +
|
| + // Finds the background sync registration associated with
|
| + // |sw_registration_id|. Calls |callback| with ErrorTypeNotFound if it doesn't
|
| + // exist. Calls |callback| with ErrorTypeOK on success.
|
| + void GetRegistration(const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const std::string sync_registration_name,
|
| + const StatusAndRegistrationCallback& callback);
|
| +
|
| + protected:
|
| + explicit BackgroundSyncManager(
|
| + const scoped_refptr<ServiceWorkerContextWrapper>& context);
|
| +
|
| + // Init must be called before any public member function. Only call it once.
|
| + void Init();
|
| +
|
| + // The following methods are virtual for testing.
|
| + virtual void StoreDataInBackend(
|
| + int64 sw_registration_id,
|
| + const GURL& origin,
|
| + const std::string& key,
|
| + const std::string& data,
|
| + const ServiceWorkerStorage::StatusCallback& callback);
|
| + virtual void GetDataFromBackend(
|
| + const std::string& key,
|
| + const ServiceWorkerStorage::GetUserDataForAllRegistrationsCallback&
|
| + callback);
|
| +
|
| + private:
|
| + using PermissionStatusCallback = base::Callback<void(bool)>;
|
| + using SWIdToRegistrationsMap = std::map<int64, BackgroundSyncRegistrations>;
|
| +
|
| + // Returns the existing registration in |existing_registration| if it is not
|
| + // null.
|
| + bool LookupRegistration(int64 sw_registration_id,
|
| + const std::string& sync_registration_name,
|
| + BackgroundSyncRegistration* existing_registration);
|
| +
|
| + // Store all registrations for a given |sw_registration_id|.
|
| + void StoreRegistrations(const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const ServiceWorkerStorage::StatusCallback& callback);
|
| +
|
| + // If the registration is in the map, removes it and returns the removed
|
| + // registration in |old_registration|. |old_registration| may be null.
|
| + void RemoveRegistrationFromMap(int64 sw_registration_id,
|
| + const std::string& sync_registration_name,
|
| + BackgroundSyncRegistration* old_registration);
|
| +
|
| + void AddRegistrationToMap(
|
| + int64 sw_registration_id,
|
| + const BackgroundSyncRegistration& sync_registration);
|
| +
|
| + void InitImpl();
|
| + void InitDidGetDataFromBackend(
|
| + const std::vector<std::pair<int64, std::string>>& user_data,
|
| + ServiceWorkerStatusCode status);
|
| +
|
| + // Register callbacks
|
| + void RegisterImpl(const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const BackgroundSyncRegistration& sync_registration,
|
| + const StatusAndRegistrationCallback& callback);
|
| + void RegisterDidStore(int64 sw_registration_id,
|
| + const BackgroundSyncRegistration& sync_registration,
|
| + const BackgroundSyncRegistration& previous_registration,
|
| + const StatusAndRegistrationCallback& callback,
|
| + ServiceWorkerStatusCode status);
|
| +
|
| + // Unregister callbacks
|
| + void UnregisterImpl(
|
| + const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const std::string& sync_registration_name,
|
| + BackgroundSyncRegistration::RegistrationId sync_registration_id,
|
| + const StatusCallback& callback);
|
| + void UnregisterDidStore(
|
| + int64 sw_registration_id,
|
| + const BackgroundSyncRegistration& old_sync_registration,
|
| + const StatusCallback& callback,
|
| + ServiceWorkerStatusCode status);
|
| +
|
| + // GetRegistration callbacks
|
| + void GetRegistrationImpl(const GURL& origin,
|
| + int64 sw_registration_id,
|
| + const std::string sync_registration_name,
|
| + const StatusAndRegistrationCallback& callback);
|
| +
|
| + // Operation Scheduling callbacks
|
| + void PendingStatusAndRegistrationCallback(
|
| + const StatusAndRegistrationCallback& callback,
|
| + ErrorType error,
|
| + const BackgroundSyncRegistration& sync_registration);
|
| + void PendingStatusCallback(const StatusCallback& callback, ErrorType error);
|
| +
|
| + SWIdToRegistrationsMap sw_to_registrations_map_;
|
| + ServiceWorkerCacheScheduler op_scheduler_;
|
| + scoped_refptr<ServiceWorkerContextWrapper> service_worker_context_;
|
| +
|
| + base::WeakPtrFactory<BackgroundSyncManager> weak_ptr_factory_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(BackgroundSyncManager);
|
| +};
|
| +
|
| +} // namespace content
|
| +
|
| +#endif // CONTENT_BROWSER_BACKGROUND_SYNC_BACKGROUND_SYNC_MANAGER_H_
|
|
|