OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/arc/arc_policy_bridge.h" | 5 #include "chrome/browser/chromeos/arc/arc_policy_bridge.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 #include <string> | 8 #include <string> |
9 | 9 |
10 #include "base/json/json_reader.h" | 10 #include "base/json/json_reader.h" |
(...skipping 216 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
227 JSONStringValueSerializer serializer(&policy_json); | 227 JSONStringValueSerializer serializer(&policy_json); |
228 serializer.Serialize(filtered_policies); | 228 serializer.Serialize(filtered_policies); |
229 return policy_json; | 229 return policy_json; |
230 } | 230 } |
231 | 231 |
232 } // namespace | 232 } // namespace |
233 | 233 |
234 ArcPolicyBridge::ArcPolicyBridge(ArcBridgeService* bridge_service) | 234 ArcPolicyBridge::ArcPolicyBridge(ArcBridgeService* bridge_service) |
235 : ArcService(bridge_service), binding_(this) { | 235 : ArcService(bridge_service), binding_(this) { |
236 VLOG(2) << "ArcPolicyBridge::ArcPolicyBridge"; | 236 VLOG(2) << "ArcPolicyBridge::ArcPolicyBridge"; |
237 arc_bridge_service()->AddObserver(this); | 237 arc_bridge_service()->policy()->AddObserver(this); |
238 } | 238 } |
239 | 239 |
240 ArcPolicyBridge::ArcPolicyBridge(ArcBridgeService* bridge_service, | 240 ArcPolicyBridge::ArcPolicyBridge(ArcBridgeService* bridge_service, |
241 policy::PolicyService* policy_service) | 241 policy::PolicyService* policy_service) |
242 : ArcService(bridge_service), | 242 : ArcService(bridge_service), |
243 binding_(this), | 243 binding_(this), |
244 policy_service_(policy_service) { | 244 policy_service_(policy_service) { |
245 VLOG(2) << "ArcPolicyBridge::ArcPolicyBridge(bridge_service, policy_service)"; | 245 VLOG(2) << "ArcPolicyBridge::ArcPolicyBridge(bridge_service, policy_service)"; |
246 arc_bridge_service()->AddObserver(this); | 246 arc_bridge_service()->policy()->AddObserver(this); |
247 } | 247 } |
248 | 248 |
249 ArcPolicyBridge::~ArcPolicyBridge() { | 249 ArcPolicyBridge::~ArcPolicyBridge() { |
250 VLOG(2) << "ArcPolicyBridge::~ArcPolicyBridge"; | 250 VLOG(2) << "ArcPolicyBridge::~ArcPolicyBridge"; |
251 arc_bridge_service()->RemoveObserver(this); | 251 arc_bridge_service()->policy()->RemoveObserver(this); |
252 } | 252 } |
253 | 253 |
254 void ArcPolicyBridge::OverrideIsManagedForTesting(bool is_managed) { | 254 void ArcPolicyBridge::OverrideIsManagedForTesting(bool is_managed) { |
255 is_managed_ = is_managed; | 255 is_managed_ = is_managed; |
256 } | 256 } |
257 | 257 |
258 void ArcPolicyBridge::OnPolicyInstanceReady() { | 258 void ArcPolicyBridge::OnInstanceReady(mojom::PolicyInstance* policy_instance, |
| 259 uint32_t version) { |
259 VLOG(1) << "ArcPolicyBridge::OnPolicyInstanceReady"; | 260 VLOG(1) << "ArcPolicyBridge::OnPolicyInstanceReady"; |
260 if (policy_service_ == nullptr) { | 261 if (policy_service_ == nullptr) { |
261 InitializePolicyService(); | 262 InitializePolicyService(); |
262 } | 263 } |
263 policy_service_->AddObserver(policy::POLICY_DOMAIN_CHROME, this); | 264 policy_service_->AddObserver(policy::POLICY_DOMAIN_CHROME, this); |
264 | 265 |
265 mojom::PolicyInstance* const policy_instance = | |
266 arc_bridge_service()->policy_instance(); | |
267 if (!policy_instance) { | |
268 LOG(ERROR) << "OnPolicyInstanceReady called, but no policy instance found"; | |
269 return; | |
270 } | |
271 | |
272 policy_instance->Init(binding_.CreateInterfacePtrAndBind()); | 266 policy_instance->Init(binding_.CreateInterfacePtrAndBind()); |
273 } | 267 } |
274 | 268 |
275 void ArcPolicyBridge::OnPolicyInstanceClosed() { | 269 void ArcPolicyBridge::OnInstanceClosed(mojom::PolicyInstance*) { |
276 VLOG(1) << "ArcPolicyBridge::OnPolicyInstanceClosed"; | 270 VLOG(1) << "ArcPolicyBridge::OnPolicyInstanceClosed"; |
277 policy_service_->RemoveObserver(policy::POLICY_DOMAIN_CHROME, this); | 271 policy_service_->RemoveObserver(policy::POLICY_DOMAIN_CHROME, this); |
278 policy_service_ = nullptr; | 272 policy_service_ = nullptr; |
279 } | 273 } |
280 | 274 |
281 void ArcPolicyBridge::GetPolicies(const GetPoliciesCallback& callback) { | 275 void ArcPolicyBridge::GetPolicies(const GetPoliciesCallback& callback) { |
282 VLOG(1) << "ArcPolicyBridge::GetPolicies"; | 276 VLOG(1) << "ArcPolicyBridge::GetPolicies"; |
283 if (!is_managed_) { | 277 if (!is_managed_) { |
284 callback.Run(mojo::String("")); | 278 callback.Run(mojo::String("")); |
285 return; | 279 return; |
286 } | 280 } |
287 const policy::PolicyNamespace policy_namespace(policy::POLICY_DOMAIN_CHROME, | 281 const policy::PolicyNamespace policy_namespace(policy::POLICY_DOMAIN_CHROME, |
288 std::string()); | 282 std::string()); |
289 const policy::PolicyMap& policy_map = | 283 const policy::PolicyMap& policy_map = |
290 policy_service_->GetPolicies(policy_namespace); | 284 policy_service_->GetPolicies(policy_namespace); |
291 const std::string json_policies = GetFilteredJSONPolicies(policy_map); | 285 const std::string json_policies = GetFilteredJSONPolicies(policy_map); |
292 callback.Run(mojo::String(json_policies)); | 286 callback.Run(mojo::String(json_policies)); |
293 } | 287 } |
294 | 288 |
295 void ArcPolicyBridge::OnPolicyUpdated(const policy::PolicyNamespace& ns, | 289 void ArcPolicyBridge::OnPolicyUpdated(const policy::PolicyNamespace& ns, |
296 const policy::PolicyMap& previous, | 290 const policy::PolicyMap& previous, |
297 const policy::PolicyMap& current) { | 291 const policy::PolicyMap& current) { |
298 VLOG(1) << "ArcPolicyBridge::OnPolicyUpdated"; | 292 VLOG(1) << "ArcPolicyBridge::OnPolicyUpdated"; |
299 DCHECK(arc_bridge_service()->policy_instance()); | 293 DCHECK(arc_bridge_service()->policy()->instance()); |
300 arc_bridge_service()->policy_instance()->OnPolicyUpdated(); | 294 arc_bridge_service()->policy()->instance()->OnPolicyUpdated(); |
301 } | 295 } |
302 | 296 |
303 void ArcPolicyBridge::InitializePolicyService() { | 297 void ArcPolicyBridge::InitializePolicyService() { |
304 const user_manager::User* const primary_user = | 298 const user_manager::User* const primary_user = |
305 user_manager::UserManager::Get()->GetPrimaryUser(); | 299 user_manager::UserManager::Get()->GetPrimaryUser(); |
306 Profile* const profile = | 300 Profile* const profile = |
307 chromeos::ProfileHelper::Get()->GetProfileByUser(primary_user); | 301 chromeos::ProfileHelper::Get()->GetProfileByUser(primary_user); |
308 auto profile_policy_connector = | 302 auto profile_policy_connector = |
309 policy::ProfilePolicyConnectorFactory::GetForBrowserContext(profile); | 303 policy::ProfilePolicyConnectorFactory::GetForBrowserContext(profile); |
310 policy_service_ = profile_policy_connector->policy_service(); | 304 policy_service_ = profile_policy_connector->policy_service(); |
311 is_managed_ = profile_policy_connector->IsManaged(); | 305 is_managed_ = profile_policy_connector->IsManaged(); |
312 } | 306 } |
313 | 307 |
314 } // namespace arc | 308 } // namespace arc |
OLD | NEW |