Upstream version 10.39.225.0
[platform/framework/web/crosswalk.git] / src / chrome / browser / ui / webui / signin / login_ui_service.h
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.
4
5 #ifndef CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_
6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_
7
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"
12
13 class Browser;
14 class Profile;
15
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;
26
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() {}
32   };
33
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) {}
40
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) {}
44
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) {}
49
50     // Called when a confirmation UI for untrusted signin is shown.
51     virtual void OnUntrustedLoginUIShown() {}
52
53    protected:
54     virtual ~Observer() {}
55   };
56
57   explicit LoginUIService(Profile* profile);
58   virtual ~LoginUIService();
59
60   // Gets the currently active login UI, or null if no login UI is active.
61   LoginUI* current_login_ui() const {
62     return ui_;
63   }
64
65   // |observer| The observer to add or remove; cannot be NULL.
66   void AddObserver(Observer* observer);
67   void RemoveObserver(Observer* observer);
68
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);
72
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);
76
77   // Called when the sync settings confirmation UI is closed.
78   void SyncConfirmationUIClosed(bool configure_sync_first);
79
80   // Called when a confirmation UI for untrusted signin is shown.
81   void UntrustedLoginUIShown();
82
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();
87
88   // Displays login results.
89   void DisplayLoginResult(Browser* browser, const base::string16& message);
90
91   // Gets the last login result set through |DisplayLoginResult|.
92   const base::string16& GetLastLoginResult();
93
94  private:
95   // Weak pointer to the currently active login UI, or null if none.
96   LoginUI* ui_;
97   Profile* profile_;
98
99   // List of observers.
100   ObserverList<Observer> observer_list_;
101
102   base::string16 last_login_result_;
103
104   DISALLOW_COPY_AND_ASSIGN(LoginUIService);
105 };
106
107 #endif  // CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_