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/policy/consumer_enrollment_handler.h" | 5 #include "chrome/browser/chromeos/policy/consumer_enrollment_handler.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/message_loop/message_loop_proxy.h" | 10 #include "base/message_loop/message_loop_proxy.h" |
11 #include "base/time/time.h" | 11 #include "base/time/time.h" |
12 #include "chrome/browser/browser_process.h" | 12 #include "chrome/browser/browser_process.h" |
13 #include "chrome/browser/browser_process_platform_part.h" | 13 #include "chrome/browser/browser_process_platform_part.h" |
14 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | 14 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" |
15 #include "chrome/browser/chromeos/policy/device_cloud_policy_initializer.h" | 15 #include "chrome/browser/chromeos/policy/device_cloud_policy_initializer.h" |
16 #include "chrome/browser/chromeos/policy/enrollment_status_chromeos.h" | 16 #include "chrome/browser/chromeos/policy/enrollment_status_chromeos.h" |
17 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" | 17 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" |
18 #include "chrome/browser/signin/signin_manager_factory.h" | 18 #include "chrome/browser/signin/signin_manager_factory.h" |
| 19 #include "components/policy/core/common/cloud/cloud_policy_constants.h" |
19 #include "components/signin/core/browser/profile_oauth2_token_service.h" | 20 #include "components/signin/core/browser/profile_oauth2_token_service.h" |
20 #include "components/signin/core/browser/signin_manager_base.h" | 21 #include "components/signin/core/browser/signin_manager_base.h" |
21 #include "google_apis/gaia/gaia_constants.h" | 22 #include "google_apis/gaia/gaia_constants.h" |
22 #include "google_apis/gaia/google_service_auth_error.h" | 23 #include "google_apis/gaia/google_service_auth_error.h" |
23 #include "policy/proto/device_management_backend.pb.h" | |
24 | |
25 namespace em = enterprise_management; | |
26 | 24 |
27 namespace policy { | 25 namespace policy { |
28 | 26 |
29 ConsumerEnrollmentHandler::ConsumerEnrollmentHandler( | 27 ConsumerEnrollmentHandler::ConsumerEnrollmentHandler( |
30 Profile* profile, | 28 Profile* profile, |
31 ConsumerManagementService* consumer_management_service, | 29 ConsumerManagementService* consumer_management_service, |
32 DeviceManagementService* device_management_service) | 30 DeviceManagementService* device_management_service) |
33 : Consumer("consumer_enrollment_handler"), | 31 : Consumer("consumer_enrollment_handler"), |
34 profile_(profile), | 32 profile_(profile), |
35 consumer_management_service_(consumer_management_service), | 33 consumer_management_service_(consumer_management_service), |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
106 BrowserPolicyConnectorChromeOS* connector = | 104 BrowserPolicyConnectorChromeOS* connector = |
107 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | 105 g_browser_process->platform_part()->browser_policy_connector_chromeos(); |
108 DeviceCloudPolicyInitializer* initializer = | 106 DeviceCloudPolicyInitializer* initializer = |
109 connector->GetDeviceCloudPolicyInitializer(); | 107 connector->GetDeviceCloudPolicyInitializer(); |
110 CHECK(initializer); | 108 CHECK(initializer); |
111 | 109 |
112 policy::DeviceCloudPolicyInitializer::AllowedDeviceModes device_modes; | 110 policy::DeviceCloudPolicyInitializer::AllowedDeviceModes device_modes; |
113 device_modes[policy::DEVICE_MODE_ENTERPRISE] = true; | 111 device_modes[policy::DEVICE_MODE_ENTERPRISE] = true; |
114 | 112 |
115 initializer->StartEnrollment( | 113 initializer->StartEnrollment( |
116 em::PolicyData::CONSUMER_MANAGED, | 114 MANAGEMENT_MODE_CONSUMER, |
117 device_management_service_, | 115 device_management_service_, |
118 access_token, | 116 access_token, |
119 false, // is_auto_enrollment | 117 false, // is_auto_enrollment |
120 device_modes, | 118 device_modes, |
121 base::Bind(&ConsumerEnrollmentHandler::OnEnrollmentCompleted, | 119 base::Bind(&ConsumerEnrollmentHandler::OnEnrollmentCompleted, |
122 weak_ptr_factory_.GetWeakPtr())); | 120 weak_ptr_factory_.GetWeakPtr())); |
123 } | 121 } |
124 | 122 |
125 void ConsumerEnrollmentHandler::OnEnrollmentCompleted(EnrollmentStatus status) { | 123 void ConsumerEnrollmentHandler::OnEnrollmentCompleted(EnrollmentStatus status) { |
126 if (status.status() != EnrollmentStatus::STATUS_SUCCESS) { | 124 if (status.status() != EnrollmentStatus::STATUS_SUCCESS) { |
127 LOG(ERROR) << "Failed to enroll the device." | 125 LOG(ERROR) << "Failed to enroll the device." |
128 << " status=" << status.status() | 126 << " status=" << status.status() |
129 << " client_status=" << status.client_status() | 127 << " client_status=" << status.client_status() |
130 << " http_status=" << status.http_status() | 128 << " http_status=" << status.http_status() |
131 << " store_status=" << status.store_status() | 129 << " store_status=" << status.store_status() |
132 << " validation_status=" << status.validation_status(); | 130 << " validation_status=" << status.validation_status(); |
133 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_DM_SERVER_FAILED); | 131 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_DM_SERVER_FAILED); |
134 return; | 132 return; |
135 } | 133 } |
136 | 134 |
137 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS); | 135 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS); |
138 } | 136 } |
139 | 137 |
140 void ConsumerEnrollmentHandler::EndEnrollment( | 138 void ConsumerEnrollmentHandler::EndEnrollment( |
141 ConsumerManagementService::EnrollmentStage stage) { | 139 ConsumerManagementService::EnrollmentStage stage) { |
142 consumer_management_service_->SetEnrollmentStage(stage); | 140 consumer_management_service_->SetEnrollmentStage(stage); |
143 } | 141 } |
144 | 142 |
145 } // namespace policy | 143 } // namespace policy |
OLD | NEW |