blob: 602a116f2e7ed3591a3be338e297cde9f0550cd4 [file] [log] [blame]
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_SESSIONS_APP_SESSION_SERVICE_FACTORY_H_
#define CHROME_BROWSER_SESSIONS_APP_SESSION_SERVICE_FACTORY_H_
#include "base/no_destructor.h"
#include "chrome/browser/profiles/profile_keyed_service_factory.h"
#include "chrome/browser/sessions/app_session_service.h"
class Profile;
// Singleton that owns all AppSessionServices and associates them with
// Profiles. Listens for the Profile's destruction notification and cleans up
// the associated SessionService.
class AppSessionServiceFactory : public ProfileKeyedServiceFactory {
public:
// Returns the session service for |profile|. This may return NULL. If this
// profile supports a session service (it isn't incognito), and the session
// service hasn't yet been created, this forces creation of the session
// service. This returns NULL if ShutdownForProfile has been called for
// |profile|.
//
// This returns NULL if the profile is incognito. Callers should always check
// the return value for NULL.
static AppSessionService* GetForProfile(Profile* profile);
// Returns the session service for |profile|, but do not create it if it
// doesn't exist. This returns NULL if the profile is incognito or if session
// service has been explicitly shutdown (browser is exiting). Callers should
// always check the return value for NULL.
static AppSessionService* GetForProfileIfExisting(Profile* profile);
// Returns the session service for |profile|. This is the same as
// GetForProfile, but will force creation of the session service even if
// ShutdownForProfile has been called for |profile|.
static AppSessionService* GetForProfileForSessionRestore(Profile* profile);
// If |profile| has a session service, it is shut down. To properly record the
// current state this forces creation of the session service, then shuts it
// down.
static void ShutdownForProfile(Profile* profile);
#if defined(UNIT_TEST)
// For test use: force setting of the session service for a given profile.
// This will delete a previous session service for this profile if it exists.
static void SetForTestProfile(Profile* profile,
std::unique_ptr<AppSessionService> service) {
GetInstance()->BrowserContextShutdown(profile);
GetInstance()->BrowserContextDestroyed(profile);
GetInstance()->Associate(profile, std::move(service));
}
#endif
static AppSessionServiceFactory* GetInstance();
private:
friend base::NoDestructor<AppSessionServiceFactory>;
AppSessionServiceFactory();
~AppSessionServiceFactory() override;
// BrowserContextKeyedServiceFactory:
std::unique_ptr<KeyedService> BuildServiceInstanceForBrowserContext(
content::BrowserContext* profile) const override;
bool ServiceIsCreatedWithBrowserContext() const override;
bool ServiceIsNULLWhileTesting() const override;
};
#endif // CHROME_BROWSER_SESSIONS_APP_SESSION_SERVICE_FACTORY_H_