Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/chromeos/power/power_button_observer.h" | 5 #include "chrome/browser/chromeos/power/power_button_observer.h" |
| 6 | 6 |
| 7 #include "ash/shell.h" | 7 #include "ash/shell.h" |
| 8 #include "ash/system/user/login_status.h" | |
| 8 #include "ash/wm/power_button_controller.h" | 9 #include "ash/wm/power_button_controller.h" |
| 9 #include "base/logging.h" | 10 #include "base/logging.h" |
| 10 #include "chrome/browser/chromeos/login/screen_locker.h" | 11 #include "chrome/browser/chromeos/login/screen_locker.h" |
| 11 #include "chrome/browser/chromeos/login/user.h" | 12 #include "chrome/browser/chromeos/login/user.h" |
| 12 #include "chrome/browser/chromeos/login/user_manager.h" | 13 #include "chrome/browser/chromeos/login/user_manager.h" |
| 13 #include "chrome/browser/chromeos/power/power_button_controller_delegate_chromeo s.h" | 14 #include "chrome/browser/chromeos/power/power_button_controller_delegate_chromeo s.h" |
| 14 #include "chrome/common/chrome_notification_types.h" | 15 #include "chrome/common/chrome_notification_types.h" |
| 15 #include "chromeos/dbus/dbus_thread_manager.h" | 16 #include "chromeos/dbus/dbus_thread_manager.h" |
| 16 #include "content/public/browser/notification_service.h" | 17 #include "content/public/browser/notification_service.h" |
| 17 | 18 |
| 18 namespace chromeos { | 19 namespace chromeos { |
| 19 | 20 |
| 20 PowerButtonObserver::PowerButtonObserver() { | 21 PowerButtonObserver::PowerButtonObserver() { |
| 21 ash::PowerButtonController* controller = | 22 ash::Shell::GetInstance()->power_button_controller()-> |
| 22 ash::Shell::GetInstance()->power_button_controller(); | 23 set_delegate(new PowerButtonControllerDelegateChromeos); |
| 23 controller->set_delegate(new PowerButtonControllerDelegateChromeos); | |
| 24 | 24 |
| 25 registrar_.Add( | 25 registrar_.Add( |
| 26 this, | 26 this, |
| 27 chrome::NOTIFICATION_LOGIN_USER_CHANGED, | 27 chrome::NOTIFICATION_LOGIN_USER_CHANGED, |
| 28 content::NotificationService::AllSources()); | 28 content::NotificationService::AllSources()); |
| 29 registrar_.Add( | 29 registrar_.Add( |
| 30 this, | 30 this, |
| 31 content::NOTIFICATION_APP_TERMINATING, | 31 content::NOTIFICATION_APP_TERMINATING, |
| 32 content::NotificationService::AllSources()); | 32 content::NotificationService::AllSources()); |
| 33 registrar_.Add( | 33 registrar_.Add( |
| 34 this, | 34 this, |
| 35 chrome::NOTIFICATION_SCREEN_LOCK_STATE_CHANGED, | 35 chrome::NOTIFICATION_SCREEN_LOCK_STATE_CHANGED, |
| 36 content::NotificationService::AllSources()); | 36 content::NotificationService::AllSources()); |
| 37 | 37 |
| 38 DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(this); | 38 DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(this); |
| 39 | 39 |
| 40 // Tell the controller about the initial state. | 40 // Tell the controller about the initial state. |
| 41 const UserManager* user_manager = UserManager::Get(); | 41 const UserManager* user_manager = UserManager::Get(); |
| 42 bool logged_in = user_manager->IsUserLoggedIn(); | 42 ash::user::LoginStatus login_status = ash::user::LOGGED_IN_NONE; |
| 43 bool is_guest = logged_in && user_manager->GetLoggedInUser().is_guest(); | 43 if (user_manager->IsUserLoggedIn()) { |
| 44 controller->OnLoginStateChange(logged_in, is_guest); | 44 if (user_manager->GetLoggedInUser().is_guest()) |
| 45 login_status = ash::user::LOGGED_IN_GUEST; | |
| 46 else | |
| 47 login_status = ash::user::LOGGED_IN_USER; | |
| 48 } | |
| 49 ash::Shell::GetInstance()->OnLoginStateChanged(login_status); | |
| 45 | 50 |
| 46 const ScreenLocker* locker = ScreenLocker::default_screen_locker(); | 51 const ScreenLocker* locker = ScreenLocker::default_screen_locker(); |
| 47 bool locked = locker && locker->locked(); | 52 bool locked = locker && locker->locked(); |
| 48 controller->OnLockStateChange(locked); | 53 ash::Shell::GetInstance()->OnLockStateChanged(locked); |
| 49 } | 54 } |
| 50 | 55 |
| 51 PowerButtonObserver::~PowerButtonObserver() { | 56 PowerButtonObserver::~PowerButtonObserver() { |
| 52 DBusThreadManager::Get()->GetPowerManagerClient()->RemoveObserver(this); | 57 DBusThreadManager::Get()->GetPowerManagerClient()->RemoveObserver(this); |
| 53 } | 58 } |
| 54 | 59 |
| 55 void PowerButtonObserver::Observe(int type, | 60 void PowerButtonObserver::Observe(int type, |
| 56 const content::NotificationSource& source, | 61 const content::NotificationSource& source, |
| 57 const content::NotificationDetails& details) { | 62 const content::NotificationDetails& details) { |
| 58 switch (type) { | 63 switch (type) { |
| 59 case chrome::NOTIFICATION_LOGIN_USER_CHANGED: { | 64 case chrome::NOTIFICATION_LOGIN_USER_CHANGED: { |
| 60 const User* user = &UserManager::Get()->GetLoggedInUser(); | 65 const User* user = &UserManager::Get()->GetLoggedInUser(); |
| 61 ash::Shell::GetInstance()->power_button_controller()-> | 66 ash::user::LoginStatus login_status = user->is_guest() ? |
|
sky
2012/04/19 15:43:29
this is nearly identical to 43-48. Refactor into a
Jun Mukai
2012/04/20 07:27:33
Done.
| |
| 62 OnLoginStateChange(true /* logged_in */, user->is_guest()); | 67 ash::user::LOGGED_IN_GUEST : |
| 68 ash::user::LOGGED_IN_USER; | |
| 69 ash::Shell::GetInstance()->OnLoginStateChanged(login_status); | |
| 63 break; | 70 break; |
| 64 } | 71 } |
| 65 case content::NOTIFICATION_APP_TERMINATING: | 72 case content::NOTIFICATION_APP_TERMINATING: |
| 66 ash::Shell::GetInstance()->power_button_controller()->OnExit(); | 73 ash::Shell::GetInstance()->OnAppTerminating(); |
| 67 break; | 74 break; |
| 68 case chrome::NOTIFICATION_SCREEN_LOCK_STATE_CHANGED: { | 75 case chrome::NOTIFICATION_SCREEN_LOCK_STATE_CHANGED: { |
| 69 bool locked = *content::Details<bool>(details).ptr(); | 76 bool locked = *content::Details<bool>(details).ptr(); |
| 70 ash::Shell::GetInstance()->power_button_controller()-> | 77 ash::Shell::GetInstance()->OnLockStateChanged(locked); |
| 71 OnLockStateChange(locked); | |
| 72 break; | 78 break; |
| 73 } | 79 } |
| 74 default: | 80 default: |
| 75 NOTREACHED() << "Unexpected notification " << type; | 81 NOTREACHED() << "Unexpected notification " << type; |
| 76 } | 82 } |
| 77 } | 83 } |
| 78 | 84 |
| 79 void PowerButtonObserver::PowerButtonStateChanged( | 85 void PowerButtonObserver::PowerButtonStateChanged( |
| 80 bool down, const base::TimeTicks& timestamp) { | 86 bool down, const base::TimeTicks& timestamp) { |
| 81 ash::Shell::GetInstance()->power_button_controller()-> | 87 ash::Shell::GetInstance()->power_button_controller()-> |
| 82 OnPowerButtonEvent(down, timestamp); | 88 OnPowerButtonEvent(down, timestamp); |
| 83 } | 89 } |
| 84 | 90 |
| 85 void PowerButtonObserver::LockButtonStateChanged( | 91 void PowerButtonObserver::LockButtonStateChanged( |
| 86 bool down, const base::TimeTicks& timestamp) { | 92 bool down, const base::TimeTicks& timestamp) { |
| 87 ash::Shell::GetInstance()->power_button_controller()-> | 93 ash::Shell::GetInstance()->power_button_controller()-> |
| 88 OnLockButtonEvent(down, timestamp); | 94 OnLockButtonEvent(down, timestamp); |
| 89 } | 95 } |
| 90 | 96 |
| 91 void PowerButtonObserver::LockScreen() { | 97 void PowerButtonObserver::LockScreen() { |
| 92 ash::Shell::GetInstance()->power_button_controller()->OnStartingLock(); | 98 ash::Shell::GetInstance()->power_button_controller()->OnStartingLock(); |
| 93 } | 99 } |
| 94 | 100 |
| 95 } // namespace chromeos | 101 } // namespace chromeos |
| OLD | NEW |