Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / chrome / browser / ui / webui / signin / login_ui_service.h
blobd15efe7d2bc4b5a36166c796ae96e8f8aa01cf23
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_
6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_
8 #include "base/basictypes.h"
9 #include "base/observer_list.h"
10 #include "base/strings/string16.h"
11 #include "components/keyed_service/core/keyed_service.h"
13 class Browser;
14 class Profile;
16 // The LoginUIService helps track per-profile information for the login related
17 // UIs - for example, whether there is login UI currently on-screen.
18 class LoginUIService : public KeyedService {
19 public:
20 // Various UI components implement this API to allow LoginUIService to
21 // manipulate their associated login UI.
22 class LoginUI {
23 public:
24 // Invoked when the login UI should be brought to the foreground.
25 virtual void FocusUI() = 0;
27 // Invoked when the login UI should be closed. This can be invoked if the
28 // user takes an action that should display new login UI.
29 virtual void CloseUI() = 0;
30 protected:
31 virtual ~LoginUI() {}
34 // Interface for obervers of LoginUIService.
35 class Observer {
36 public:
37 // Called when a new login UI is shown.
38 // |ui| The login UI that was just shown. Will never be null.
39 virtual void OnLoginUIShown(LoginUI* ui) {}
41 // Called when a login UI is closed.
42 // |ui| The login UI that was just closed; will never be null.
43 virtual void OnLoginUIClosed(LoginUI* ui) {}
45 // Called when the sync confirmation UI is closed. |configure_sync_first|
46 // is true if the user has requested to configure the sync settings before
47 // sync starts.
48 virtual void OnSyncConfirmationUIClosed(bool configure_sync_first) {}
50 // Called when a confirmation UI for untrusted signin is shown.
51 virtual void OnUntrustedLoginUIShown() {}
53 protected:
54 virtual ~Observer() {}
57 explicit LoginUIService(Profile* profile);
58 ~LoginUIService() override;
60 // Gets the currently active login UI, or null if no login UI is active.
61 LoginUI* current_login_ui() const {
62 return ui_;
65 // |observer| The observer to add or remove; cannot be NULL.
66 void AddObserver(Observer* observer);
67 void RemoveObserver(Observer* observer);
69 // Sets the currently active login UI. It is illegal to call this if there is
70 // already login UI visible.
71 void SetLoginUI(LoginUI* ui);
73 // Called when login UI is closed. If the passed UI is the current login UI,
74 // sets current_login_ui() to null.
75 void LoginUIClosed(LoginUI* ui);
77 // Called when the sync settings confirmation UI is closed.
78 void SyncConfirmationUIClosed(bool configure_sync_first);
80 // Called when a confirmation UI for untrusted signin is shown.
81 void UntrustedLoginUIShown();
83 // Delegate to an existing login dialog if one exists.
84 // If not, we make a new popup dialog window, and set it to
85 // chrome://signin to ask the user to sign in to chrome.
86 void ShowLoginPopup();
88 // Displays login results.
89 void DisplayLoginResult(Browser* browser, const base::string16& message);
91 // Gets the last login result set through |DisplayLoginResult|.
92 const base::string16& GetLastLoginResult();
94 private:
95 // Weak pointer to the currently active login UI, or null if none.
96 LoginUI* ui_;
97 Profile* profile_;
99 // List of observers.
100 base::ObserverList<Observer> observer_list_;
102 base::string16 last_login_result_;
104 DISALLOW_COPY_AND_ASSIGN(LoginUIService);
107 #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_