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

Unified Diff: components/sync/device_info/device_info_service.h

Issue 2460903003: [Sync] Rename DeviceInfoService to DeviceInfoSyncBridge. (Closed)
Patch Set: Updating nullptr to null in comment. Created 4 years, 2 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
« no previous file with comments | « components/sync/BUILD.gn ('k') | components/sync/device_info/device_info_service.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/sync/device_info/device_info_service.h
diff --git a/components/sync/device_info/device_info_service.h b/components/sync/device_info/device_info_service.h
deleted file mode 100644
index 958f0dbcab5e91bdca8384503c0cc96637c54fb9..0000000000000000000000000000000000000000
--- a/components/sync/device_info/device_info_service.h
+++ /dev/null
@@ -1,158 +0,0 @@
-// 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 COMPONENTS_SYNC_DEVICE_INFO_DEVICE_INFO_SERVICE_H_
-#define COMPONENTS_SYNC_DEVICE_INFO_DEVICE_INFO_SERVICE_H_
-
-#include <map>
-#include <memory>
-#include <string>
-#include <vector>
-
-#include "base/macros.h"
-#include "base/memory/weak_ptr.h"
-#include "base/observer_list.h"
-#include "base/time/time.h"
-#include "base/timer/timer.h"
-#include "components/sync/device_info/device_info_tracker.h"
-#include "components/sync/device_info/local_device_info_provider.h"
-#include "components/sync/model/model_type_store.h"
-#include "components/sync/model/model_type_sync_bridge.h"
-#include "components/sync/model/simple_metadata_change_list.h"
-
-namespace sync_pb {
-class DeviceInfoSpecifics;
-} // namespace sync_pb
-
-namespace syncer {
-
-class ModelTypeChangeProcessor;
-class SyncError;
-
-// USS service implementation for DEVICE_INFO model type. Handles storage of
-// device info and associated sync metadata, applying/merging foreign changes,
-// and allows public read access.
-class DeviceInfoService : public ModelTypeSyncBridge, public DeviceInfoTracker {
- public:
- typedef base::Callback<void(const ModelTypeStore::InitCallback& callback)>
- StoreFactoryFunction;
-
- DeviceInfoService(LocalDeviceInfoProvider* local_device_info_provider,
- const StoreFactoryFunction& callback,
- const ChangeProcessorFactory& change_processor_factory);
- ~DeviceInfoService() override;
-
- // ModelTypeSyncBridge implementation.
- std::unique_ptr<MetadataChangeList> CreateMetadataChangeList() override;
- SyncError MergeSyncData(
- std::unique_ptr<MetadataChangeList> metadata_change_list,
- EntityDataMap entity_data_map) override;
- SyncError ApplySyncChanges(
- std::unique_ptr<MetadataChangeList> metadata_change_list,
- EntityChangeList entity_changes) override;
- void GetData(StorageKeyList storage_keys, DataCallback callback) override;
- void GetAllData(DataCallback callback) override;
- std::string GetClientTag(const EntityData& entity_data) override;
- std::string GetStorageKey(const EntityData& entity_data) override;
- void DisableSync() override;
-
- // DeviceInfoTracker implementation.
- bool IsSyncing() const override;
- std::unique_ptr<DeviceInfo> GetDeviceInfo(
- const std::string& client_id) const override;
- std::vector<std::unique_ptr<DeviceInfo>> GetAllDeviceInfo() const override;
- void AddObserver(Observer* observer) override;
- void RemoveObserver(Observer* observer) override;
- int CountActiveDevices() const override;
-
- private:
- friend class DeviceInfoServiceTest;
-
- // Cache of all syncable and local data, stored by device cache guid.
- using ClientIdToSpecifics =
- std::map<std::string, std::unique_ptr<sync_pb::DeviceInfoSpecifics>>;
-
- // Store SyncData in the cache and durable storage.
- void StoreSpecifics(std::unique_ptr<sync_pb::DeviceInfoSpecifics> specifics,
- ModelTypeStore::WriteBatch* batch);
- // Delete SyncData from the cache and durable storage, returns true if there
- // was actually anything at the given tag.
- bool DeleteSpecifics(const std::string& tag,
- ModelTypeStore::WriteBatch* batch);
-
- // Notify all registered observers.
- void NotifyObservers();
-
- // Used as callback given to LocalDeviceInfoProvider.
- void OnProviderInitialized();
-
- // Methods used as callbacks given to DataTypeStore.
- void OnStoreCreated(ModelTypeStore::Result result,
- std::unique_ptr<ModelTypeStore> store);
- void OnReadAllData(ModelTypeStore::Result result,
- std::unique_ptr<ModelTypeStore::RecordList> record_list);
- void OnReadAllMetadata(
- ModelTypeStore::Result result,
- std::unique_ptr<ModelTypeStore::RecordList> metadata_records,
- const std::string& global_metadata);
- void OnCommit(ModelTypeStore::Result result);
-
- // Load metadata if the data is loaded and the provider is initialized.
- void LoadMetadataIfReady();
-
- // Performs reconciliation between the locally provided device info and the
- // stored device info data. If the sets of data differ, then we consider this
- // a local change and we send it to the processor.
- void ReconcileLocalAndStored();
-
- // Stores the updated version of the local copy of device info in durable
- // storage, in memory, and informs sync of the change. Should not be called
- // before the provider and processor have initialized.
- void SendLocalData();
-
- // Persists the changes in the given aggregators and notifies observers if
- // indicated to do as such.
- void CommitAndNotify(std::unique_ptr<ModelTypeStore::WriteBatch> batch,
- std::unique_ptr<MetadataChangeList> metadata_change_list,
- bool should_notify);
-
- // Counts the number of active devices relative to |now|. The activeness of a
- // device depends on the amount of time since it was updated, which means
- // comparing it against the current time. |now| is passed into this method to
- // allow unit tests to control expected results.
- int CountActiveDevices(const base::Time now) const;
-
- // Report an error starting up to sync if it tries to connect to this
- // datatype, since these errors prevent us from knowing if sync is enabled.
- void ReportStartupErrorToSync(const std::string& msg);
-
- // |local_device_info_provider_| isn't owned.
- const LocalDeviceInfoProvider* const local_device_info_provider_;
-
- ClientIdToSpecifics all_data_;
-
- // Registered observers, not owned.
- base::ObserverList<Observer, true> observers_;
-
- // Used to listen for provider initialization. If the provider is already
- // initialized during our constructor then the subscription is never used.
- std::unique_ptr<LocalDeviceInfoProvider::Subscription> subscription_;
-
- // In charge of actually persiting changes to disk, or loading previous data.
- std::unique_ptr<ModelTypeStore> store_;
-
- // If |local_device_info_provider_| has initialized.
- bool has_provider_initialized_ = false;
- // If data has been loaded from the store.
- bool has_data_loaded_ = false;
-
- // Used to update our local device info once every pulse interval.
- base::OneShotTimer pulse_timer_;
-
- DISALLOW_COPY_AND_ASSIGN(DeviceInfoService);
-};
-
-} // namespace syncer
-
-#endif // COMPONENTS_SYNC_DEVICE_INFO_DEVICE_INFO_SERVICE_H_
« no previous file with comments | « components/sync/BUILD.gn ('k') | components/sync/device_info/device_info_service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698