Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1612)

Side by Side Diff: chrome/browser/chromeos/kiosk_mode/kiosk_mode_screensaver.cc

Issue 11363109: Check for login screen availibility before showing spinner. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "ash/screensaver/screensaver_view.h" 7 #include "ash/screensaver/screensaver_view.h"
8 #include "ash/shell.h" 8 #include "ash/shell.h"
9 #include "ash/wm/user_activity_detector.h" 9 #include "ash/wm/user_activity_detector.h"
10 #include "base/bind.h" 10 #include "base/bind.h"
(...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after
170 &SandboxedUnpacker::Start, screensaver_unpacker.get())); 170 &SandboxedUnpacker::Start, screensaver_unpacker.get()));
171 } 171 }
172 172
173 void KioskModeScreensaver::SetupScreensaver( 173 void KioskModeScreensaver::SetupScreensaver(
174 scoped_refptr<Extension> extension, 174 scoped_refptr<Extension> extension,
175 const FilePath& extension_base_path) { 175 const FilePath& extension_base_path) {
176 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 176 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
177 extension_base_path_ = extension_base_path; 177 extension_base_path_ = extension_base_path;
178 178
179 // If the user is already logged in, don't need to display the screensaver. 179 // If the user is already logged in, don't need to display the screensaver.
180 if (chromeos::UserManager::Get()->IsUserLoggedIn()) 180 if (chromeos::UserManager::Get()->IsSessionStarted())
Nikita (slow) 2012/11/07 10:51:37 Difference between these two is that IsSessionStar
rkc 2012/11/07 20:25:02 IsSessionStarted seemed more appropriate (since it
181 return; 181 return;
182 182
183 ash::Shell::GetInstance()->user_activity_detector()->AddObserver(this); 183 ash::Shell::GetInstance()->user_activity_detector()->AddObserver(this);
184 184
185 Profile* default_profile = ProfileManager::GetDefaultProfile(); 185 Profile* default_profile = ProfileManager::GetDefaultProfile();
186 // Add the extension to the extension service and display the screensaver. 186 // Add the extension to the extension service and display the screensaver.
187 if (default_profile) { 187 if (default_profile) {
188 default_profile->GetExtensionService()->AddExtension(extension); 188 default_profile->GetExtensionService()->AddExtension(extension);
189 ash::ShowScreensaver(extension->GetFullLaunchURL()); 189 ash::ShowScreensaver(extension->GetFullLaunchURL());
190 } else { 190 } else {
191 LOG(ERROR) << "Couldn't get default profile. Unable to load screensaver!"; 191 LOG(ERROR) << "Couldn't get default profile. Unable to load screensaver!";
192 ShutdownKioskModeScreensaver(); 192 ShutdownKioskModeScreensaver();
193 } 193 }
194 } 194 }
195 195
196 void KioskModeScreensaver::OnUserActivity() { 196 void KioskModeScreensaver::OnUserActivity() {
197 // We don't want to handle further user notifications; we'll either login 197 // We don't want to handle further user notifications; we'll either login
198 // the user and close out or or at least close the screensaver. 198 // the user and close out or or at least close the screensaver.
199 ash::Shell::GetInstance()->user_activity_detector()->RemoveObserver(this); 199 ash::Shell::GetInstance()->user_activity_detector()->RemoveObserver(this);
200 200
201 // Find the retail mode login page. 201 // Find the retail mode login page.
202 CHECK(WebUILoginDisplayHost::default_host()); 202 if (WebUILoginDisplayHost::default_host()) {
Nikita (slow) 2012/11/07 10:51:37 If default_host is gone now I believe login alread
rkc 2012/11/07 20:25:02 If you're certain that is the only case that the d
203 WebUILoginDisplayHost* webui_host = 203 WebUILoginDisplayHost* webui_host =
204 static_cast<WebUILoginDisplayHost*>( 204 static_cast<WebUILoginDisplayHost*>(
205 WebUILoginDisplayHost::default_host()); 205 WebUILoginDisplayHost::default_host());
206 OobeUI* oobe_ui = webui_host->GetOobeUI(); 206 OobeUI* oobe_ui = webui_host->GetOobeUI();
207 207
208 // Show the login spinner. 208 // Show the login spinner.
209 CHECK(oobe_ui); 209 if (oobe_ui)
210 oobe_ui->ShowRetailModeLoginSpinner(); 210 oobe_ui->ShowRetailModeLoginSpinner();
211 }
211 212
212 // Close the screensaver, our login spinner is already showing. 213 // Close the screensaver, our login spinner is already showing.
213 ash::CloseScreensaver(); 214 ash::CloseScreensaver();
214 215
215 // Log us in. 216 // Log us in.
216 ExistingUserController* controller = 217 ExistingUserController* controller =
217 ExistingUserController::current_controller(); 218 ExistingUserController::current_controller();
218 CHECK(controller); 219 if (controller && !chromeos::UserManager::Get()->IsSessionStarted())
219 controller->LoginAsDemoUser(); 220 controller->LoginAsDemoUser();
220 221
221 ShutdownKioskModeScreensaver(); 222 ShutdownKioskModeScreensaver();
222 } 223 }
223 224
224 static KioskModeScreensaver* g_kiosk_mode_screensaver = NULL; 225 static KioskModeScreensaver* g_kiosk_mode_screensaver = NULL;
225 226
226 void InitializeKioskModeScreensaver() { 227 void InitializeKioskModeScreensaver() {
227 if (g_kiosk_mode_screensaver) { 228 if (g_kiosk_mode_screensaver) {
228 LOG(WARNING) << "Screensaver was already initialized"; 229 LOG(WARNING) << "Screensaver was already initialized";
229 return; 230 return;
230 } 231 }
231 232
232 g_kiosk_mode_screensaver = new KioskModeScreensaver(); 233 g_kiosk_mode_screensaver = new KioskModeScreensaver();
233 } 234 }
234 235
235 void ShutdownKioskModeScreensaver() { 236 void ShutdownKioskModeScreensaver() {
236 delete g_kiosk_mode_screensaver; 237 delete g_kiosk_mode_screensaver;
237 g_kiosk_mode_screensaver = NULL; 238 g_kiosk_mode_screensaver = NULL;
238 } 239 }
239 240
240 } // namespace chromeos 241 } // namespace chromeos
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698