Chromium Code Reviews| Index: chrome/browser/remoting/setup_flow_login_step.cc |
| diff --git a/chrome/browser/remoting/setup_flow_login_step.cc b/chrome/browser/remoting/setup_flow_login_step.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..25d476101ea4b39319ade8ec270b51f3b06ac6ee |
| --- /dev/null |
| +++ b/chrome/browser/remoting/setup_flow_login_step.cc |
| @@ -0,0 +1,137 @@ |
| +// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/remoting/setup_flow_login_step.h" |
| + |
| +#include "base/json/json_reader.h" |
| +#include "base/json/json_writer.h" |
| +#include "base/string_util.h" |
| +#include "base/utf_string_conversions.h" |
| +#include "base/values.h" |
| +#include "chrome/browser/dom_ui/dom_ui_util.h" |
| +#include "chrome/browser/profiles/profile.h" |
| +#include "chrome/common/net/gaia/gaia_constants.h" |
| +#include "chrome/common/net/gaia/google_service_auth_error.h" |
| + |
| +namespace remoting { |
| + |
| +static const wchar_t kLoginIFrameXPath[] = L"//iframe[@id='login']"; |
| + |
| +SetupFlowLoginStep::SetupFlowLoginStep() { } |
| +SetupFlowLoginStep::~SetupFlowLoginStep() { } |
| + |
| +void SetupFlowLoginStep::HandleMessage(const std::string& message, |
| + const ListValue* args) { |
| + if (message == "SubmitAuth") { |
|
Alpha Left Google
2010/12/21 21:52:04
Make this class DOMMessageHandler and turn this in
Sergey Ulanov
2010/12/21 22:26:49
This is not possible right now. We would have to c
|
| + std::string json(dom_ui_util::GetJsonResponseFromFirstArgumentInList(args)); |
| + if (json.empty()) |
| + return; |
| + |
| + scoped_ptr<Value> parsed_value(base::JSONReader::Read(json, false)); |
| + if (!parsed_value.get() || !parsed_value->IsType(Value::TYPE_DICTIONARY)) { |
| + NOTREACHED() << "Unable to parse auth data"; |
| + return; |
| + } |
| + |
| + CHECK(parsed_value->IsType(Value::TYPE_DICTIONARY)); |
| + |
| + std::string username, password, captcha; |
| + DictionaryValue* result = static_cast<DictionaryValue*>(parsed_value.get()); |
| + if (!result->GetString("user", &username) || |
| + !result->GetString("pass", &password) || |
| + !result->GetString("captcha", &captcha)) { |
| + NOTREACHED() << "Unable to parse auth data"; |
| + return; |
| + } |
| + |
| + OnUserSubmittedAuth(username, password, captcha); |
| + } |
| +} |
| + |
| +void SetupFlowLoginStep::Cancel() { |
| + if (authenticator_.get()) |
| + authenticator_->CancelRequest(); |
| +} |
| + |
| +void SetupFlowLoginStep::OnUserSubmittedAuth(const std::string& user, |
| + const std::string& password, |
| + const std::string& captcha) { |
| + // Save the login name only. |
| + login_ = user; |
| + |
| + // Start the authenticator. |
| + authenticator_.reset( |
| + new GaiaAuthFetcher(this, GaiaConstants::kChromeSource, |
| + flow()->profile()->GetRequestContext())); |
| + authenticator_->StartClientLogin(user, password, |
| + GaiaConstants::kRemotingService, |
| + "", captcha, |
| + GaiaAuthFetcher::HostedAccountsAllowed); |
| +} |
| + |
| +void SetupFlowLoginStep::OnClientLoginSuccess( |
| + const GaiaAuthConsumer::ClientLoginResult& credentials) { |
| + // Save the token for remoting. |
| + remoting_token_ = credentials.token; |
| + |
| + // After login has succeeded try to fetch the token for sync. |
| + // We need the token for sync to connect to the talk network. |
| + authenticator_->StartIssueAuthToken(credentials.sid, credentials.lsid, |
| + GaiaConstants::kSyncService); |
| +} |
| + |
| +void SetupFlowLoginStep::OnClientLoginFailure( |
| + const GoogleServiceAuthError& error) { |
| + ShowGaiaFailed(error); |
| + authenticator_.reset(); |
| +} |
| + |
| +void SetupFlowLoginStep::OnIssueAuthTokenSuccess( |
| + const std::string& service, const std::string& auth_token) { |
| + // Save the sync token. |
| + talk_token_ = auth_token; |
| + authenticator_.reset(); |
| + |
| + Done(new SetupFlowDoneStep()); |
| +} |
| + |
| +void SetupFlowLoginStep::OnIssueAuthTokenFailure(const std::string& service, |
| + const GoogleServiceAuthError& error) { |
| + ShowGaiaFailed(error); |
| + authenticator_.reset(); |
| +} |
| + |
| +void SetupFlowLoginStep::DoStart() { |
| + DictionaryValue args; |
| + args.SetString("iframeToShow", "login"); |
| + // TODO(sergeyu): Supply current login name if the service was started before. |
| + args.SetString("user", ""); |
| + args.SetBoolean("editable_user", true); |
| + ShowGaiaLogin(args); |
| +} |
| + |
| +void SetupFlowLoginStep::ShowGaiaLogin(const DictionaryValue& args) { |
| + DOMUI* dom_ui = flow()->dom_ui(); |
| + DCHECK(dom_ui); |
| + |
| + dom_ui->CallJavascriptFunction(L"showGaiaLoginIframe"); |
| + |
| + std::string json; |
| + base::JSONWriter::Write(&args, false, &json); |
| + std::wstring javascript = std::wstring(L"showGaiaLogin") + |
| + L"(" + UTF8ToWide(json) + L");"; |
| + ExecuteJavascriptInIFrame(kLoginIFrameXPath, javascript); |
| +} |
| + |
| +void SetupFlowLoginStep::ShowGaiaFailed(const GoogleServiceAuthError& error) { |
| + DictionaryValue args; |
| + args.SetString("iframeToShow", "login"); |
| + args.SetString("user", ""); |
| + args.SetInteger("error", error.state()); |
| + args.SetBoolean("editable_user", true); |
| + args.SetString("captchaUrl", error.captcha().image_url.spec()); |
| + ShowGaiaLogin(args); |
| +} |
| + |
| +} // namespace remoting |