OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/settings/session_manager_operation.h" | 5 #include "chrome/browser/chromeos/settings/session_manager_operation.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
13 #include "base/message_loop/message_loop.h" | 13 #include "base/message_loop/message_loop.h" |
14 #include "base/stl_util.h" | 14 #include "base/stl_util.h" |
15 #include "base/task_runner_util.h" | 15 #include "base/task_runner_util.h" |
16 #include "base/task_scheduler/post_task.h" | 16 #include "base/task_scheduler/post_task.h" |
17 #include "base/threading/sequenced_worker_pool.h" | 17 #include "base/threading/sequenced_worker_pool.h" |
18 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" | 18 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" |
19 #include "chrome/browser/net/nss_context.h" | 19 #include "chrome/browser/net/nss_context.h" |
20 #include "components/ownership/owner_key_util.h" | 20 #include "components/ownership/owner_key_util.h" |
21 #include "components/policy/core/common/cloud/cloud_policy_constants.h" | 21 #include "components/policy/core/common/cloud/cloud_policy_constants.h" |
22 #include "components/policy/proto/device_management_backend.pb.h" | 22 #include "components/policy/proto/device_management_backend.pb.h" |
23 #include "content/public/browser/browser_thread.h" | 23 #include "content/public/browser/browser_thread.h" |
24 #include "crypto/rsa_private_key.h" | 24 #include "crypto/rsa_private_key.h" |
25 #include "crypto/signature_creator.h" | 25 #include "crypto/signature_creator.h" |
26 | 26 |
| 27 using RetrievePolicyResponseType = |
| 28 chromeos::SessionManagerClient::RetrievePolicyResponseType; |
27 using ownership::OwnerKeyUtil; | 29 using ownership::OwnerKeyUtil; |
28 using ownership::PublicKey; | 30 using ownership::PublicKey; |
29 | 31 |
30 namespace em = enterprise_management; | 32 namespace em = enterprise_management; |
31 | 33 |
32 namespace chromeos { | 34 namespace chromeos { |
33 | 35 |
34 SessionManagerOperation::SessionManagerOperation(const Callback& callback) | 36 SessionManagerOperation::SessionManagerOperation(const Callback& callback) |
35 : callback_(callback), weak_factory_(this) {} | 37 : callback_(callback), weak_factory_(this) {} |
36 | 38 |
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
135 callback.Run(); | 137 callback.Run(); |
136 } | 138 } |
137 | 139 |
138 void SessionManagerOperation::RetrieveDeviceSettings() { | 140 void SessionManagerOperation::RetrieveDeviceSettings() { |
139 session_manager_client()->RetrieveDevicePolicy( | 141 session_manager_client()->RetrieveDevicePolicy( |
140 base::Bind(&SessionManagerOperation::ValidateDeviceSettings, | 142 base::Bind(&SessionManagerOperation::ValidateDeviceSettings, |
141 weak_factory_.GetWeakPtr())); | 143 weak_factory_.GetWeakPtr())); |
142 } | 144 } |
143 | 145 |
144 void SessionManagerOperation::BlockingRetrieveDeviceSettings() { | 146 void SessionManagerOperation::BlockingRetrieveDeviceSettings() { |
145 ValidateDeviceSettings( | 147 std::string policy_blob; |
146 session_manager_client()->BlockingRetrieveDevicePolicy()); | 148 RetrievePolicyResponseType response = |
| 149 session_manager_client()->BlockingRetrieveDevicePolicy(&policy_blob); |
| 150 ValidateDeviceSettings(policy_blob, response); |
147 } | 151 } |
148 | 152 |
149 void SessionManagerOperation::ValidateDeviceSettings( | 153 void SessionManagerOperation::ValidateDeviceSettings( |
150 const std::string& policy_blob) { | 154 const std::string& policy_blob, |
| 155 RetrievePolicyResponseType response_type) { |
151 std::unique_ptr<em::PolicyFetchResponse> policy( | 156 std::unique_ptr<em::PolicyFetchResponse> policy( |
152 new em::PolicyFetchResponse()); | 157 new em::PolicyFetchResponse()); |
153 if (policy_blob.empty()) { | 158 if (policy_blob.empty()) { |
154 ReportResult(DeviceSettingsService::STORE_NO_POLICY); | 159 ReportResult(DeviceSettingsService::STORE_NO_POLICY); |
155 return; | 160 return; |
156 } | 161 } |
157 | 162 |
158 if (!policy->ParseFromString(policy_blob) || | 163 if (!policy->ParseFromString(policy_blob) || !policy->IsInitialized()) { |
159 !policy->IsInitialized()) { | |
160 ReportResult(DeviceSettingsService::STORE_INVALID_POLICY); | 164 ReportResult(DeviceSettingsService::STORE_INVALID_POLICY); |
161 return; | 165 return; |
162 } | 166 } |
163 | 167 |
164 base::SequencedWorkerPool* pool = | 168 base::SequencedWorkerPool* pool = |
165 content::BrowserThread::GetBlockingPool(); | 169 content::BrowserThread::GetBlockingPool(); |
166 scoped_refptr<base::SequencedTaskRunner> background_task_runner = | 170 scoped_refptr<base::SequencedTaskRunner> background_task_runner = |
167 pool->GetSequencedTaskRunnerWithShutdownBehavior( | 171 pool->GetSequencedTaskRunnerWithShutdownBehavior( |
168 pool->GetSequenceToken(), | 172 pool->GetSequenceToken(), |
169 base::SequencedWorkerPool::SKIP_ON_SHUTDOWN); | 173 base::SequencedWorkerPool::SKIP_ON_SHUTDOWN); |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
266 } | 270 } |
267 | 271 |
268 void StoreSettingsOperation::HandleStoreResult(bool success) { | 272 void StoreSettingsOperation::HandleStoreResult(bool success) { |
269 if (!success) | 273 if (!success) |
270 ReportResult(DeviceSettingsService::STORE_OPERATION_FAILED); | 274 ReportResult(DeviceSettingsService::STORE_OPERATION_FAILED); |
271 else | 275 else |
272 StartLoading(); | 276 StartLoading(); |
273 } | 277 } |
274 | 278 |
275 } // namespace chromeos | 279 } // namespace chromeos |
OLD | NEW |