// Copyright (c) 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 CHROME_BROWSER_CHROMEOS_LOGIN_LOGIN_UTILS_H_ #define CHROME_BROWSER_CHROMEOS_LOGIN_LOGIN_UTILS_H_ #include <string> #include "base/memory/ref_counted.h" class CommandLine; class GURL; class PrefRegistrySimple; class PrefService; class Profile; namespace chromeos { class Authenticator; class LoginDisplayHost; class LoginStatusConsumer; struct UserContext; class LoginUtils { public: class Delegate { public: // Called after profile is loaded and prepared for the session. virtual void OnProfilePrepared(Profile* profile) = 0; #if defined(ENABLE_RLZ) // Called after post-profile RLZ initialization. virtual void OnRlzInitialized(Profile* profile) {} #endif protected: virtual ~Delegate() {} }; // Registers log-in related preferences. static void RegisterPrefs(PrefRegistrySimple* registry); // Get LoginUtils singleton object. If it was not set before, new default // instance will be created. static LoginUtils* Get(); // Set LoginUtils singleton object for test purpose only! static void Set(LoginUtils* ptr); // Checks if the given username is whitelisted and allowed to sign-in to // this device. |wildcard_match| may be NULL. If it's present, it'll be set to // true if the whitelist check was satisfied via a wildcard. static bool IsWhitelisted(const std::string& username, bool* wildcard_match); virtual ~LoginUtils() {} // Thin wrapper around StartupBrowserCreator::LaunchBrowser(). Meant to be // used in a Task posted to the UI thread. Once the browser is launched the // login host is deleted. virtual void DoBrowserLaunch(Profile* profile, LoginDisplayHost* login_host) = 0; // Loads and prepares profile for the session. Fires |delegate| in the end. // If |pending_requests| is true, there's a pending online auth request. // If |display_email| is not empty, user's displayed email will be set to // this value, shown in UI. // |user_context.username_hash| defines when user homedir is mounted. // Also see DelegateDeleted method. // If |has_active_session| is true than this is a case of restoring user // session after browser crash so no need to start new session. virtual void PrepareProfile( const UserContext& user_context, const std::string& display_email, bool has_cookies, bool has_active_session, Delegate* delegate) = 0; // Invalidates |delegate|, which was passed to PrepareProfile method call. virtual void DelegateDeleted(Delegate* delegate) = 0; // Invoked after the tmpfs is successfully mounted. // Asks session manager to restart Chrome in Browse Without Sign In mode. // |start_url| is url for launched browser to open. virtual void CompleteOffTheRecordLogin(const GURL& start_url) = 0; // Invoked when the user is logging in for the first time, or is logging in as // a guest user. virtual void SetFirstLoginPrefs(PrefService* prefs) = 0; // Creates and returns the authenticator to use. // Before WebUI login (Up to R14) the caller owned the returned // Authenticator instance and had to delete it when done. // New instance was created on each new login attempt. // Starting with WebUI login (R15) single Authenticator instance is used for // entire login process, even for multiple retries. Authenticator instance // holds reference to login profile and is later used during fetching of // OAuth tokens. // TODO(nkostylev): Cleanup after WebUI login migration is complete. virtual scoped_refptr<Authenticator> CreateAuthenticator( LoginStatusConsumer* consumer) = 0; // Restores authentication session after crash. virtual void RestoreAuthenticationSession(Profile* profile) = 0; // Initialize RLZ. virtual void InitRlzDelayed(Profile* user_profile) = 0; }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_LOGIN_LOGIN_UTILS_H_