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