OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/login/session/chrome_session_manager.h" | 5 #include "chrome/browser/chromeos/login/session/chrome_session_manager.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
11 #include "base/sys_info.h" | 11 #include "base/sys_info.h" |
12 #include "chrome/browser/chrome_notification_types.h" | 12 #include "chrome/browser/chrome_notification_types.h" |
13 #include "chrome/browser/chromeos/app_mode/kiosk_app_launch_error.h" | 13 #include "chrome/browser/chromeos/app_mode/kiosk_app_launch_error.h" |
14 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" | 14 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" |
15 #include "chrome/browser/chromeos/login/session/kiosk_auto_launcher_session_mana
ger_delegate.h" | 15 #include "chrome/browser/chromeos/login/session/kiosk_auto_launcher_session_mana
ger_delegate.h" |
16 #include "chrome/browser/chromeos/login/session/login_oobe_session_manager_deleg
ate.h" | 16 #include "chrome/browser/chromeos/login/session/login_oobe_session_manager_deleg
ate.h" |
17 #include "chrome/browser/chromeos/login/session/restore_after_crash_session_mana
ger_delegate.h" | 17 #include "chrome/browser/chromeos/login/session/restore_after_crash_session_mana
ger_delegate.h" |
18 #include "chrome/browser/chromeos/login/session/stub_login_session_manager_deleg
ate.h" | 18 #include "chrome/browser/chromeos/login/session/stub_login_session_manager_deleg
ate.h" |
19 #include "chrome/browser/profiles/profile.h" | 19 #include "chrome/browser/profiles/profile.h" |
20 #include "chromeos/chromeos_switches.h" | 20 #include "chromeos/chromeos_switches.h" |
21 #include "chromeos/cryptohome/cryptohome_parameters.h" | 21 #include "chromeos/cryptohome/cryptohome_parameters.h" |
22 #include "chromeos/login/user_names.h" | |
23 #include "components/signin/core/account_id/account_id.h" | 22 #include "components/signin/core/account_id/account_id.h" |
24 #include "components/user_manager/user_manager.h" | 23 #include "components/user_manager/user_manager.h" |
| 24 #include "components/user_manager/user_names.h" |
25 #include "content/public/browser/notification_service.h" | 25 #include "content/public/browser/notification_service.h" |
26 | 26 |
27 namespace chromeos { | 27 namespace chromeos { |
28 | 28 |
29 namespace { | 29 namespace { |
30 | 30 |
31 bool ShouldAutoLaunchKioskApp(const base::CommandLine& command_line) { | 31 bool ShouldAutoLaunchKioskApp(const base::CommandLine& command_line) { |
32 KioskAppManager* app_manager = KioskAppManager::Get(); | 32 KioskAppManager* app_manager = KioskAppManager::Get(); |
33 return command_line.HasSwitch(switches::kLoginManager) && | 33 return command_line.HasSwitch(switches::kLoginManager) && |
34 !command_line.HasSwitch(switches::kForceLoginManagerInTests) && | 34 !command_line.HasSwitch(switches::kForceLoginManagerInTests) && |
(...skipping 26 matching lines...) Expand all Loading... |
61 VLOG(1) << "Starting Chrome with KioskAutoLauncherSessionManagerDelegate"; | 61 VLOG(1) << "Starting Chrome with KioskAutoLauncherSessionManagerDelegate"; |
62 return std::unique_ptr<session_manager::SessionManager>( | 62 return std::unique_ptr<session_manager::SessionManager>( |
63 new ChromeSessionManager( | 63 new ChromeSessionManager( |
64 new KioskAutoLauncherSessionManagerDelegate())); | 64 new KioskAutoLauncherSessionManagerDelegate())); |
65 } else if (parsed_command_line.HasSwitch(switches::kLoginManager) && | 65 } else if (parsed_command_line.HasSwitch(switches::kLoginManager) && |
66 (!is_running_test || force_login_screen_in_test)) { | 66 (!is_running_test || force_login_screen_in_test)) { |
67 VLOG(1) << "Starting Chrome with LoginOobeSessionManagerDelegate"; | 67 VLOG(1) << "Starting Chrome with LoginOobeSessionManagerDelegate"; |
68 return std::unique_ptr<session_manager::SessionManager>( | 68 return std::unique_ptr<session_manager::SessionManager>( |
69 new ChromeSessionManager(new LoginOobeSessionManagerDelegate())); | 69 new ChromeSessionManager(new LoginOobeSessionManagerDelegate())); |
70 } else if (!base::SysInfo::IsRunningOnChromeOS() && | 70 } else if (!base::SysInfo::IsRunningOnChromeOS() && |
71 login_account_id == login::StubAccountId()) { | 71 login_account_id == user_manager::StubAccountId()) { |
72 VLOG(1) << "Starting Chrome with StubLoginSessionManagerDelegate"; | 72 VLOG(1) << "Starting Chrome with StubLoginSessionManagerDelegate"; |
73 return std::unique_ptr<session_manager::SessionManager>( | 73 return std::unique_ptr<session_manager::SessionManager>( |
74 new ChromeSessionManager(new StubLoginSessionManagerDelegate( | 74 new ChromeSessionManager(new StubLoginSessionManagerDelegate( |
75 profile, login_account_id.GetUserEmail()))); | 75 profile, login_account_id.GetUserEmail()))); |
76 } else { | 76 } else { |
77 VLOG(1) << "Starting Chrome with RestoreAfterCrashSessionManagerDelegate"; | 77 VLOG(1) << "Starting Chrome with RestoreAfterCrashSessionManagerDelegate"; |
78 // Restarting Chrome inside existing user session. Possible cases: | 78 // Restarting Chrome inside existing user session. Possible cases: |
79 // 1. Chrome is restarted after crash. | 79 // 1. Chrome is restarted after crash. |
80 // 2. Chrome is restarted for Guest session. | 80 // 2. Chrome is restarted for Guest session. |
81 // 3. Chrome is started in browser_tests skipping the login flow. | 81 // 3. Chrome is started in browser_tests skipping the login flow. |
82 // 4. Chrome is started on dev machine i.e. not on Chrome OS device w/o | 82 // 4. Chrome is started on dev machine i.e. not on Chrome OS device w/o |
83 // login flow. In that case --login-user=[chromeos::login::kStubUser] is | 83 // login flow. In that case |
| 84 // --login-user=[user_manager::kStubUser] is |
84 // added. See PreEarlyInitialization(). | 85 // added. See PreEarlyInitialization(). |
85 return std::unique_ptr<session_manager::SessionManager>( | 86 return std::unique_ptr<session_manager::SessionManager>( |
86 new ChromeSessionManager(new RestoreAfterCrashSessionManagerDelegate( | 87 new ChromeSessionManager(new RestoreAfterCrashSessionManagerDelegate( |
87 profile, login_account_id.GetUserEmail()))); | 88 profile, login_account_id.GetUserEmail()))); |
88 } | 89 } |
89 } | 90 } |
90 | 91 |
91 ChromeSessionManager::ChromeSessionManager( | 92 ChromeSessionManager::ChromeSessionManager( |
92 session_manager::SessionManagerDelegate* delegate) { | 93 session_manager::SessionManagerDelegate* delegate) { |
93 Initialize(delegate); | 94 Initialize(delegate); |
(...skipping 12 matching lines...) Expand all Loading... |
106 user_manager->OnSessionStarted(); | 107 user_manager->OnSessionStarted(); |
107 | 108 |
108 content::NotificationService::current()->Notify( | 109 content::NotificationService::current()->Notify( |
109 chrome::NOTIFICATION_SESSION_STARTED, | 110 chrome::NOTIFICATION_SESSION_STARTED, |
110 content::Source<session_manager::SessionManager>(this), | 111 content::Source<session_manager::SessionManager>(this), |
111 content::Details<const user_manager::User>( | 112 content::Details<const user_manager::User>( |
112 user_manager->GetActiveUser())); | 113 user_manager->GetActiveUser())); |
113 } | 114 } |
114 | 115 |
115 } // namespace chromeos | 116 } // namespace chromeos |
OLD | NEW |