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/kiosk_mode/kiosk_mode_screensaver.h" | 5 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_screensaver.h" |
6 | 6 |
7 #include "base/bind.h" | |
7 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
8 #include "base/logging.h" | 9 #include "base/logging.h" |
9 #include "chrome/browser/chromeos/dbus/dbus_thread_manager.h" | 10 #include "chrome/browser/chromeos/dbus/dbus_thread_manager.h" |
11 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_helper.h" | |
10 #include "chrome/browser/chromeos/login/user_manager.h" | 12 #include "chrome/browser/chromeos/login/user_manager.h" |
11 #include "chrome/browser/chromeos/ui/screensaver_extension_dialog.h" | 13 #include "chrome/browser/chromeos/ui/screensaver_extension_dialog.h" |
12 #include "chrome/common/chrome_notification_types.h" | 14 #include "chrome/common/chrome_notification_types.h" |
13 #include "content/public/browser/notification_service.h" | 15 #include "content/public/browser/notification_service.h" |
14 | 16 |
15 namespace { | |
16 | |
17 // This (along with screensaver location) will change once we have the | |
18 // retail mode enterprise policy set up. | |
19 const int64 kScreensaverIdleTimeout = 60; | |
20 | |
21 } // namespace | |
22 | |
23 namespace chromeos { | 17 namespace chromeos { |
24 | 18 |
25 KioskModeScreensaver::KioskModeScreensaver() { | 19 KioskModeScreensaver::KioskModeScreensaver() { |
20 if (chromeos::KioskModeHelper::Get()->is_initialized()) | |
21 Init(); | |
xiyuan
2012/02/29 18:01:12
nit: Could we have a better name? On first look, "
rkc
2012/02/29 20:57:48
Done.
| |
22 else | |
23 chromeos::KioskModeHelper::Get()->Initialize( | |
xiyuan
2012/02/29 18:01:12
nit: suggest to enclose this with {} since it's mo
rkc
2012/02/29 20:57:48
Done.
| |
24 base::Bind(&KioskModeScreensaver::Init, | |
25 base::Unretained(this))); | |
26 | |
27 } | |
28 | |
29 KioskModeScreensaver::~KioskModeScreensaver() { | |
30 chromeos::PowerManagerClient* power_manager = | |
31 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); | |
32 if (power_manager->HasObserver(this)) | |
33 power_manager->RemoveObserver(this); | |
34 } | |
35 | |
36 void KioskModeScreensaver::Init() { | |
37 | |
26 // We should NOT be created if already logged in. | 38 // We should NOT be created if already logged in. |
27 CHECK(!chromeos::UserManager::Get()->user_is_logged_in()); | 39 CHECK(!chromeos::UserManager::Get()->user_is_logged_in()); |
28 | 40 |
29 registrar_.Add(this, chrome::NOTIFICATION_LOGIN_USER_CHANGED, | 41 registrar_.Add(this, chrome::NOTIFICATION_LOGIN_USER_CHANGED, |
30 content::NotificationService::AllSources()); | 42 content::NotificationService::AllSources()); |
31 | 43 |
32 // We will register ourselves now and unregister if a user logs in. | 44 // We will register ourselves now and unregister if a user logs in. |
33 chromeos::PowerManagerClient* power_manager = | 45 chromeos::PowerManagerClient* power_manager = |
34 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); | 46 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); |
35 if (!power_manager->HasObserver(this)) | 47 if (!power_manager->HasObserver(this)) |
36 power_manager->AddObserver(this); | 48 power_manager->AddObserver(this); |
37 | 49 |
38 // Register for the next Idle for kScreensaverIdleTimeout event. | 50 // Register for the next Idle for kScreensaverIdleTimeout event. |
39 chromeos::DBusThreadManager::Get()->GetPowerManagerClient()-> | 51 chromeos::DBusThreadManager::Get()-> |
Nikita (slow)
2012/02/29 12:21:55
I've realized that you would also need a patch for
rkc
2012/02/29 20:57:48
That is correct. I need to speak to Benson about t
| |
40 RequestIdleNotification(kScreensaverIdleTimeout * 1000); | 52 GetPowerManagerClient()->RequestIdleNotification( |
41 } | 53 chromeos::KioskModeHelper::Get()->GetScreensaverTimeout() * 1000); |
42 | |
43 KioskModeScreensaver::~KioskModeScreensaver() { | |
44 chromeos::PowerManagerClient* power_manager = | |
45 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); | |
46 if (power_manager->HasObserver(this)) | |
47 power_manager->RemoveObserver(this); | |
48 } | 54 } |
49 | 55 |
50 // NotificationObserver overrides: | 56 // NotificationObserver overrides: |
51 void KioskModeScreensaver::Observe( | 57 void KioskModeScreensaver::Observe( |
52 int type, | 58 int type, |
53 const content::NotificationSource& source, | 59 const content::NotificationSource& source, |
54 const content::NotificationDetails& details) { | 60 const content::NotificationDetails& details) { |
55 DCHECK_EQ(type, chrome::NOTIFICATION_LOGIN_USER_CHANGED); | 61 DCHECK_EQ(type, chrome::NOTIFICATION_LOGIN_USER_CHANGED); |
56 // User logged in, remove our observers, screensaver will be deactivated. | 62 // User logged in, remove our observers, screensaver will be deactivated. |
57 chromeos::PowerManagerClient* power_manager = | 63 chromeos::PowerManagerClient* power_manager = |
58 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); | 64 chromeos::DBusThreadManager::Get()->GetPowerManagerClient(); |
59 if (power_manager->HasObserver(this)) | 65 if (power_manager->HasObserver(this)) |
60 power_manager->RemoveObserver(this); | 66 power_manager->RemoveObserver(this); |
61 | 67 |
62 ShutdownKioskModeScreensaver(); | 68 ShutdownKioskModeScreensaver(); |
63 } | 69 } |
64 | 70 |
65 void KioskModeScreensaver::IdleNotify(int64 threshold) { | 71 void KioskModeScreensaver::IdleNotify(int64 threshold) { |
66 // We're idle, next time we go active, we need to know so we can remove | 72 // We're idle, next time we go active, we need to know so we can remove |
67 // the logout dialog if it's still up. | 73 // the logout dialog if it's still up. |
Nikita (slow)
2012/02/29 12:21:55
nit: logout dialog?
rkc
2012/02/29 20:57:48
Done.
| |
68 chromeos::DBusThreadManager::Get()->GetPowerManagerClient()-> | 74 chromeos::DBusThreadManager::Get()-> |
69 RequestActiveNotification(); | 75 GetPowerManagerClient()->RequestActiveNotification(); |
70 | 76 |
71 browser::ShowScreensaverDialog(); | 77 browser::ShowScreensaverDialog(); |
72 } | 78 } |
73 | 79 |
74 void KioskModeScreensaver::ActiveNotify() { | 80 void KioskModeScreensaver::ActiveNotify() { |
75 // Before anything else, close the logout dialog to prevent restart | 81 // Before anything else, close the logout dialog to prevent restart |
Nikita (slow)
2012/02/29 12:21:55
nit: logout dialog?
rkc
2012/02/29 20:57:48
Done.
| |
76 browser::CloseScreensaverDialog(); | 82 browser::CloseScreensaverDialog(); |
77 | 83 |
78 // Now that we're active, register a request for notification for | 84 // Now that we're active, register a request for notification for |
79 // the next time we go idle for kScreensaverIdleTimeout seconds. | 85 // the next time we go idle for kScreensaverIdleTimeout seconds. |
80 chromeos::DBusThreadManager::Get()->GetPowerManagerClient()-> | 86 chromeos::DBusThreadManager::Get()-> |
81 RequestIdleNotification(kScreensaverIdleTimeout * 1000); | 87 GetPowerManagerClient()->RequestIdleNotification( |
82 } | 88 chromeos::KioskModeHelper::Get()->GetScreensaverTimeout() * 1000);} |
83 | 89 |
84 static KioskModeScreensaver* g_kiosk_mode_screensaver = NULL; | 90 static KioskModeScreensaver* g_kiosk_mode_screensaver = NULL; |
85 | 91 |
86 void InitializeKioskModeScreensaver() { | 92 void InitializeKioskModeScreensaver() { |
87 if (g_kiosk_mode_screensaver) { | 93 if (g_kiosk_mode_screensaver) { |
88 LOG(WARNING) << "Screensaver was already initialized"; | 94 LOG(WARNING) << "Screensaver was already initialized"; |
89 return; | 95 return; |
90 } | 96 } |
91 | 97 |
92 g_kiosk_mode_screensaver = new KioskModeScreensaver(); | 98 g_kiosk_mode_screensaver = new KioskModeScreensaver(); |
93 } | 99 } |
94 | 100 |
95 void ShutdownKioskModeScreensaver() { | 101 void ShutdownKioskModeScreensaver() { |
96 if (g_kiosk_mode_screensaver) { | 102 if (!g_kiosk_mode_screensaver) { |
Nikita (slow)
2012/02/29 12:21:55
On the second thought delete of a NULL pointer is
rkc
2012/02/29 20:57:48
This actually really helped me with debugging alre
| |
97 LOG(WARNING) << "Screensaver shutdown called when uninitialized."; | 103 LOG(WARNING) << "Screensaver shutdown called when uninitialized."; |
98 return; | 104 return; |
99 } | 105 } |
100 | 106 |
101 delete g_kiosk_mode_screensaver; | 107 delete g_kiosk_mode_screensaver; |
102 g_kiosk_mode_screensaver = NULL; | 108 g_kiosk_mode_screensaver = NULL; |
103 } | 109 } |
104 | 110 |
105 } // namespace chromeos | 111 } // namespace chromeos |
OLD | NEW |