Chromium Code Reviews| 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/screens/device_disabled_screen.h" | 5 #include "chrome/browser/chromeos/login/screens/device_disabled_screen.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | |
| 10 #include "base/command_line.h" | |
| 9 #include "base/logging.h" | 11 #include "base/logging.h" |
| 12 #include "base/prefs/pref_service.h" | |
| 10 #include "base/values.h" | 13 #include "base/values.h" |
| 14 #include "chrome/browser/browser_process.h" | |
| 15 #include "chrome/browser/browser_process_platform_part.h" | |
| 11 #include "chrome/browser/chromeos/login/screens/screen_observer.h" | 16 #include "chrome/browser/chromeos/login/screens/screen_observer.h" |
| 12 #include "chrome/browser/chromeos/login/wizard_controller.h" | 17 #include "chrome/browser/chromeos/login/wizard_controller.h" |
| 18 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | |
| 19 #include "chrome/browser/chromeos/policy/enterprise_install_attributes.h" | |
| 20 #include "chrome/browser/chromeos/policy/server_backed_device_state.h" | |
| 21 #include "chrome/common/pref_names.h" | |
| 22 #include "chromeos/chromeos_switches.h" | |
| 23 #include "components/policy/core/common/cloud/cloud_policy_constants.h" | |
| 13 | 24 |
| 14 namespace chromeos { | 25 namespace chromeos { |
| 15 | 26 |
| 16 DeviceDisabledScreen::DeviceDisabledScreen(ScreenObserver* observer, | 27 DeviceDisabledScreen::DeviceDisabledScreen(ScreenObserver* observer, |
| 17 DeviceDisabledScreenActor* actor) | 28 DeviceDisabledScreenActor* actor) |
| 18 : BaseScreen(observer), | 29 : BaseScreen(observer), |
| 19 actor_(actor) { | 30 showing_(false), |
| 31 actor_(actor), | |
| 32 weak_factory_(this) { | |
| 20 DCHECK(actor_); | 33 DCHECK(actor_); |
| 21 if (actor_) | 34 if (actor_) |
| 22 actor_->SetDelegate(this); | 35 actor_->SetDelegate(this); |
| 23 } | 36 } |
| 24 | 37 |
| 25 DeviceDisabledScreen::~DeviceDisabledScreen() { | 38 DeviceDisabledScreen::~DeviceDisabledScreen() { |
| 26 if (actor_) | 39 if (actor_) |
| 27 actor_->SetDelegate(NULL); | 40 actor_->SetDelegate(NULL); |
|
Joao da Silva
2014/10/24 09:07:30
nullptr
bartfab (slow)
2014/10/24 11:13:51
Done.
| |
| 28 } | 41 } |
| 29 | 42 |
| 30 void DeviceDisabledScreen::PrepareToShow() { | 43 void DeviceDisabledScreen::PrepareToShow() { |
| 31 } | 44 } |
| 32 | 45 |
| 33 void DeviceDisabledScreen::Show() { | 46 void DeviceDisabledScreen::Show() { |
| 34 if (actor_) | 47 if (!actor_) |
|
Joao da Silva
2014/10/24 09:07:30
|| showing_?
bartfab (slow)
2014/10/24 11:13:52
Done.
| |
| 35 actor_->Show(); | 48 return; |
| 49 | |
| 50 bool is_device_disabled = false; | |
| 51 g_browser_process->local_state()->GetDictionary( | |
| 52 prefs::kServerBackedDeviceState)->GetBoolean(policy::kDeviceStateDisabled, | |
|
Nikita (slow)
2014/10/24 10:26:12
If device_mode is policy::DEVICE_MODE_PENDING then
bartfab (slow)
2014/10/24 11:13:52
The value of |is_device_disabled| is independent o
Nikita (slow)
2014/10/24 13:57:28
So if is_device_disabled is true and you proceed i
bartfab (slow)
2014/10/24 14:02:18
In theory, yes, it could happen. And we handled it
| |
| 53 &is_device_disabled); | |
| 54 if (!is_device_disabled || | |
| 55 CommandLine::ForCurrentProcess()->HasSwitch( | |
| 56 switches::kDisableDeviceDisabling)) { | |
| 57 // Skip the screen if the device is not marked as disabled or device | |
| 58 // disabling has been turned off by flag. | |
| 59 IndicateDeviceNotDisabled(); | |
| 60 return; | |
| 61 } | |
| 62 | |
| 63 policy::BrowserPolicyConnectorChromeOS* connector = | |
| 64 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | |
| 65 if (connector->GetDeviceMode() == policy::DEVICE_MODE_PENDING) { | |
| 66 // Ensure that the device mode is known before proceeding. | |
| 67 connector->GetInstallAttributes()->ReadImmutableAttributes( | |
| 68 base::Bind(&DeviceDisabledScreen::Show, | |
|
Nikita (slow)
2014/10/24 10:26:12
What would be the UI transition if this check resu
bartfab (slow)
2014/10/24 11:13:51
Yes, the previous screen will still be showing. On
| |
| 69 weak_factory_.GetWeakPtr())); | |
| 70 return; | |
| 71 } | |
| 72 | |
| 73 if (connector->GetDeviceMode() != policy::DEVICE_MODE_NOT_SET) { | |
| 74 // Skip the screen if the device is owned already. The device disabling | |
| 75 // screen should only be shown during OOBE. | |
|
Joao da Silva
2014/10/24 09:07:30
Just so I understand, how do we disable devices th
bartfab (slow)
2014/10/24 11:13:52
In this CL, we don't :). It will be done in a foll
| |
| 76 IndicateDeviceNotDisabled(); | |
| 77 return; | |
| 78 } | |
| 79 | |
| 80 showing_ = true; | |
| 81 | |
| 82 std::string message; | |
| 83 g_browser_process->local_state()->GetDictionary( | |
| 84 prefs::kServerBackedDeviceState)->GetString( | |
| 85 policy::kDeviceStateDisabledMessage, | |
| 86 &message); | |
| 87 actor_->Show(message); | |
| 36 } | 88 } |
| 37 | 89 |
| 38 void DeviceDisabledScreen::Hide() { | 90 void DeviceDisabledScreen::Hide() { |
| 91 if (!showing_) | |
| 92 return; | |
| 93 showing_ = false; | |
| 94 | |
| 39 if (actor_) | 95 if (actor_) |
| 40 actor_->Hide(); | 96 actor_->Hide(); |
| 41 } | 97 } |
| 42 | 98 |
| 43 std::string DeviceDisabledScreen::GetName() const { | 99 std::string DeviceDisabledScreen::GetName() const { |
| 44 return WizardController::kDeviceDisabledScreenName; | 100 return WizardController::kDeviceDisabledScreenName; |
| 45 } | 101 } |
| 46 | 102 |
| 47 void DeviceDisabledScreen::OnActorDestroyed(DeviceDisabledScreenActor* actor) { | 103 void DeviceDisabledScreen::OnActorDestroyed(DeviceDisabledScreenActor* actor) { |
| 48 if (actor_ == actor) | 104 if (actor_ == actor) |
| 49 actor_ = NULL; | 105 actor_ = NULL; |
|
Joao da Silva
2014/10/24 09:07:30
nullptr
bartfab (slow)
2014/10/24 11:13:51
Done.
| |
| 50 } | 106 } |
| 51 | 107 |
| 108 void DeviceDisabledScreen::IndicateDeviceNotDisabled() { | |
| 109 get_screen_observer()->OnExit(ScreenObserver::DEVICE_NOT_DISABLED); | |
| 110 } | |
| 111 | |
| 52 } // namespace chromeos | 112 } // namespace chromeos |
| OLD | NEW |