Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 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/app_mode/app_session_lifetime.h" | 5 #include "chrome/browser/chromeos/app_mode/app_session_lifetime.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 31 #include "extensions/browser/app_window/app_window_registry.h" | 31 #include "extensions/browser/app_window/app_window_registry.h" |
| 32 | 32 |
| 33 using extensions::AppWindow; | 33 using extensions::AppWindow; |
| 34 using extensions::AppWindowRegistry; | 34 using extensions::AppWindowRegistry; |
| 35 | 35 |
| 36 namespace chromeos { | 36 namespace chromeos { |
| 37 | 37 |
| 38 namespace { | 38 namespace { |
| 39 | 39 |
| 40 // AppWindowHandler watches for app window and exits the session when the | 40 // AppWindowHandler watches for app window and exits the session when the |
| 41 // last app window is closed. | 41 // last window of a given app is closed. |
| 42 class AppWindowHandler : public AppWindowRegistry::Observer { | 42 class AppWindowHandler : public AppWindowRegistry::Observer { |
| 43 public: | 43 public: |
| 44 AppWindowHandler() : window_registry_(NULL) {} | 44 AppWindowHandler() : window_registry_(NULL) {} |
| 45 ~AppWindowHandler() override {} | 45 ~AppWindowHandler() override {} |
| 46 | 46 |
| 47 void Init(Profile* profile) { | 47 void Init(Profile* profile, const std::string& app_id) { |
| 48 DCHECK(!window_registry_); | 48 DCHECK(!window_registry_); |
| 49 window_registry_ = AppWindowRegistry::Get(profile); | 49 window_registry_ = AppWindowRegistry::Get(profile); |
| 50 if (window_registry_) | 50 if (window_registry_) |
| 51 window_registry_->AddObserver(this); | 51 window_registry_->AddObserver(this); |
| 52 app_id_ = app_id; | |
| 52 } | 53 } |
| 53 | 54 |
| 54 private: | 55 private: |
| 55 // extensions::AppWindowRegistry::Observer overrides: | 56 // extensions::AppWindowRegistry::Observer overrides: |
| 56 void OnAppWindowRemoved(AppWindow* app_window) override { | 57 void OnAppWindowRemoved(AppWindow* app_window) override { |
| 57 if (window_registry_->app_windows().empty()) { | 58 if (window_registry_->GetAppWindowsForApp(app_id_).empty()) { |
| 58 if (DemoAppLauncher::IsDemoAppSession( | 59 if (DemoAppLauncher::IsDemoAppSession( |
| 59 user_manager::UserManager::Get()->GetActiveUser()->email())) { | 60 user_manager::UserManager::Get()->GetActiveUser()->email())) { |
| 60 // If we were in demo mode, we disabled all our network technologies, | 61 // If we were in demo mode, we disabled all our network technologies, |
| 61 // re-enable them. | 62 // re-enable them. |
| 62 NetworkStateHandler* handler = | 63 NetworkStateHandler* handler = |
| 63 NetworkHandler::Get()->network_state_handler(); | 64 NetworkHandler::Get()->network_state_handler(); |
| 64 handler->SetTechnologyEnabled( | 65 handler->SetTechnologyEnabled( |
| 65 NetworkTypePattern::NonVirtual(), | 66 NetworkTypePattern::NonVirtual(), |
| 66 true, | 67 true, |
| 67 chromeos::network_handler::ErrorCallback()); | 68 chromeos::network_handler::ErrorCallback()); |
| 68 } | 69 } |
| 69 chrome::AttemptUserExit(); | 70 chrome::AttemptUserExit(); |
| 70 window_registry_->RemoveObserver(this); | 71 window_registry_->RemoveObserver(this); |
| 71 } | 72 } |
| 72 } | 73 } |
| 73 | 74 |
| 74 AppWindowRegistry* window_registry_; | 75 AppWindowRegistry* window_registry_; |
| 76 std::string app_id_; | |
|
bartfab (slow)
2015/01/26 15:59:46
Nit: const.
xiyuan
2015/01/26 17:21:32
Cannot use const here because we use it as a AppWi
| |
| 75 | 77 |
| 76 DISALLOW_COPY_AND_ASSIGN(AppWindowHandler); | 78 DISALLOW_COPY_AND_ASSIGN(AppWindowHandler); |
| 77 }; | 79 }; |
| 78 | 80 |
| 79 base::LazyInstance<AppWindowHandler> app_window_handler | 81 base::LazyInstance<AppWindowHandler> app_window_handler |
| 80 = LAZY_INSTANCE_INITIALIZER; | 82 = LAZY_INSTANCE_INITIALIZER; |
| 81 | 83 |
| 82 // BrowserWindowHandler monitors Browser object being created during | 84 // BrowserWindowHandler monitors Browser object being created during |
| 83 // a kiosk session, log info such as URL so that the code path could be | 85 // a kiosk session, log info such as URL so that the code path could be |
| 84 // fixed and closes the just opened browser window. | 86 // fixed and closes the just opened browser window. |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 114 }; | 116 }; |
| 115 | 117 |
| 116 base::LazyInstance<BrowserWindowHandler> browser_window_handler | 118 base::LazyInstance<BrowserWindowHandler> browser_window_handler |
| 117 = LAZY_INSTANCE_INITIALIZER; | 119 = LAZY_INSTANCE_INITIALIZER; |
| 118 | 120 |
| 119 } // namespace | 121 } // namespace |
| 120 | 122 |
| 121 void InitAppSession(Profile* profile, const std::string& app_id) { | 123 void InitAppSession(Profile* profile, const std::string& app_id) { |
| 122 // Binds the session lifetime with app window counts. | 124 // Binds the session lifetime with app window counts. |
| 123 CHECK(app_window_handler == NULL); | 125 CHECK(app_window_handler == NULL); |
| 124 app_window_handler.Get().Init(profile); | 126 app_window_handler.Get().Init(profile, app_id); |
| 125 | 127 |
| 126 CHECK(browser_window_handler == NULL); | 128 CHECK(browser_window_handler == NULL); |
| 127 browser_window_handler.Get(); | 129 browser_window_handler.Get(); |
| 128 | 130 |
| 129 // For a demo app, we don't need to either setup the update service or | 131 // For a demo app, we don't need to either setup the update service or |
| 130 // the idle app name notification. | 132 // the idle app name notification. |
| 131 if (DemoAppLauncher::IsDemoAppSession( | 133 if (DemoAppLauncher::IsDemoAppSession( |
| 132 user_manager::UserManager::Get()->GetActiveUser()->email())) | 134 user_manager::UserManager::Get()->GetActiveUser()->email())) |
| 133 return; | 135 return; |
| 134 | 136 |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 148 policy::BrowserPolicyConnectorChromeOS* connector = | 150 policy::BrowserPolicyConnectorChromeOS* connector = |
| 149 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | 151 g_browser_process->platform_part()->browser_policy_connector_chromeos(); |
| 150 if (!connector->IsEnterpriseManaged()) { | 152 if (!connector->IsEnterpriseManaged()) { |
| 151 PrefService* local_state = g_browser_process->local_state(); | 153 PrefService* local_state = g_browser_process->local_state(); |
| 152 local_state->SetBoolean(prefs::kRebootAfterUpdate, true); | 154 local_state->SetBoolean(prefs::kRebootAfterUpdate, true); |
| 153 KioskModeIdleAppNameNotification::Initialize(); | 155 KioskModeIdleAppNameNotification::Initialize(); |
| 154 } | 156 } |
| 155 } | 157 } |
| 156 | 158 |
| 157 } // namespace chromeos | 159 } // namespace chromeos |
| OLD | NEW |