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.h" | 10 #include "base/message_loop/message_loop.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 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 BrowserPolicyConnectorChromeOS* connector = | 102 BrowserPolicyConnectorChromeOS* connector = |
105 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | 103 g_browser_process->platform_part()->browser_policy_connector_chromeos(); |
106 DeviceCloudPolicyInitializer* initializer = | 104 DeviceCloudPolicyInitializer* initializer = |
107 connector->GetDeviceCloudPolicyInitializer(); | 105 connector->GetDeviceCloudPolicyInitializer(); |
108 CHECK(initializer); | 106 CHECK(initializer); |
109 | 107 |
110 policy::DeviceCloudPolicyInitializer::AllowedDeviceModes device_modes; | 108 policy::DeviceCloudPolicyInitializer::AllowedDeviceModes device_modes; |
111 device_modes[policy::DEVICE_MODE_ENTERPRISE] = true; | 109 device_modes[policy::DEVICE_MODE_ENTERPRISE] = true; |
112 | 110 |
113 initializer->StartEnrollment( | 111 initializer->StartEnrollment( |
114 em::PolicyData::CONSUMER_MANAGED, | 112 MANAGEMENT_MODE_CONSUMER_MANAGED, |
115 device_management_service_, | 113 device_management_service_, |
116 access_token, | 114 access_token, |
117 false, // is_auto_enrollment | 115 false, // is_auto_enrollment |
118 device_modes, | 116 device_modes, |
119 base::Bind(&ConsumerEnrollmentHandler::OnEnrollmentCompleted, | 117 base::Bind(&ConsumerEnrollmentHandler::OnEnrollmentCompleted, |
120 weak_ptr_factory_.GetWeakPtr())); | 118 weak_ptr_factory_.GetWeakPtr())); |
121 } | 119 } |
122 | 120 |
123 void ConsumerEnrollmentHandler::OnEnrollmentCompleted(EnrollmentStatus status) { | 121 void ConsumerEnrollmentHandler::OnEnrollmentCompleted(EnrollmentStatus status) { |
124 if (status.status() != EnrollmentStatus::STATUS_SUCCESS) { | 122 if (status.status() != EnrollmentStatus::STATUS_SUCCESS) { |
125 LOG(ERROR) << "Failed to enroll the device." | 123 LOG(ERROR) << "Failed to enroll the device." |
126 << " status=" << status.status() | 124 << " status=" << status.status() |
127 << " client_status=" << status.client_status() | 125 << " client_status=" << status.client_status() |
128 << " http_status=" << status.http_status() | 126 << " http_status=" << status.http_status() |
129 << " store_status=" << status.store_status() | 127 << " store_status=" << status.store_status() |
130 << " validation_status=" << status.validation_status(); | 128 << " validation_status=" << status.validation_status(); |
131 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_DM_SERVER_FAILED); | 129 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_DM_SERVER_FAILED); |
132 return; | 130 return; |
133 } | 131 } |
134 | 132 |
135 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS); | 133 EndEnrollment(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS); |
136 } | 134 } |
137 | 135 |
138 void ConsumerEnrollmentHandler::EndEnrollment( | 136 void ConsumerEnrollmentHandler::EndEnrollment( |
139 ConsumerManagementService::EnrollmentStage stage) { | 137 ConsumerManagementService::EnrollmentStage stage) { |
140 consumer_management_service_->SetEnrollmentStage(stage); | 138 consumer_management_service_->SetEnrollmentStage(stage); |
141 } | 139 } |
142 | 140 |
143 } // namespace policy | 141 } // namespace policy |
OLD | NEW |