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/ui/webui/chromeos/login/gaia_screen_handler.h" | 5 #include "chrome/browser/ui/webui/chromeos/login/gaia_screen_handler.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/metrics/histogram.h" | 9 #include "base/metrics/histogram.h" |
| 10 #include "base/prefs/pref_service.h" |
10 #include "base/strings/utf_string_conversions.h" | 11 #include "base/strings/utf_string_conversions.h" |
11 #include "base/values.h" | 12 #include "base/values.h" |
12 #include "chrome/browser/browser_process.h" | 13 #include "chrome/browser/browser_process.h" |
13 #include "chrome/browser/browser_shutdown.h" | 14 #include "chrome/browser/browser_shutdown.h" |
14 #include "chrome/browser/chromeos/login/ui/user_adding_screen.h" | 15 #include "chrome/browser/chromeos/login/ui/user_adding_screen.h" |
15 #include "chrome/browser/chromeos/policy/consumer_management_service.h" | 16 #include "chrome/browser/chromeos/policy/consumer_management_service.h" |
16 #include "chrome/browser/chromeos/profiles/profile_helper.h" | 17 #include "chrome/browser/chromeos/profiles/profile_helper.h" |
17 #include "chrome/browser/chromeos/settings/cros_settings.h" | 18 #include "chrome/browser/chromeos/settings/cros_settings.h" |
18 #include "chrome/browser/io_thread.h" | 19 #include "chrome/browser/io_thread.h" |
19 #include "chrome/browser/ui/webui/chromeos/login/signin_screen_handler.h" | 20 #include "chrome/browser/ui/webui/chromeos/login/signin_screen_handler.h" |
20 #include "chrome/browser/ui/webui/signin/inline_login_ui.h" | 21 #include "chrome/browser/ui/webui/signin/inline_login_ui.h" |
| 22 #include "chrome/common/pref_names.h" |
21 #include "chrome/grit/generated_resources.h" | 23 #include "chrome/grit/generated_resources.h" |
22 #include "chromeos/chromeos_switches.h" | 24 #include "chromeos/chromeos_switches.h" |
23 #include "chromeos/settings/cros_settings_names.h" | 25 #include "chromeos/settings/cros_settings_names.h" |
24 #include "components/user_manager/user_manager.h" | 26 #include "components/user_manager/user_manager.h" |
25 #include "content/public/browser/browser_thread.h" | 27 #include "content/public/browser/browser_thread.h" |
26 #include "content/public/browser/render_frame_host.h" | 28 #include "content/public/browser/render_frame_host.h" |
27 #include "google_apis/gaia/gaia_auth_util.h" | 29 #include "google_apis/gaia/gaia_auth_util.h" |
28 #include "google_apis/gaia/gaia_switches.h" | 30 #include "google_apis/gaia/gaia_switches.h" |
29 #include "google_apis/gaia/gaia_urls.h" | 31 #include "google_apis/gaia/gaia_urls.h" |
30 #include "ui/base/l10n/l10n_util.h" | 32 #include "ui/base/l10n/l10n_util.h" |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
107 | 109 |
108 GaiaContext::GaiaContext() | 110 GaiaContext::GaiaContext() |
109 : force_reload(false), | 111 : force_reload(false), |
110 is_local(false), | 112 is_local(false), |
111 password_changed(false), | 113 password_changed(false), |
112 show_users(false), | 114 show_users(false), |
113 use_offline(false), | 115 use_offline(false), |
114 has_users(false) {} | 116 has_users(false) {} |
115 | 117 |
116 GaiaScreenHandler::GaiaScreenHandler( | 118 GaiaScreenHandler::GaiaScreenHandler( |
| 119 CoreOobeActor* core_oobe_actor, |
117 const scoped_refptr<NetworkStateInformer>& network_state_informer, | 120 const scoped_refptr<NetworkStateInformer>& network_state_informer, |
118 policy::ConsumerManagementService* consumer_management) | 121 policy::ConsumerManagementService* consumer_management) |
119 : BaseScreenHandler(kJsScreenPath), | 122 : BaseScreenHandler(kJsScreenPath), |
120 frame_state_(FRAME_STATE_UNKNOWN), | 123 frame_state_(FRAME_STATE_UNKNOWN), |
121 frame_error_(net::OK), | 124 frame_error_(net::OK), |
122 network_state_informer_(network_state_informer), | 125 network_state_informer_(network_state_informer), |
123 consumer_management_(consumer_management), | 126 consumer_management_(consumer_management), |
| 127 core_oobe_actor_(core_oobe_actor), |
124 dns_cleared_(false), | 128 dns_cleared_(false), |
125 dns_clear_task_running_(false), | 129 dns_clear_task_running_(false), |
126 cookies_cleared_(false), | 130 cookies_cleared_(false), |
127 focus_stolen_(false), | 131 focus_stolen_(false), |
128 gaia_silent_load_(false), | 132 gaia_silent_load_(false), |
129 using_saml_api_(false), | 133 using_saml_api_(false), |
130 is_enrolling_consumer_management_(false), | 134 is_enrolling_consumer_management_(false), |
131 test_expects_complete_login_(false), | 135 test_expects_complete_login_(false), |
132 signin_screen_handler_(NULL), | 136 signin_screen_handler_(NULL), |
133 weak_factory_(this) { | 137 weak_factory_(this) { |
(...skipping 426 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
560 signin_screen_handler_->UpdateUIState( | 564 signin_screen_handler_->UpdateUIState( |
561 SigninScreenHandler::UI_STATE_GAIA_SIGNIN, NULL); | 565 SigninScreenHandler::UI_STATE_GAIA_SIGNIN, NULL); |
562 | 566 |
563 if (gaia_silent_load_) { | 567 if (gaia_silent_load_) { |
564 // The variable is assigned to false because silently loaded Gaia page was | 568 // The variable is assigned to false because silently loaded Gaia page was |
565 // used. | 569 // used. |
566 gaia_silent_load_ = false; | 570 gaia_silent_load_ = false; |
567 if (focus_stolen_) | 571 if (focus_stolen_) |
568 HandleGaiaUIReady(); | 572 HandleGaiaUIReady(); |
569 } | 573 } |
| 574 signin_screen_handler_->UpdateState(ErrorScreenActor::ERROR_REASON_UPDATE); |
570 | 575 |
571 signin_screen_handler_->UpdateState(ErrorScreenActor::ERROR_REASON_UPDATE); | 576 PrefService* prefs = g_browser_process->local_state(); |
| 577 if (prefs->GetBoolean(prefs::kFactoryResetRequested)) { |
| 578 if (core_oobe_actor_) |
| 579 core_oobe_actor_->ShowDeviceResetScreen(); |
| 580 } |
572 } | 581 } |
573 | 582 |
574 void GaiaScreenHandler::MaybePreloadAuthExtension() { | 583 void GaiaScreenHandler::MaybePreloadAuthExtension() { |
575 VLOG(1) << "MaybePreloadAuthExtension() call."; | 584 VLOG(1) << "MaybePreloadAuthExtension() call."; |
576 | 585 |
577 // If cookies clearing was initiated or |dns_clear_task_running_| then auth | 586 // If cookies clearing was initiated or |dns_clear_task_running_| then auth |
578 // extension showing has already been initiated and preloading is senseless. | 587 // extension showing has already been initiated and preloading is senseless. |
579 if (signin_screen_handler_->ShouldLoadGaia() && | 588 if (signin_screen_handler_->ShouldLoadGaia() && |
580 !gaia_silent_load_ && | 589 !gaia_silent_load_ && |
581 !cookies_cleared_ && | 590 !cookies_cleared_ && |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
615 | 624 |
616 SigninScreenHandlerDelegate* GaiaScreenHandler::Delegate() { | 625 SigninScreenHandlerDelegate* GaiaScreenHandler::Delegate() { |
617 DCHECK(signin_screen_handler_); | 626 DCHECK(signin_screen_handler_); |
618 return signin_screen_handler_->delegate_; | 627 return signin_screen_handler_->delegate_; |
619 } | 628 } |
620 | 629 |
621 void GaiaScreenHandler::SetSigninScreenHandler(SigninScreenHandler* handler) { | 630 void GaiaScreenHandler::SetSigninScreenHandler(SigninScreenHandler* handler) { |
622 signin_screen_handler_ = handler; | 631 signin_screen_handler_ = handler; |
623 } | 632 } |
624 } // namespace chromeos | 633 } // namespace chromeos |
OLD | NEW |