| 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 |