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

Side by Side Diff: chrome/browser/chromeos/login/enrollment/auto_enrollment_check_screen.cc

Issue 289133002: Add a enterprise enrollment check screen to OOBE in ChromeOS. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Improved wording. Created 6 years, 7 months 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 | Annotate | Revision Log
OLDNEW
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/enrollment/auto_enrollment_check_step.h" 5 #include "chrome/browser/chromeos/login/enrollment/auto_enrollment_check_screen. h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "chrome/browser/chromeos/login/screens/screen_observer.h" 11 #include "chrome/browser/chromeos/login/screens/screen_observer.h"
12 #include "chrome/browser/chromeos/login/wizard_controller.h"
12 #include "chromeos/chromeos_switches.h" 13 #include "chromeos/chromeos_switches.h"
13 #include "chromeos/network/network_state.h" 14 #include "chromeos/network/network_state.h"
14 #include "chromeos/network/network_state_handler.h" 15 #include "chromeos/network/network_state_handler.h"
15 16
16 namespace chromeos { 17 namespace chromeos {
17 18
18 AutoEnrollmentCheckStep::AutoEnrollmentCheckStep( 19 AutoEnrollmentCheckScreen::AutoEnrollmentCheckScreen(
19 ScreenObserver* screen_observer, 20 ScreenObserver* observer,
21 AutoEnrollmentCheckScreenActor* actor,
20 AutoEnrollmentController* auto_enrollment_controller) 22 AutoEnrollmentController* auto_enrollment_controller)
21 : screen_observer_(screen_observer), 23 : WizardScreen(observer),
24 actor_(actor),
22 auto_enrollment_controller_(auto_enrollment_controller), 25 auto_enrollment_controller_(auto_enrollment_controller),
23 captive_portal_status_( 26 captive_portal_status_(
24 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_UNKNOWN), 27 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_UNKNOWN),
25 auto_enrollment_state_(policy::AUTO_ENROLLMENT_STATE_IDLE) {} 28 auto_enrollment_state_(policy::AUTO_ENROLLMENT_STATE_IDLE) {
29 DCHECK(actor_);
30 if (actor_)
Mattias Nissler (ping if slow) 2014/05/19 19:25:51 indentation
pastarmovj 2014/05/20 13:50:08 Done.
31 actor_->SetDelegate(this);
32 }
26 33
27 AutoEnrollmentCheckStep::~AutoEnrollmentCheckStep() { 34 AutoEnrollmentCheckScreen::~AutoEnrollmentCheckScreen() {
28 NetworkPortalDetector::Get()->RemoveObserver(this); 35 NetworkPortalDetector::Get()->RemoveObserver(this);
29 } 36 }
30 37
31 void AutoEnrollmentCheckStep::Start() { 38 void AutoEnrollmentCheckScreen::Start() {
32 if (AutoEnrollmentController::GetMode() != 39 if (AutoEnrollmentController::GetMode() !=
33 AutoEnrollmentController::MODE_FORCED_RE_ENROLLMENT) { 40 AutoEnrollmentController::MODE_FORCED_RE_ENROLLMENT) {
34 SignalCompletion(); 41 SignalCompletion();
35 return; 42 return;
36 } 43 }
37 44
38 // Make sure the auto-enrollment client is running. 45 // Make sure the auto-enrollment client is running.
39 auto_enrollment_controller_->Start(); 46 auto_enrollment_controller_->Start();
40 47
41 auto_enrollment_progress_subscription_ = 48 auto_enrollment_progress_subscription_ =
42 auto_enrollment_controller_->RegisterProgressCallback( 49 auto_enrollment_controller_->RegisterProgressCallback(
43 base::Bind(&AutoEnrollmentCheckStep::OnAutoEnrollmentCheckProgressed, 50 base::Bind(
44 base::Unretained(this))); 51 &AutoEnrollmentCheckScreen::OnAutoEnrollmentCheckProgressed,
52 base::Unretained(this)));
45 auto_enrollment_state_ = auto_enrollment_controller_->state(); 53 auto_enrollment_state_ = auto_enrollment_controller_->state();
46 54
47 // NB: AddAndFireObserver below call back into OnPortalDetectionCompleted. 55 // NB: AddAndFireObserver below call back into OnPortalDetectionCompleted.
48 // This guarantees that the UI gets synced to current state. 56 // This guarantees that the UI gets synced to current state.
49 NetworkPortalDetector* portal_detector = NetworkPortalDetector::Get(); 57 NetworkPortalDetector* portal_detector = NetworkPortalDetector::Get();
50 portal_detector->StartDetectionIfIdle(); 58 portal_detector->StartDetectionIfIdle();
51 portal_detector->AddAndFireObserver(this); 59 portal_detector->AddAndFireObserver(this);
52 } 60 }
53 61
54 void AutoEnrollmentCheckStep::OnPortalDetectionCompleted( 62 void AutoEnrollmentCheckScreen::PrepareToShow() {
63 }
64
65 void AutoEnrollmentCheckScreen::Show() {
66 if (actor_)
67 actor_->Show();
Mattias Nissler (ping if slow) 2014/05/19 19:25:51 I don't think we should even call actor_->Show() i
pastarmovj 2014/05/20 13:50:08 Done.
68 Start();
69 }
70
71 void AutoEnrollmentCheckScreen::Hide() {
72 }
73
74 std::string AutoEnrollmentCheckScreen::GetName() const {
75 return WizardController::kAutoEnrollmentCheckScreenName;
76 }
77
78 void AutoEnrollmentCheckScreen::OnExit() {
79 get_screen_observer()->OnExit(
80 ScreenObserver::ENTERPRISE_AUTO_ENROLLMENT_CHECK_COMPLETED);
81 }
82
83 void AutoEnrollmentCheckScreen::OnActorDestroyed(
84 AutoEnrollmentCheckScreenActor* actor) {
85 if (actor_ == actor)
86 actor_ = NULL;
87 }
88
89 void AutoEnrollmentCheckScreen::OnPortalDetectionCompleted(
55 const NetworkState* /* network */, 90 const NetworkState* /* network */,
56 const NetworkPortalDetector::CaptivePortalState& state) { 91 const NetworkPortalDetector::CaptivePortalState& state) {
57 UpdateState(state.status, auto_enrollment_state_); 92 UpdateState(state.status, auto_enrollment_state_);
58 } 93 }
59 94
60 void AutoEnrollmentCheckStep::OnAutoEnrollmentCheckProgressed( 95 void AutoEnrollmentCheckScreen::OnAutoEnrollmentCheckProgressed(
61 policy::AutoEnrollmentState state) { 96 policy::AutoEnrollmentState state) {
62 UpdateState(captive_portal_status_, state); 97 UpdateState(captive_portal_status_, state);
63 } 98 }
64 99
65 void AutoEnrollmentCheckStep::UpdateState( 100 void AutoEnrollmentCheckScreen::UpdateState(
66 NetworkPortalDetector::CaptivePortalStatus new_captive_portal_status, 101 NetworkPortalDetector::CaptivePortalStatus new_captive_portal_status,
67 policy::AutoEnrollmentState new_auto_enrollment_state) { 102 policy::AutoEnrollmentState new_auto_enrollment_state) {
68 // Configure the error screen to show the approriate error message. 103 // Configure the error screen to show the approriate error message.
69 if (!UpdateCaptivePortalStatus(new_captive_portal_status)) 104 if (!UpdateCaptivePortalStatus(new_captive_portal_status))
70 UpdateAutoEnrollmentState(new_auto_enrollment_state); 105 UpdateAutoEnrollmentState(new_auto_enrollment_state);
71 106
72 // Update the connecting indicator. 107 // Update the connecting indicator.
73 ErrorScreen* error_screen = screen_observer_->GetErrorScreen(); 108 ErrorScreen* error_screen = get_screen_observer()->GetErrorScreen();
74 error_screen->ShowConnectingIndicator( 109 error_screen->ShowConnectingIndicator(
75 new_auto_enrollment_state == policy::AUTO_ENROLLMENT_STATE_PENDING); 110 new_auto_enrollment_state == policy::AUTO_ENROLLMENT_STATE_PENDING);
76 111
77 // Determine whether a retry is in order. 112 // Determine whether a retry is in order.
78 bool retry = (new_captive_portal_status == 113 bool retry = (new_captive_portal_status ==
79 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE) && 114 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE) &&
80 (captive_portal_status_ != 115 (captive_portal_status_ !=
81 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE); 116 NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE);
82 117
83 // Save the new state. 118 // Save the new state.
(...skipping 16 matching lines...) Expand all
100 SignalCompletion(); 135 SignalCompletion();
101 return; 136 return;
102 } 137 }
103 138
104 // Retry if applicable. This is last so eventual callbacks find consistent 139 // Retry if applicable. This is last so eventual callbacks find consistent
105 // state. 140 // state.
106 if (retry) 141 if (retry)
107 auto_enrollment_controller_->Retry(); 142 auto_enrollment_controller_->Retry();
108 } 143 }
109 144
110 bool AutoEnrollmentCheckStep::UpdateCaptivePortalStatus( 145 bool AutoEnrollmentCheckScreen::UpdateCaptivePortalStatus(
111 NetworkPortalDetector::CaptivePortalStatus new_captive_portal_status) { 146 NetworkPortalDetector::CaptivePortalStatus new_captive_portal_status) {
112 switch (new_captive_portal_status) { 147 switch (new_captive_portal_status) {
113 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_UNKNOWN: 148 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_UNKNOWN:
114 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE: 149 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE:
115 return false; 150 return false;
116 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_OFFLINE: 151 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_OFFLINE:
117 ShowErrorScreen(ErrorScreen::ERROR_STATE_OFFLINE); 152 ShowErrorScreen(ErrorScreen::ERROR_STATE_OFFLINE);
118 return true; 153 return true;
119 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PORTAL: 154 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PORTAL:
120 ShowErrorScreen(ErrorScreen::ERROR_STATE_PORTAL); 155 ShowErrorScreen(ErrorScreen::ERROR_STATE_PORTAL);
121 if (captive_portal_status_ != new_captive_portal_status) 156 if (captive_portal_status_ != new_captive_portal_status)
122 screen_observer_->GetErrorScreen()->FixCaptivePortal(); 157 get_screen_observer()->GetErrorScreen()->FixCaptivePortal();
123 return true; 158 return true;
124 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PROXY_AUTH_REQUIRED: 159 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_PROXY_AUTH_REQUIRED:
125 ShowErrorScreen(ErrorScreen::ERROR_STATE_PROXY); 160 ShowErrorScreen(ErrorScreen::ERROR_STATE_PROXY);
126 return true; 161 return true;
127 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_COUNT: 162 case NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_COUNT:
128 // Trigger NOTREACHED() below. 163 // Trigger NOTREACHED() below.
129 break; 164 break;
130 } 165 }
131 166
132 NOTREACHED() << "Bad status " << new_captive_portal_status; 167 NOTREACHED() << "Bad status " << new_captive_portal_status;
133 return false; 168 return false;
134 } 169 }
135 170
136 bool AutoEnrollmentCheckStep::UpdateAutoEnrollmentState( 171 bool AutoEnrollmentCheckScreen::UpdateAutoEnrollmentState(
137 policy::AutoEnrollmentState new_auto_enrollment_state) { 172 policy::AutoEnrollmentState new_auto_enrollment_state) {
138 switch (new_auto_enrollment_state) { 173 switch (new_auto_enrollment_state) {
139 case policy::AUTO_ENROLLMENT_STATE_IDLE: 174 case policy::AUTO_ENROLLMENT_STATE_IDLE:
140 // The client should have been started already. 175 // The client should have been started already.
141 NOTREACHED(); 176 NOTREACHED();
142 return false; 177 return false;
143 case policy::AUTO_ENROLLMENT_STATE_PENDING: 178 case policy::AUTO_ENROLLMENT_STATE_PENDING:
144 case policy::AUTO_ENROLLMENT_STATE_SERVER_ERROR: 179 case policy::AUTO_ENROLLMENT_STATE_SERVER_ERROR:
145 case policy::AUTO_ENROLLMENT_STATE_TRIGGER_ENROLLMENT: 180 case policy::AUTO_ENROLLMENT_STATE_TRIGGER_ENROLLMENT:
146 case policy::AUTO_ENROLLMENT_STATE_NO_ENROLLMENT: 181 case policy::AUTO_ENROLLMENT_STATE_NO_ENROLLMENT:
147 return false; 182 return false;
148 case policy::AUTO_ENROLLMENT_STATE_CONNECTION_ERROR: 183 case policy::AUTO_ENROLLMENT_STATE_CONNECTION_ERROR:
149 ShowErrorScreen(ErrorScreen::ERROR_STATE_OFFLINE); 184 ShowErrorScreen(ErrorScreen::ERROR_STATE_OFFLINE);
150 return true; 185 return true;
151 } 186 }
152 187
153 NOTREACHED() << "bad state " << new_auto_enrollment_state; 188 NOTREACHED() << "bad state " << new_auto_enrollment_state;
154 return false; 189 return false;
155 } 190 }
156 191
157 void AutoEnrollmentCheckStep::ShowErrorScreen( 192 void AutoEnrollmentCheckScreen::ShowErrorScreen(
158 ErrorScreen::ErrorState error_state) { 193 ErrorScreen::ErrorState error_state) {
159 const NetworkState* network = 194 const NetworkState* network =
160 NetworkHandler::Get()->network_state_handler()->DefaultNetwork(); 195 NetworkHandler::Get()->network_state_handler()->DefaultNetwork();
161 ErrorScreen* error_screen = screen_observer_->GetErrorScreen(); 196 ErrorScreen* error_screen = get_screen_observer()->GetErrorScreen();
162 error_screen->SetUIState(ErrorScreen::UI_STATE_AUTO_ENROLLMENT_ERROR); 197 error_screen->SetUIState(ErrorScreen::UI_STATE_AUTO_ENROLLMENT_ERROR);
163 error_screen->AllowGuestSignin(true); 198 error_screen->AllowGuestSignin(true);
164 error_screen->SetErrorState(error_state, 199 error_screen->SetErrorState(error_state,
165 network ? network->name() : std::string()); 200 network ? network->name() : std::string());
166 screen_observer_->ShowErrorScreen(); 201 get_screen_observer()->ShowErrorScreen();
167 } 202 }
168 203
169 void AutoEnrollmentCheckStep::SignalCompletion() { 204 void AutoEnrollmentCheckScreen::SignalCompletion() {
170 NetworkPortalDetector::Get()->RemoveObserver(this); 205 NetworkPortalDetector::Get()->RemoveObserver(this);
171 auto_enrollment_progress_subscription_.reset(); 206 auto_enrollment_progress_subscription_.reset();
172 screen_observer_->OnExit( 207 get_screen_observer()->OnExit(
173 ScreenObserver::ENTERPRISE_AUTO_ENROLLMENT_CHECK_COMPLETED); 208 ScreenObserver::ENTERPRISE_AUTO_ENROLLMENT_CHECK_COMPLETED);
174 } 209 }
175 210
176 } // namespace chromeos 211 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698