OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_INLINE_LOGIN_HANDLER_IMPL_H_ | 5 #ifndef CHROME_BROWSER_UI_WEBUI_SIGNIN_INLINE_LOGIN_HANDLER_IMPL_H_ |
6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_INLINE_LOGIN_HANDLER_IMPL_H_ | 6 #define CHROME_BROWSER_UI_WEBUI_SIGNIN_INLINE_LOGIN_HANDLER_IMPL_H_ |
7 | 7 |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
11 #include "base/memory/weak_ptr.h" | 11 #include "base/memory/weak_ptr.h" |
12 #include "chrome/browser/ui/sync/one_click_signin_sync_starter.h" | 12 #include "chrome/browser/ui/sync/one_click_signin_sync_starter.h" |
13 #include "chrome/browser/ui/webui/signin/inline_login_handler.h" | 13 #include "chrome/browser/ui/webui/signin/inline_login_handler.h" |
14 #include "content/public/browser/web_contents_delegate.h" | 14 #include "content/public/browser/web_contents_delegate.h" |
15 | 15 |
16 class GaiaAuthFetcher; | 16 class GaiaAuthFetcher; |
17 | 17 |
18 // Implementation for the inline login WebUI handler on desktop Chrome. Once | 18 // Implementation for the inline login WebUI handler on desktop Chrome. Once |
19 // CrOS migrates to the same webview approach as desktop Chrome, much of the | 19 // CrOS migrates to the same webview approach as desktop Chrome, much of the |
20 // code in this class should move to its base class |InlineLoginHandler|. | 20 // code in this class should move to its base class |InlineLoginHandler|. |
21 class InlineLoginHandlerImpl : public InlineLoginHandler, | 21 class InlineLoginHandlerImpl : public InlineLoginHandler, |
22 public content::WebContentsDelegate { | 22 public content::WebContentsDelegate, |
| 23 public content::WebContentsObserver { |
23 public: | 24 public: |
24 InlineLoginHandlerImpl(); | 25 InlineLoginHandlerImpl(); |
25 virtual ~InlineLoginHandlerImpl(); | 26 virtual ~InlineLoginHandlerImpl(); |
26 | 27 |
27 using InlineLoginHandler::web_ui; | 28 using InlineLoginHandler::web_ui; |
28 | 29 |
29 base::WeakPtr<InlineLoginHandlerImpl> GetWeakPtr() { | 30 base::WeakPtr<InlineLoginHandlerImpl> GetWeakPtr() { |
30 return weak_factory_.GetWeakPtr(); | 31 return weak_factory_.GetWeakPtr(); |
31 } | 32 } |
32 | 33 |
33 Browser* GetDesktopBrowser(); | 34 Browser* GetDesktopBrowser(); |
34 void SyncStarterCallback(OneClickSigninSyncStarter::SyncSetupResult result); | 35 void SyncStarterCallback(OneClickSigninSyncStarter::SyncSetupResult result); |
35 // Closes the current tab and shows the account management view of the avatar | 36 // Closes the current tab and shows the account management view of the avatar |
36 // bubble if |show_account_management| is true. | 37 // bubble if |show_account_management| is true. |
37 void CloseTab(bool show_account_management); | 38 void CloseTab(bool show_account_management); |
38 void HandleLoginError(const std::string& error_msg); | 39 void HandleLoginError(const std::string& error_msg); |
39 | 40 |
40 private: | 41 private: |
41 // InlineLoginHandler overrides: | 42 // InlineLoginHandler overrides: |
42 virtual void SetExtraInitParams(base::DictionaryValue& params) OVERRIDE; | 43 virtual void SetExtraInitParams(base::DictionaryValue& params) OVERRIDE; |
43 virtual void CompleteLogin(const base::ListValue* args) OVERRIDE; | 44 virtual void CompleteLogin(const base::ListValue* args) OVERRIDE; |
44 | 45 |
45 // Overridden from content::WebContentsDelegate. | 46 // Overridden from content::WebContentsDelegate. |
46 virtual bool HandleContextMenu( | 47 virtual bool HandleContextMenu( |
47 const content::ContextMenuParams& params) OVERRIDE; | 48 const content::ContextMenuParams& params) OVERRIDE; |
48 | 49 |
| 50 // Overridden from content::WebContentsObserver overrides. |
| 51 virtual void DidCommitProvisionalLoadForFrame( |
| 52 content::RenderFrameHost* render_frame_host, |
| 53 const GURL& url, |
| 54 content::PageTransition transition_type) OVERRIDE; |
| 55 |
49 base::WeakPtrFactory<InlineLoginHandlerImpl> weak_factory_; | 56 base::WeakPtrFactory<InlineLoginHandlerImpl> weak_factory_; |
50 std::string email_; | 57 // True if the user has navigated to untrusted domains during the signin |
51 std::string password_; | 58 // process. |
52 std::string session_index_; | 59 bool confirm_untrusted_signin_; |
53 bool choose_what_to_sync_; | |
54 | 60 |
55 DISALLOW_COPY_AND_ASSIGN(InlineLoginHandlerImpl); | 61 DISALLOW_COPY_AND_ASSIGN(InlineLoginHandlerImpl); |
56 }; | 62 }; |
57 | 63 |
58 #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_INLINE_LOGIN_HANDLER_IMPL_H_ | 64 #endif // CHROME_BROWSER_UI_WEBUI_SIGNIN_INLINE_LOGIN_HANDLER_IMPL_H_ |
OLD | NEW |