blob: 2ef4f602f99554bb3c03c008ce9705e208d96411 [file] [log] [blame]
// Copyright 2012 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 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:
using SyncServiceState = enum {
kNoSyncServiceError,
kSyncServiceSignInNeedsUpdate,
kSyncServiceCouldNotConnect,
kSyncServiceServiceUnavailable,
kSyncServiceNeedsPassphrase,
kSyncServiceNeedsTrustedVaultKey,
kSyncServiceTrustedVaultRecoverabilityDegraded,
kSyncServiceUnrecoverableError,
kLastSyncServiceError = kSyncServiceUnrecoverableError
};
// 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;
// Enables or disables sync. Changes won't take effect in the sync backend
// before the next call to |CommitChanges|.
// TODO(crbug.com/1291946): This is only used in sync_test_util.mm; inline it
// there.
virtual void SetSyncEnabled(bool sync_enabled);
// 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 the current sync service state.
virtual SyncServiceState GetSyncServiceState();
// Returns whether all sync data is being encrypted.
virtual bool IsEncryptEverythingEnabled() const;
// Returns true if the user has gone through the initial sync configuration.
// This method is guaranteed not to start the sync backend so it can be
// called at start-up.
virtual bool HasFinishedInitialSetup();
// 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_