15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/automation/automation_event_observers.h"
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/browser_process.h"
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/chromeos/login/existing_user_controller.h"
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using chromeos::ExistingUserController;
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)LoginEventObserver::LoginEventObserver(
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    AutomationEventQueue* event_queue,
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    AutomationProvider* automation)
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    : AutomationEventObserver(event_queue, false),
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      automation_(automation->AsWeakPtr()) {
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ExistingUserController* controller =
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      ExistingUserController::current_controller();
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DCHECK(controller);
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  controller->set_login_status_consumer(this);
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)LoginEventObserver::~LoginEventObserver() {}
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void LoginEventObserver::OnLoginFailure(const chromeos::LoginFailure& error) {
25868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  VLOG(1) << "Login failed, error=" << error.GetErrorString();
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  _NotifyLoginEvent(error.GetErrorString());
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
292a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void LoginEventObserver::OnLoginSuccess(
308bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles)    const chromeos::UserContext& user_context) {
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // Profile changes after login. Ensure AutomationProvider refers to
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  // the correct one.
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (automation_) {
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    automation_->set_profile(
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)        g_browser_process->profile_manager()->GetLastUsedProfile());
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  }
37868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  VLOG(1) << "Successfully logged in.";
38868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)  _NotifyLoginEvent(std::string());
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void LoginEventObserver::_NotifyLoginEvent(const std::string& error_string) {
425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  DictionaryValue* dict = new DictionaryValue;
435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  dict->SetString("type", "login_event");
445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (error_string.length())
455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    dict->SetString("error_string", error_string);
465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  NotifyEvent(dict);
475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  ExistingUserController* controller =
485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)      ExistingUserController::current_controller();
495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  if (controller)
505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)    controller->set_login_status_consumer(NULL);
515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  RemoveIfDone();
525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}
53