Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(415)

Side by Side Diff: chrome/browser/ui/webui/signin/inline_login_handler.cc

Issue 256623002: Implemented inline login dialog for Chrome OS. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Merged SetExtraInitParams. Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 #include "chrome/browser/ui/webui/signin/inline_login_handler.h" 5 #include "chrome/browser/ui/webui/signin/inline_login_handler.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/prefs/pref_service.h"
9 #include "base/strings/utf_string_conversions.h"
8 #include "base/values.h" 10 #include "base/values.h"
9 #include "chrome/browser/browser_process.h" 11 #include "chrome/browser/browser_process.h"
12 #include "chrome/browser/profiles/profile.h"
13 #include "chrome/browser/signin/signin_promo.h"
14 #include "chrome/browser/ui/browser_navigator.h"
15 #include "chrome/common/pref_names.h"
16 #include "content/public/browser/web_contents.h"
10 #include "content/public/browser/web_ui.h" 17 #include "content/public/browser/web_ui.h"
11 #include "google_apis/gaia/gaia_urls.h" 18 #include "google_apis/gaia/gaia_urls.h"
19 #include "net/base/url_util.h"
12 20
13 InlineLoginHandler::InlineLoginHandler() {} 21 InlineLoginHandler::InlineLoginHandler() {}
14 22
15 InlineLoginHandler::~InlineLoginHandler() {} 23 InlineLoginHandler::~InlineLoginHandler() {}
16 24
17 void InlineLoginHandler::RegisterMessages() { 25 void InlineLoginHandler::RegisterMessages() {
18 web_ui()->RegisterMessageCallback("initialize", 26 web_ui()->RegisterMessageCallback("initialize",
19 base::Bind(&InlineLoginHandler::HandleInitializeMessage, 27 base::Bind(&InlineLoginHandler::HandleInitializeMessage,
20 base::Unretained(this))); 28 base::Unretained(this)));
21 web_ui()->RegisterMessageCallback("completeLogin", 29 web_ui()->RegisterMessageCallback("completeLogin",
22 base::Bind(&InlineLoginHandler::HandleCompleteLoginMessage, 30 base::Bind(&InlineLoginHandler::HandleCompleteLoginMessage,
23 base::Unretained(this))); 31 base::Unretained(this)));
32 web_ui()->RegisterMessageCallback(
33 "switchToFullTab",
34 base::Bind(&InlineLoginHandler::HandleSwitchToFullTabMessage,
35 base::Unretained(this)));
24 } 36 }
25 37
26 void InlineLoginHandler::HandleInitializeMessage(const base::ListValue* args) { 38 void InlineLoginHandler::HandleInitializeMessage(const base::ListValue* args) {
27 base::DictionaryValue params; 39 base::DictionaryValue params;
28 40
29 const std::string& app_locale = g_browser_process->GetApplicationLocale(); 41 const std::string& app_locale = g_browser_process->GetApplicationLocale();
30 params.SetString("hl", app_locale); 42 params.SetString("hl", app_locale);
31 GaiaUrls* gaiaUrls = GaiaUrls::GetInstance(); 43 GaiaUrls* gaiaUrls = GaiaUrls::GetInstance();
32 params.SetString("gaiaUrl", gaiaUrls->gaia_url().spec()); 44 params.SetString("gaiaUrl", gaiaUrls->gaia_url().spec());
33 params.SetInteger("authMode", kDefaultAuthMode); 45 params.SetInteger("authMode", InlineLoginHandler::kDesktopAuthMode);
46
47 const GURL& current_url = web_ui()->GetWebContents()->GetURL();
48 signin::Source source = signin::GetSourceForPromoURL(current_url);
49 DCHECK(source != signin::SOURCE_UNKNOWN);
50 if (source == signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT ||
51 source == signin::SOURCE_AVATAR_BUBBLE_SIGN_IN) {
52 // Drop the leading slash in the path.
53 params.SetString("gaiaPath",
54 GaiaUrls::GetInstance()->embedded_signin_url().path().substr(1));
55 }
56
57 params.SetString("continueUrl",
58 signin::GetLandingURL("source", static_cast<int>(source)).spec());
59
60 std::string default_email;
61 if (source != signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT) {
62 default_email = Profile::FromWebUI(web_ui())->GetPrefs()->
63 GetString(prefs::kGoogleServicesLastUsername);
64 } else {
65 if (!net::GetValueForKeyInQuery(current_url, "email", &default_email))
66 default_email.clear();
67 }
68 if (!default_email.empty())
69 params.SetString("email", default_email);
70
71 std::string frame_url;
72 net::GetValueForKeyInQuery(current_url, "frameUrl", &frame_url);
73 if (!frame_url.empty())
74 params.SetString("frameUrl", frame_url);
75
76 std::string is_constrained;
77 net::GetValueForKeyInQuery(current_url, "constrained", &is_constrained);
78 if (!is_constrained.empty())
79 params.SetString("constrained", is_constrained);
80
81 // TODO(rogerta): this needs to be passed on to gaia somehow.
82 std::string read_only_email;
83 net::GetValueForKeyInQuery(current_url, "readOnlyEmail", &read_only_email);
84 if (!read_only_email.empty())
85 params.SetString("readOnlyEmail", read_only_email);
34 86
35 SetExtraInitParams(params); 87 SetExtraInitParams(params);
36 88
37 web_ui()->CallJavascriptFunction("inline.login.loadAuthExtension", params); 89 web_ui()->CallJavascriptFunction("inline.login.loadAuthExtension", params);
38 } 90 }
39 91
40 void InlineLoginHandler::HandleCompleteLoginMessage( 92 void InlineLoginHandler::HandleCompleteLoginMessage(
41 const base::ListValue* args) { 93 const base::ListValue* args) {
42 CompleteLogin(args); 94 CompleteLogin(args);
43 } 95 }
96
97 void InlineLoginHandler::HandleSwitchToFullTabMessage(
98 const base::ListValue* args) {
99 base::string16 url_str;
100 CHECK(args->GetString(0, &url_str));
101
102 content::WebContents* web_contents = web_ui()->GetWebContents();
103 GURL main_frame_url(web_contents->GetURL());
104 main_frame_url = net::AppendOrReplaceQueryParameter(
105 main_frame_url, "frameUrl", base::UTF16ToASCII(url_str));
106 chrome::NavigateParams params(
107 Profile::FromWebUI(web_ui()),
108 net::AppendOrReplaceQueryParameter(main_frame_url, "constrained", "0"),
109 content::PAGE_TRANSITION_AUTO_TOPLEVEL);
110 chrome::Navigate(&params);
111
112 web_ui()->CallJavascriptFunction("inline.login.closeDialog");
113 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698