blob: 4b6bccd7c05716492b32dafb1304e7d1a08b8413 [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef IOS_CHROME_BROWSER_SYNC_SYNC_SETUP_SERVICE_H_
#define IOS_CHROME_BROWSER_SYNC_SYNC_SETUP_SERVICE_H_
#include <memory>
#include "components/keyed_service/core/keyed_service.h"
#include "components/sync/base/model_type.h"
#include "components/sync/driver/sync_user_settings.h"
namespace syncer {
class SyncService;
class SyncSetupInProgressHandle;
} // namespace syncer
// Class that allows configuring sync. It handles enabling and disabling it, as
// well as choosing datatypes. Most actions are delayed until a commit is done,
// to allow the complex sync setup flow on iOS.
class SyncSetupService : public KeyedService {
public:
// The set of user-selectable datatypes handled by Chrome for iOS.
// TODO(crbug.com/1067280): Use syncer::UserSelectableType instead.
using SyncableDatatype = enum {
kSyncBookmarks,
kSyncOmniboxHistory,
kSyncPasswords,
kSyncOpenTabs,
kSyncAutofill,
kSyncPreferences,
kSyncReadingList,
kNumberOfSyncableDatatypes
};
explicit SyncSetupService(syncer::SyncService* sync_service);
SyncSetupService(const SyncSetupService&) = delete;
SyncSetupService& operator=(const SyncSetupService&) = delete;
~SyncSetupService() override;
// Returns the `syncer::ModelType` associated to the given
// `SyncableDatatypes`.
static syncer::ModelType GetModelType(SyncableDatatype datatype);
// Returns whether the user wants Sync to run.
// TODO(crbug.com/1291946): Callers should typically use CanSyncFeatureStart()
// or IsSyncFeatureEnabled() instead.
virtual bool IsSyncRequested() const;
// Returns whether Sync-the-transport can start the Sync feature.
virtual bool CanSyncFeatureStart() const;
// Returns all currently enabled datatypes.
syncer::ModelTypeSet GetPreferredDataTypes() const;
// Returns whether the given datatype has been enabled for sync and its
// initialization is complete (SyncEngineHost::OnEngineInitialized has been
// called).
virtual bool IsDataTypeActive(syncer::ModelType datatype) const;
// Returns whether the given datatype is enabled by the user.
virtual bool IsDataTypePreferred(syncer::ModelType datatype) const;
// Enables or disables the given datatype. To be noted: this can be called at
// any time, but will only be meaningful if `CanSyncFeatureStart` is true and
// `IsSyncingAllDataTypes` is false. Changes won't take effect in the sync
// backend before the next call to `CommitChanges`.
void SetDataTypeEnabled(syncer::ModelType datatype, bool enabled);
// Returns whether the user needs to enter a passphrase or enable sync to make
// tab sync work.
bool UserActionIsRequiredToHaveTabSyncWork();
// Returns whether all datatypes are being synced.
virtual bool IsSyncingAllDataTypes() const;
// Sets whether all datatypes should be synced or not. Changes won't take
// effect before the next call to `CommitChanges`.
virtual void SetSyncingAllDataTypes(bool sync_all);
// Returns whether all sync data is being encrypted.
virtual bool IsEncryptEverythingEnabled() const;
// Returns true if the initial sync setup is currently ongoing.
// Returns false if it is either finished or not started.
// This method is guaranteed not to start the sync backend so it can be
// called at start-up.
virtual bool IsInitialSetupOngoing();
// Pauses sync allowing the user to configure what data to sync before
// actually starting to sync data with the server.
virtual void PrepareForFirstSyncSetup();
// Sets the first setup complete flag. This method doesn't commit sync
// changes. PrepareForFirstSyncSetup() needs to be called before. This flag is
// not set if the user didn't turn on sync.
// This method should only be used with UnifiedConsent flag.
virtual void SetFirstSetupComplete(
syncer::SyncFirstSetupCompleteSource source);
// Returns true if the user finished the Sync setup flow.
bool IsFirstSetupComplete() const;
// Commits all the pending configuration changes to Sync.
void CommitSyncChanges();
// Returns true if there are uncommitted sync changes.
bool HasUncommittedChanges();
private:
syncer::SyncService* const sync_service_;
// Prevents Sync from running until configuration is complete.
std::unique_ptr<syncer::SyncSetupInProgressHandle> sync_blocker_;
};
#endif // IOS_CHROME_BROWSER_SYNC_SYNC_SETUP_SERVICE_H_