| // 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_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |
| #define CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |
| |
| #include "base/basictypes.h" |
| #include "base/observer_list.h" |
| #include "base/strings/string16.h" |
| #include "components/keyed_service/core/keyed_service.h" |
| |
| class Browser; |
| class Profile; |
| |
| // The LoginUIService helps track per-profile information for the login related |
| // UIs - for example, whether there is login UI currently on-screen. |
| class LoginUIService : public KeyedService { |
| public: |
| // Various UI components implement this API to allow LoginUIService to |
| // manipulate their associated login UI. |
| class LoginUI { |
| public: |
| // Invoked when the login UI should be brought to the foreground. |
| virtual void FocusUI() = 0; |
| |
| // Invoked when the login UI should be closed. This can be invoked if the |
| // user takes an action that should display new login UI. |
| virtual void CloseUI() = 0; |
| protected: |
| virtual ~LoginUI() {} |
| }; |
| |
| // Interface for obervers of LoginUIService. |
| class Observer { |
| public: |
| // Called when a new login UI is shown. |
| // |ui| The login UI that was just shown. Will never be null. |
| virtual void OnLoginUIShown(LoginUI* ui) {} |
| |
| // Called when a login UI is closed. |
| // |ui| The login UI that was just closed; will never be null. |
| virtual void OnLoginUIClosed(LoginUI* ui) {} |
| |
| // Called when the sync confirmation UI is closed. |configure_sync_first| |
| // is true if the user has requested to configure the sync settings before |
| // sync starts. |
| virtual void OnSyncConfirmationUIClosed(bool configure_sync_first) {} |
| |
| // Called when a confirmation UI for untrusted signin is shown. |
| virtual void OnUntrustedLoginUIShown() {} |
| |
| protected: |
| virtual ~Observer() {} |
| }; |
| |
| explicit LoginUIService(Profile* profile); |
| ~LoginUIService() override; |
| |
| // Gets the currently active login UI, or null if no login UI is active. |
| LoginUI* current_login_ui() const { |
| return ui_; |
| } |
| |
| // |observer| The observer to add or remove; cannot be NULL. |
| void AddObserver(Observer* observer); |
| void RemoveObserver(Observer* observer); |
| |
| // Sets the currently active login UI. It is illegal to call this if there is |
| // already login UI visible. |
| void SetLoginUI(LoginUI* ui); |
| |
| // Called when login UI is closed. If the passed UI is the current login UI, |
| // sets current_login_ui() to null. |
| void LoginUIClosed(LoginUI* ui); |
| |
| // Called when the sync settings confirmation UI is closed. |
| void SyncConfirmationUIClosed(bool configure_sync_first); |
| |
| // Called when a confirmation UI for untrusted signin is shown. |
| void UntrustedLoginUIShown(); |
| |
| // Delegate to an existing login dialog if one exists. |
| // If not, we make a new popup dialog window, and set it to |
| // chrome://signin to ask the user to sign in to chrome. |
| void ShowLoginPopup(); |
| |
| // Displays login results. |
| void DisplayLoginResult(Browser* browser, const base::string16& message); |
| |
| // Gets the last login result set through |DisplayLoginResult|. |
| const base::string16& GetLastLoginResult(); |
| |
| private: |
| // Weak pointer to the currently active login UI, or null if none. |
| LoginUI* ui_; |
| Profile* profile_; |
| |
| // List of observers. |
| ObserverList<Observer> observer_list_; |
| |
| base::string16 last_login_result_; |
| |
| DISALLOW_COPY_AND_ASSIGN(LoginUIService); |
| }; |
| |
| #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |