blob: f0c04142ccfa1feaf6aae6029e16f8f7d39ae565 [file] [log] [blame]
// 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_SESSIONS_SYNC_SESSIONS_CLIENT_H_
#define COMPONENTS_SYNC_SESSIONS_SYNC_SESSIONS_CLIENT_H_
#include <memory>
#include "base/macros.h"
#include "components/sync/model/model_type_store.h"
class GURL;
namespace favicon {
class FaviconService;
}
namespace history {
class HistoryService;
}
namespace syncer {
class DeviceInfo;
} // namespace syncer
namespace sync_sessions {
class LocalSessionEventRouter;
class SessionSyncPrefs;
class SyncedWindowDelegatesGetter;
// Interface for clients of a sync sessions datatype. Should be used as a getter
// for services and data the Sync Sessions datatype depends on.
class SyncSessionsClient {
public:
SyncSessionsClient();
virtual ~SyncSessionsClient();
// Getters for services that sessions depends on.
virtual favicon::FaviconService* GetFaviconService() = 0;
virtual history::HistoryService* GetHistoryService() = 0;
virtual SessionSyncPrefs* GetSessionSyncPrefs() = 0;
virtual syncer::RepeatingModelTypeStoreFactory GetStoreFactory() = 0;
// Checks if the given url is considered interesting enough to sync. Most urls
// are considered interesting. Examples of ones that are not are invalid urls,
// files, and chrome internal pages.
// TODO(zea): make this a standalone function if the url constants are
// componentized.
virtual bool ShouldSyncURL(const GURL& url) const = 0;
// Returns the DeviceInfo representing the local device. May return null if
// sync is not running.
virtual const syncer::DeviceInfo* GetLocalDeviceInfo() = 0;
// Returns the SyncedWindowDelegatesGetter for this client.
virtual SyncedWindowDelegatesGetter* GetSyncedWindowDelegatesGetter() = 0;
// Returns a LocalSessionEventRouter instance that is customized for the
// embedder's context.
virtual LocalSessionEventRouter* GetLocalSessionEventRouter() = 0;
private:
DISALLOW_COPY_AND_ASSIGN(SyncSessionsClient);
};
} // namespace sync_sessions
#endif // COMPONENTS_SYNC_SESSIONS_SYNC_SESSIONS_CLIENT_H_