| 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 #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" | 8 #include "base/prefs/pref_service.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 10 #include "base/values.h" | 10 #include "base/values.h" |
| (...skipping 29 matching lines...) Expand all Loading... |
| 40 | 40 |
| 41 const std::string& app_locale = g_browser_process->GetApplicationLocale(); | 41 const std::string& app_locale = g_browser_process->GetApplicationLocale(); |
| 42 params.SetString("hl", app_locale); | 42 params.SetString("hl", app_locale); |
| 43 GaiaUrls* gaiaUrls = GaiaUrls::GetInstance(); | 43 GaiaUrls* gaiaUrls = GaiaUrls::GetInstance(); |
| 44 params.SetString("gaiaUrl", gaiaUrls->gaia_url().spec()); | 44 params.SetString("gaiaUrl", gaiaUrls->gaia_url().spec()); |
| 45 params.SetInteger("authMode", InlineLoginHandler::kDesktopAuthMode); | 45 params.SetInteger("authMode", InlineLoginHandler::kDesktopAuthMode); |
| 46 | 46 |
| 47 const GURL& current_url = web_ui()->GetWebContents()->GetURL(); | 47 const GURL& current_url = web_ui()->GetWebContents()->GetURL(); |
| 48 signin::Source source = signin::GetSourceForPromoURL(current_url); | 48 signin::Source source = signin::GetSourceForPromoURL(current_url); |
| 49 if (source == signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT || | 49 if (source == signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT || |
| 50 source == signin::SOURCE_AVATAR_BUBBLE_SIGN_IN) { | 50 source == signin::SOURCE_AVATAR_BUBBLE_SIGN_IN || |
| 51 source == signin::SOURCE_REAUTH) { |
| 51 // Drop the leading slash in the path. | 52 // Drop the leading slash in the path. |
| 52 params.SetString( | 53 params.SetString( |
| 53 "gaiaPath", | 54 "gaiaPath", |
| 54 GaiaUrls::GetInstance()->embedded_signin_url().path().substr(1)); | 55 GaiaUrls::GetInstance()->embedded_signin_url().path().substr(1)); |
| 55 } | 56 } |
| 56 | 57 |
| 57 params.SetString( | 58 params.SetString( |
| 58 "continueUrl", | 59 "continueUrl", |
| 59 signin::GetLandingURL("source", static_cast<int>(source)).spec()); | 60 signin::GetLandingURL("source", static_cast<int>(source)).spec()); |
| 60 | 61 |
| 61 std::string default_email; | 62 std::string default_email; |
| 62 if (source != signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT) { | 63 if (source != signin::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT && |
| 64 source != signin::SOURCE_REAUTH) { |
| 63 default_email = Profile::FromWebUI(web_ui())->GetPrefs()->GetString( | 65 default_email = Profile::FromWebUI(web_ui())->GetPrefs()->GetString( |
| 64 prefs::kGoogleServicesLastUsername); | 66 prefs::kGoogleServicesLastUsername); |
| 65 } else { | 67 } else { |
| 66 if (!net::GetValueForKeyInQuery(current_url, "email", &default_email)) | 68 if (!net::GetValueForKeyInQuery(current_url, "email", &default_email)) |
| 67 default_email.clear(); | 69 default_email.clear(); |
| 68 } | 70 } |
| 69 if (!default_email.empty()) | 71 if (!default_email.empty()) |
| 70 params.SetString("email", default_email); | 72 params.SetString("email", default_email); |
| 71 | 73 |
| 72 std::string frame_url; | 74 std::string frame_url; |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 105 main_frame_url = net::AppendOrReplaceQueryParameter( | 107 main_frame_url = net::AppendOrReplaceQueryParameter( |
| 106 main_frame_url, "frameUrl", base::UTF16ToASCII(url_str)); | 108 main_frame_url, "frameUrl", base::UTF16ToASCII(url_str)); |
| 107 chrome::NavigateParams params( | 109 chrome::NavigateParams params( |
| 108 Profile::FromWebUI(web_ui()), | 110 Profile::FromWebUI(web_ui()), |
| 109 net::AppendOrReplaceQueryParameter(main_frame_url, "constrained", "0"), | 111 net::AppendOrReplaceQueryParameter(main_frame_url, "constrained", "0"), |
| 110 content::PAGE_TRANSITION_AUTO_TOPLEVEL); | 112 content::PAGE_TRANSITION_AUTO_TOPLEVEL); |
| 111 chrome::Navigate(¶ms); | 113 chrome::Navigate(¶ms); |
| 112 | 114 |
| 113 web_ui()->CallJavascriptFunction("inline.login.closeDialog"); | 115 web_ui()->CallJavascriptFunction("inline.login.closeDialog"); |
| 114 } | 116 } |
| OLD | NEW |