OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/chrome_browser_main_chromeos.h" | 5 #include "chrome/browser/chromeos/chrome_browser_main_chromeos.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "ash/ash_switches.h" | 10 #include "ash/ash_switches.h" |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 #include "chromeos/ime/ime_keyboard.h" | 96 #include "chromeos/ime/ime_keyboard.h" |
97 #include "chromeos/ime/input_method_manager.h" | 97 #include "chromeos/ime/input_method_manager.h" |
98 #include "chromeos/login/login_state.h" | 98 #include "chromeos/login/login_state.h" |
99 #include "chromeos/login/user_names.h" | 99 #include "chromeos/login/user_names.h" |
100 #include "chromeos/network/network_change_notifier_chromeos.h" | 100 #include "chromeos/network/network_change_notifier_chromeos.h" |
101 #include "chromeos/network/network_change_notifier_factory_chromeos.h" | 101 #include "chromeos/network/network_change_notifier_factory_chromeos.h" |
102 #include "chromeos/network/network_handler.h" | 102 #include "chromeos/network/network_handler.h" |
103 #include "chromeos/system/statistics_provider.h" | 103 #include "chromeos/system/statistics_provider.h" |
104 #include "chromeos/tpm_token_loader.h" | 104 #include "chromeos/tpm_token_loader.h" |
105 #include "components/metrics/metrics_service.h" | 105 #include "components/metrics/metrics_service.h" |
| 106 #include "components/session_manager/core/session_manager.h" |
106 #include "content/public/browser/browser_thread.h" | 107 #include "content/public/browser/browser_thread.h" |
107 #include "content/public/browser/notification_service.h" | 108 #include "content/public/browser/notification_service.h" |
108 #include "content/public/browser/power_save_blocker.h" | 109 #include "content/public/browser/power_save_blocker.h" |
109 #include "content/public/common/main_function_params.h" | 110 #include "content/public/common/main_function_params.h" |
110 #include "grit/platform_locale_settings.h" | 111 #include "grit/platform_locale_settings.h" |
111 #include "media/audio/sounds/sounds_manager.h" | 112 #include "media/audio/sounds/sounds_manager.h" |
112 #include "net/base/network_change_notifier.h" | 113 #include "net/base/network_change_notifier.h" |
113 #include "net/url_request/url_request.h" | 114 #include "net/url_request/url_request.h" |
114 #include "net/url_request/url_request_context_getter.h" | 115 #include "net/url_request/url_request_context_getter.h" |
115 #include "ui/base/touch/touch_device.h" | 116 #include "ui/base/touch/touch_device.h" |
116 #include "ui/events/event_utils.h" | 117 #include "ui/events/event_utils.h" |
117 | 118 |
118 // Exclude X11 dependents for ozone | 119 // Exclude X11 dependents for ozone |
119 #if defined(USE_X11) | 120 #if defined(USE_X11) |
120 #include "chrome/browser/chromeos/device_uma.h" | 121 #include "chrome/browser/chromeos/device_uma.h" |
121 #include "chrome/browser/chromeos/events/system_key_event_listener.h" | 122 #include "chrome/browser/chromeos/events/system_key_event_listener.h" |
122 #include "chrome/browser/chromeos/events/xinput_hierarchy_changed_event_listener
.h" | 123 #include "chrome/browser/chromeos/events/xinput_hierarchy_changed_event_listener
.h" |
123 #endif | 124 #endif |
124 | 125 |
125 namespace chromeos { | 126 namespace chromeos { |
126 | 127 |
127 namespace { | 128 namespace { |
128 | 129 |
129 void ChromeOSVersionCallback(const std::string& version) { | 130 void ChromeOSVersionCallback(const std::string& version) { |
130 base::SetLinuxDistro(std::string("CrOS ") + version); | 131 base::SetLinuxDistro(std::string("CrOS ") + version); |
131 } | 132 } |
132 | 133 |
133 // Login ----------------------------------------------------------------------- | 134 bool ShouldAutoLaunchKioskApp(const base::CommandLine& command_line) { |
134 | |
135 bool ShouldAutoLaunchKioskApp(const CommandLine& command_line) { | |
136 KioskAppManager* app_manager = KioskAppManager::Get(); | 135 KioskAppManager* app_manager = KioskAppManager::Get(); |
137 return command_line.HasSwitch(switches::kLoginManager) && | 136 return command_line.HasSwitch(switches::kLoginManager) && |
138 !command_line.HasSwitch(switches::kForceLoginManagerInTests) && | 137 !command_line.HasSwitch(switches::kForceLoginManagerInTests) && |
139 app_manager->IsAutoLaunchEnabled() && | 138 app_manager->IsAutoLaunchEnabled() && |
140 KioskAppLaunchError::Get() == KioskAppLaunchError::NONE; | 139 KioskAppLaunchError::Get() == KioskAppLaunchError::NONE; |
141 } | 140 } |
142 | 141 |
143 void RunAutoLaunchKioskApp() { | |
144 ShowLoginWizard(chromeos::WizardController::kAppLaunchSplashScreenName); | |
145 | |
146 // Login screen is skipped but 'login-prompt-visible' signal is still needed. | |
147 VLOG(1) << "Kiosk app auto launch >> login-prompt-visible"; | |
148 DBusThreadManager::Get()->GetSessionManagerClient()-> | |
149 EmitLoginPromptVisible(); | |
150 } | |
151 | |
152 void OptionallyRunChromeOSLoginManager(const CommandLine& parsed_command_line, | |
153 Profile* profile) { | |
154 std::string login_user = parsed_command_line. | |
155 GetSwitchValueASCII(chromeos::switches::kLoginUser); | |
156 if (!base::SysInfo::IsRunningOnChromeOS() && | |
157 login_user == chromeos::login::kStubUser) { | |
158 return; | |
159 } | |
160 | |
161 if (ShouldAutoLaunchKioskApp(parsed_command_line)) { | |
162 RunAutoLaunchKioskApp(); | |
163 } else if (parsed_command_line.HasSwitch(switches::kLoginManager)) { | |
164 ShowLoginWizard(std::string()); | |
165 | |
166 if (KioskModeSettings::Get()->IsKioskModeEnabled()) | |
167 InitializeKioskModeScreensaver(); | |
168 | |
169 // Reset reboot after update flag when login screen is shown. | |
170 policy::BrowserPolicyConnectorChromeOS* connector = | |
171 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | |
172 if (!connector->IsEnterpriseManaged()) { | |
173 PrefService* local_state = g_browser_process->local_state(); | |
174 local_state->ClearPref(prefs::kRebootAfterUpdate); | |
175 } | |
176 } else { | |
177 if (!parsed_command_line.HasSwitch(::switches::kTestName)) { | |
178 // Enable CrasAudioHandler logging when chrome restarts after crashing. | |
179 if (chromeos::CrasAudioHandler::IsInitialized()) | |
180 chromeos::CrasAudioHandler::Get()->LogErrors(); | |
181 | |
182 // We did not log in (we crashed or are debugging), so we need to | |
183 // restore Sync. | |
184 UserSessionManager::GetInstance()->RestoreAuthenticationSession(profile); | |
185 } | |
186 } | |
187 } | |
188 | |
189 } // namespace | 142 } // namespace |
190 | 143 |
191 namespace internal { | 144 namespace internal { |
192 | 145 |
193 // Wrapper class for initializing dbus related services and shutting them | 146 // Wrapper class for initializing dbus related services and shutting them |
194 // down. This gets instantiated in a scoped_ptr so that shutdown methods in the | 147 // down. This gets instantiated in a scoped_ptr so that shutdown methods in the |
195 // destructor will get called if and only if this has been instantiated. | 148 // destructor will get called if and only if this has been instantiated. |
196 class DBusServices { | 149 class DBusServices { |
197 public: | 150 public: |
198 explicit DBusServices(const content::MainFunctionParams& parameters) { | 151 explicit DBusServices(const content::MainFunctionParams& parameters) { |
(...skipping 351 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
550 UserSessionManager::GetInstance()->RespectLocalePreference( | 503 UserSessionManager::GetInstance()->RespectLocalePreference( |
551 profile, user, callback.Pass()); | 504 profile, user, callback.Pass()); |
552 } | 505 } |
553 | 506 |
554 void ChromeBrowserMainPartsChromeos::PostProfileInit() { | 507 void ChromeBrowserMainPartsChromeos::PostProfileInit() { |
555 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() | 508 // -- This used to be in ChromeBrowserMainParts::PreMainMessageLoopRun() |
556 // -- just after CreateProfile(). | 509 // -- just after CreateProfile(). |
557 | 510 |
558 BootTimesLoader::Get()->OnChromeProcessStart(); | 511 BootTimesLoader::Get()->OnChromeProcessStart(); |
559 | 512 |
560 // Restarting Chrome inside existing user session. Possible cases: | |
561 // 1. Chrome is restarted after crash. | |
562 // 2. Chrome is started in browser_tests skipping the login flow. | |
563 // 3. Chrome is started on dev machine i.e. not on Chrome OS device w/o | |
564 // login flow. In that case --login-user=[chromeos::login::kStubUser] is | |
565 // added. | |
566 // See PreEarlyInitialization(). | |
567 if (parsed_command_line().HasSwitch(switches::kLoginUser)) { | |
568 std::string login_user = login::CanonicalizeUserID( | |
569 parsed_command_line().GetSwitchValueASCII( | |
570 chromeos::switches::kLoginUser)); | |
571 if (!base::SysInfo::IsRunningOnChromeOS() && | |
572 login_user == chromeos::login::kStubUser) { | |
573 // For dev machines and stub user emulate as if sync has been initialized. | |
574 profile()->GetPrefs()->SetString(prefs::kGoogleServicesUsername, | |
575 login_user); | |
576 } | |
577 | |
578 // This is done in SessionManager::OnProfileCreated during normal login. | |
579 UserSessionManager::GetInstance()->InitRlz(profile()); | |
580 | |
581 // Send the PROFILE_PREPARED notification and call SessionStarted() | |
582 // so that the Launcher and other Profile dependent classes are created. | |
583 content::NotificationService::current()->Notify( | |
584 chrome::NOTIFICATION_LOGIN_USER_PROFILE_PREPARED, | |
585 content::NotificationService::AllSources(), | |
586 content::Details<Profile>(profile())); | |
587 UserManager::Get()->SessionStarted(); | |
588 | |
589 // Now is the good time to retrieve other logged in users for this session. | |
590 // First user has been already marked as logged in and active in | |
591 // PreProfileInit(). Chrome should tread other user in a session as active | |
592 // in the background. | |
593 UserSessionManager::GetInstance()->RestoreActiveSessions(); | |
594 } | |
595 | |
596 // Initialize the network portal detector for Chrome OS. The network | 513 // Initialize the network portal detector for Chrome OS. The network |
597 // portal detector starts to listen for notifications from | 514 // portal detector starts to listen for notifications from |
598 // NetworkStateHandler and initiates captive portal detection for | 515 // NetworkStateHandler and initiates captive portal detection for |
599 // active networks. Shoule be called before call to | 516 // active networks. Should be called before call to CreateSessionManager, |
600 // OptionallyRunChromeOSLoginManager, because it depends on | 517 // because it depends on NetworkPortalDetector. |
601 // NetworkPortalDetector. | |
602 NetworkPortalDetectorImpl::Initialize( | 518 NetworkPortalDetectorImpl::Initialize( |
603 g_browser_process->system_request_context()); | 519 g_browser_process->system_request_context()); |
604 { | 520 { |
605 NetworkPortalDetector* detector = NetworkPortalDetector::Get(); | 521 NetworkPortalDetector* detector = NetworkPortalDetector::Get(); |
606 #if defined(GOOGLE_CHROME_BUILD) | 522 #if defined(GOOGLE_CHROME_BUILD) |
607 bool is_official_build = true; | 523 bool is_official_build = true; |
608 #else | 524 #else |
609 bool is_official_build = false; | 525 bool is_official_build = false; |
610 #endif | 526 #endif |
611 // Enable portal detector if EULA was previously accepted or if | 527 // Enable portal detector if EULA was previously accepted or if |
612 // this is an unofficial build. | 528 // this is an unofficial build. |
613 if (!is_official_build || StartupUtils::IsEulaAccepted()) | 529 if (!is_official_build || StartupUtils::IsEulaAccepted()) |
614 detector->Enable(true); | 530 detector->Enable(true); |
615 } | 531 } |
616 | 532 |
617 // Tests should be able to tune login manager before showing it. | 533 bool is_running_test = parameters().ui_task != NULL; |
618 // Thus only show login manager in normal (non-testing) mode. | 534 g_browser_process->platform_part()->InitializeSessionManager( |
619 if (!parameters().ui_task || | 535 parsed_command_line(), profile(), is_running_test); |
620 parsed_command_line().HasSwitch(switches::kForceLoginManagerInTests)) { | 536 g_browser_process->platform_part()->session_manager()->Start(); |
621 OptionallyRunChromeOSLoginManager(parsed_command_line(), profile()); | |
622 } | |
623 | 537 |
624 // Guest user profile is never initialized with locale settings, | 538 // Guest user profile is never initialized with locale settings, |
625 // so we need special handling for Guest session. | 539 // so we need special handling for Guest session. |
626 if (UserManager::Get()->IsLoggedInAsGuest()) | 540 if (UserManager::Get()->IsLoggedInAsGuest()) |
627 SetGuestLocale(profile()); | 541 SetGuestLocale(profile()); |
628 | 542 |
629 // These observers must be initialized after the profile because | 543 // These observers must be initialized after the profile because |
630 // they use the profile to dispatch extension events. | 544 // they use the profile to dispatch extension events. |
631 extension_system_event_observer_.reset(new ExtensionSystemEventObserver()); | 545 extension_system_event_observer_.reset(new ExtensionSystemEventObserver()); |
632 if (KioskModeSettings::Get()->IsKioskModeEnabled()) { | 546 if (KioskModeSettings::Get()->IsKioskModeEnabled()) { |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
803 // Stops all in-flight OAuth2 token fetchers before the IO thread stops. | 717 // Stops all in-flight OAuth2 token fetchers before the IO thread stops. |
804 DeviceOAuth2TokenServiceFactory::Shutdown(); | 718 DeviceOAuth2TokenServiceFactory::Shutdown(); |
805 | 719 |
806 // Called after | 720 // Called after |
807 // ChromeBrowserMainPartsLinux::PostMainMessageLoopRun() to be | 721 // ChromeBrowserMainPartsLinux::PostMainMessageLoopRun() to be |
808 // executed after execution of chrome::CloseAsh(), because some | 722 // executed after execution of chrome::CloseAsh(), because some |
809 // parts of WebUI depends on NetworkPortalDetector. | 723 // parts of WebUI depends on NetworkPortalDetector. |
810 NetworkPortalDetector::Shutdown(); | 724 NetworkPortalDetector::Shutdown(); |
811 | 725 |
812 UserManager::Destroy(); | 726 UserManager::Destroy(); |
| 727 |
| 728 g_browser_process->platform_part()->ShutdownSessionManager(); |
813 } | 729 } |
814 | 730 |
815 void ChromeBrowserMainPartsChromeos::PostDestroyThreads() { | 731 void ChromeBrowserMainPartsChromeos::PostDestroyThreads() { |
816 // Destroy DBus services immediately after threads are stopped. | 732 // Destroy DBus services immediately after threads are stopped. |
817 dbus_services_.reset(); | 733 dbus_services_.reset(); |
818 | 734 |
819 ChromeBrowserMainPartsLinux::PostDestroyThreads(); | 735 ChromeBrowserMainPartsLinux::PostDestroyThreads(); |
820 | 736 |
821 // Destroy DeviceSettingsService after g_browser_process. | 737 // Destroy DeviceSettingsService after g_browser_process. |
822 DeviceSettingsService::Shutdown(); | 738 DeviceSettingsService::Shutdown(); |
823 } | 739 } |
824 | 740 |
825 } // namespace chromeos | 741 } // namespace chromeos |
OLD | NEW |