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

Side by Side Diff: chrome/browser/ui/webui/chromeos/login/oobe_ui.cc

Issue 811033002: Add device policy to disallow shutdown - ash UI modifications (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: shutdown_allowed => reboot_on_shutdown Created 6 years 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
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/ui/webui/chromeos/login/oobe_ui.h" 5 #include "chrome/browser/ui/webui/chromeos/login/oobe_ui.h"
6 6
7 #include "base/bind.h"
8 #include "base/bind_helpers.h"
7 #include "base/command_line.h" 9 #include "base/command_line.h"
8 #include "base/logging.h" 10 #include "base/logging.h"
9 #include "base/strings/stringprintf.h" 11 #include "base/strings/stringprintf.h"
10 #include "base/values.h" 12 #include "base/values.h"
11 #include "chrome/browser/browser_process.h" 13 #include "chrome/browser/browser_process.h"
12 #include "chrome/browser/browser_process_platform_part.h" 14 #include "chrome/browser/browser_process_platform_part.h"
13 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_settings.h" 15 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_settings.h"
14 #include "chrome/browser/chromeos/login/enrollment/auto_enrollment_check_screen_ actor.h" 16 #include "chrome/browser/chromeos/login/enrollment/auto_enrollment_check_screen_ actor.h"
15 #include "chrome/browser/chromeos/login/enrollment/enrollment_screen_actor.h" 17 #include "chrome/browser/chromeos/login/enrollment/enrollment_screen_actor.h"
16 #include "chrome/browser/chromeos/login/screens/error_screen.h" 18 #include "chrome/browser/chromeos/login/screens/error_screen.h"
17 #include "chrome/browser/chromeos/login/wizard_controller.h" 19 #include "chrome/browser/chromeos/login/wizard_controller.h"
18 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" 20 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h"
19 #include "chrome/browser/chromeos/policy/consumer_management_service.h" 21 #include "chrome/browser/chromeos/policy/consumer_management_service.h"
22 #include "chrome/browser/chromeos/settings/cros_settings.h"
20 #include "chrome/browser/chromeos/system/input_device_settings.h" 23 #include "chrome/browser/chromeos/system/input_device_settings.h"
21 #include "chrome/browser/extensions/signin/gaia_auth_extension_loader.h" 24 #include "chrome/browser/extensions/signin/gaia_auth_extension_loader.h"
22 #include "chrome/browser/extensions/tab_helper.h" 25 #include "chrome/browser/extensions/tab_helper.h"
23 #include "chrome/browser/profiles/profile.h" 26 #include "chrome/browser/profiles/profile.h"
24 #include "chrome/browser/ui/webui/about_ui.h" 27 #include "chrome/browser/ui/webui/about_ui.h"
25 #include "chrome/browser/ui/webui/chromeos/login/app_launch_splash_screen_handle r.h" 28 #include "chrome/browser/ui/webui/chromeos/login/app_launch_splash_screen_handle r.h"
26 #include "chrome/browser/ui/webui/chromeos/login/auto_enrollment_check_screen_ha ndler.h" 29 #include "chrome/browser/ui/webui/chromeos/login/auto_enrollment_check_screen_ha ndler.h"
27 #include "chrome/browser/ui/webui/chromeos/login/base_screen_handler.h" 30 #include "chrome/browser/ui/webui/chromeos/login/base_screen_handler.h"
28 #include "chrome/browser/ui/webui/chromeos/login/controller_pairing_screen_handl er.h" 31 #include "chrome/browser/ui/webui/chromeos/login/controller_pairing_screen_handl er.h"
29 #include "chrome/browser/ui/webui/chromeos/login/device_disabled_screen_handler. h" 32 #include "chrome/browser/ui/webui/chromeos/login/device_disabled_screen_handler. h"
(...skipping 527 matching lines...) Expand 10 before | Expand all | Expand 10 after
557 ready_callbacks_[i].Run(); 560 ready_callbacks_[i].Run();
558 ready_callbacks_.clear(); 561 ready_callbacks_.clear();
559 562
560 // Notify 'initialize' for synchronously loaded screens. 563 // Notify 'initialize' for synchronously loaded screens.
561 for (size_t i = 0; i < handlers_.size(); ++i) { 564 for (size_t i = 0; i < handlers_.size(); ++i) {
562 if (handlers_[i]->async_assets_load_id().empty()) 565 if (handlers_[i]->async_assets_load_id().empty())
563 handlers_[i]->InitializeBase(); 566 handlers_[i]->InitializeBase();
564 } 567 }
565 } 568 }
566 569
570 void OobeUI::InitShutdownPolicyObserver() {
571 // Instantiate the ShutdownPolicyObserver.
572 shutdown_policy_observer_.reset(
573 new ShutdownPolicyObserver(CrosSettings::Get(), this));
574
575 // Trigger an initial update.
576 shutdown_policy_observer_->CheckIfRebootOnShutdown(
577 base::Bind(&OobeUI::OnShutdownPolicyChanged, base::Unretained(this)));
578 }
579
580 void OobeUI::OnShutdownPolicyChanged(bool reboot_on_shutdown) {
581 core_handler_->UpdateShutdownButtonVisibility(!reboot_on_shutdown);
582 }
583
567 void OobeUI::OnScreenAssetsLoaded(const std::string& async_assets_load_id) { 584 void OobeUI::OnScreenAssetsLoaded(const std::string& async_assets_load_id) {
568 DCHECK(!async_assets_load_id.empty()); 585 DCHECK(!async_assets_load_id.empty());
569 586
570 for (size_t i = 0; i < handlers_.size(); ++i) { 587 for (size_t i = 0; i < handlers_.size(); ++i) {
571 if (handlers_[i]->async_assets_load_id() == async_assets_load_id) 588 if (handlers_[i]->async_assets_load_id() == async_assets_load_id)
572 handlers_[i]->InitializeBase(); 589 handlers_[i]->InitializeBase();
573 } 590 }
574 } 591 }
575 592
576 bool OobeUI::IsJSReady(const base::Closure& display_is_ready_callback) { 593 bool OobeUI::IsJSReady(const base::Closure& display_is_ready_callback) {
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
622 DCHECK(screen_ids_.count(screen)) 639 DCHECK(screen_ids_.count(screen))
623 << "Screen should be registered in InitializeScreenMaps()"; 640 << "Screen should be registered in InitializeScreenMaps()";
624 Screen new_screen = screen_ids_[screen]; 641 Screen new_screen = screen_ids_[screen];
625 FOR_EACH_OBSERVER(Observer, 642 FOR_EACH_OBSERVER(Observer,
626 observer_list_, 643 observer_list_,
627 OnCurrentScreenChanged(current_screen_, new_screen)); 644 OnCurrentScreenChanged(current_screen_, new_screen));
628 current_screen_ = new_screen; 645 current_screen_ = new_screen;
629 } 646 }
630 647
631 } // namespace chromeos 648 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698