| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |
| 6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ | 6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |
| 7 | 7 |
| 8 #include "base/macros.h" | 8 #include "base/macros.h" |
| 9 #include "base/observer_list.h" | 9 #include "base/observer_list.h" |
| 10 #include "base/strings/string16.h" | 10 #include "base/strings/string16.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 | 26 |
| 27 // Invoked when the login UI should be closed. This can be invoked if the | 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. | 28 // user takes an action that should display new login UI. |
| 29 virtual void CloseUI() = 0; | 29 virtual void CloseUI() = 0; |
| 30 protected: | 30 protected: |
| 31 virtual ~LoginUI() {} | 31 virtual ~LoginUI() {} |
| 32 }; | 32 }; |
| 33 | 33 |
| 34 // Used when the sync confirmation UI is closed to signify which option was | 34 // Used when the sync confirmation UI is closed to signify which option was |
| 35 // selected by the user. | 35 // selected by the user. |
| 36 enum SyncConfirmationUIClosedResults { | 36 enum SyncConfirmationUIClosedResult { |
| 37 // Open the activity controls URL. |
| 38 OPEN_ACTIVITY_CONTROLS_URL = 1 << 0, |
| 37 // Start sync immediately. | 39 // Start sync immediately. |
| 38 SYNC_WITH_DEFAULT_SETTINGS, | 40 SYNC_WITH_DEFAULT_SETTINGS = 1 << 1, |
| 39 // Show the user the sync settings before starting sync. | 41 // Show the user the sync settings before starting sync. |
| 40 CONFIGURE_SYNC_FIRST, | 42 CONFIGURE_SYNC_FIRST = 1 << 2, |
| 41 // The signing process was aborted, don't start sync or show settings. | 43 // The signing process was aborted, don't start sync or show settings. |
| 42 ABORT_SIGNIN, | 44 ABORT_SIGNIN = 1 << 3, |
| 43 }; | 45 }; |
| 44 | 46 |
| 45 // Interface for obervers of LoginUIService. | 47 // Interface for obervers of LoginUIService. |
| 46 class Observer { | 48 class Observer { |
| 47 public: | 49 public: |
| 48 // Called when a new login UI is shown. | 50 // Called when a new login UI is shown. |
| 49 // |ui| The login UI that was just shown. Will never be null. | 51 // |ui| The login UI that was just shown. Will never be null. |
| 50 virtual void OnLoginUIShown(LoginUI* ui) {} | 52 virtual void OnLoginUIShown(LoginUI* ui) {} |
| 51 | 53 |
| 52 // Called when a login UI is closed. | 54 // Called when a login UI is closed. |
| 53 // |ui| The login UI that was just closed; will never be null. | 55 // |ui| The login UI that was just closed; will never be null. |
| 54 virtual void OnLoginUIClosed(LoginUI* ui) {} | 56 virtual void OnLoginUIClosed(LoginUI* ui) {} |
| 55 | 57 |
| 56 // Called when the sync confirmation UI is closed. |results| indicates the | 58 // Called when the sync confirmation UI is closed. |result| is a bitmask for |
| 57 // option chosen by the user in the confirmation UI. | 59 // the LoginUIService::SyncConfirmationUIClosedResult enum that indicates |
| 58 virtual void OnSyncConfirmationUIClosed( | 60 // the options chosen by the user in the confirmation UI. |
| 59 SyncConfirmationUIClosedResults results) {} | 61 virtual void OnSyncConfirmationUIClosed(uint32_t result) {} |
| 60 | 62 |
| 61 // Called when a confirmation UI for untrusted signin is shown. | 63 // Called when a confirmation UI for untrusted signin is shown. |
| 62 virtual void OnUntrustedLoginUIShown() {} | 64 virtual void OnUntrustedLoginUIShown() {} |
| 63 | 65 |
| 64 protected: | 66 protected: |
| 65 virtual ~Observer() {} | 67 virtual ~Observer() {} |
| 66 }; | 68 }; |
| 67 | 69 |
| 68 explicit LoginUIService(Profile* profile); | 70 explicit LoginUIService(Profile* profile); |
| 69 ~LoginUIService() override; | 71 ~LoginUIService() override; |
| 70 | 72 |
| 71 // Gets the currently active login UI, or null if no login UI is active. | 73 // Gets the currently active login UI, or null if no login UI is active. |
| 72 LoginUI* current_login_ui() const { | 74 LoginUI* current_login_ui() const { |
| 73 return ui_; | 75 return ui_; |
| 74 } | 76 } |
| 75 | 77 |
| 76 // |observer| The observer to add or remove; cannot be NULL. | 78 // |observer| The observer to add or remove; cannot be NULL. |
| 77 void AddObserver(Observer* observer); | 79 void AddObserver(Observer* observer); |
| 78 void RemoveObserver(Observer* observer); | 80 void RemoveObserver(Observer* observer); |
| 79 | 81 |
| 80 // Sets the currently active login UI. It is illegal to call this if there is | 82 // Sets the currently active login UI. It is illegal to call this if there is |
| 81 // already login UI visible. | 83 // already login UI visible. |
| 82 void SetLoginUI(LoginUI* ui); | 84 void SetLoginUI(LoginUI* ui); |
| 83 | 85 |
| 84 // Called when login UI is closed. If the passed UI is the current login UI, | 86 // Called when login UI is closed. If the passed UI is the current login UI, |
| 85 // sets current_login_ui() to null. | 87 // sets current_login_ui() to null. |
| 86 void LoginUIClosed(LoginUI* ui); | 88 void LoginUIClosed(LoginUI* ui); |
| 87 | 89 |
| 88 // Called when the sync settings confirmation UI is closed. | 90 // Called when the sync confirmation UI is closed. |result| is a bitmask for |
| 89 void SyncConfirmationUIClosed(SyncConfirmationUIClosedResults results); | 91 // the LoginUIService::SyncConfirmationUIClosedResult enum that indicates |
| 92 // the options chosen by the user in the confirmation UI. |
| 93 void SyncConfirmationUIClosed(uint32_t result); |
| 90 | 94 |
| 91 // Called when a confirmation UI for untrusted signin is shown. | 95 // Called when a confirmation UI for untrusted signin is shown. |
| 92 void UntrustedLoginUIShown(); | 96 void UntrustedLoginUIShown(); |
| 93 | 97 |
| 94 // Delegate to an existing login dialog if one exists. | 98 // Delegate to an existing login dialog if one exists. |
| 95 // If not, we make a new popup dialog window, and set it to | 99 // If not, we make a new popup dialog window, and set it to |
| 96 // chrome://signin to ask the user to sign in to chrome. | 100 // chrome://signin to ask the user to sign in to chrome. |
| 97 void ShowLoginPopup(); | 101 void ShowLoginPopup(); |
| 98 | 102 |
| 99 // Displays login results. | 103 // Displays login results. |
| 100 void DisplayLoginResult(Browser* browser, const base::string16& message); | 104 void DisplayLoginResult(Browser* browser, const base::string16& message); |
| 101 | 105 |
| 102 // Gets the last login result set through |DisplayLoginResult|. | 106 // Gets the last login result set through |DisplayLoginResult|. |
| 103 const base::string16& GetLastLoginResult(); | 107 const base::string16& GetLastLoginResult(); |
| 104 | 108 |
| 105 private: | 109 private: |
| 106 // Weak pointer to the currently active login UI, or null if none. | 110 // Weak pointer to the currently active login UI, or null if none. |
| 107 LoginUI* ui_; | 111 LoginUI* ui_; |
| 108 Profile* profile_; | 112 Profile* profile_; |
| 109 | 113 |
| 110 // List of observers. | 114 // List of observers. |
| 111 base::ObserverList<Observer> observer_list_; | 115 base::ObserverList<Observer> observer_list_; |
| 112 | 116 |
| 113 base::string16 last_login_result_; | 117 base::string16 last_login_result_; |
| 114 | 118 |
| 115 DISALLOW_COPY_AND_ASSIGN(LoginUIService); | 119 DISALLOW_COPY_AND_ASSIGN(LoginUIService); |
| 116 }; | 120 }; |
| 117 | 121 |
| 118 #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ | 122 #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_LOGIN_UI_SERVICE_H_ |
| OLD | NEW |