| // Copyright 2020 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include "ios/chrome/browser/policy/browser_policy_connector_ios.h" |
| |
| #include <stdint.h> |
| |
| #include <utility> |
| |
| #include "base/callback.h" |
| #include "base/macros.h" |
| #include "base/sequenced_task_runner.h" |
| #include "base/strings/stringprintf.h" |
| #include "base/system/sys_info.h" |
| #include "base/task/post_task.h" |
| #include "base/task/thread_pool.h" |
| #include "components/enterprise/browser/controller/chrome_browser_cloud_management_controller.h" |
| #include "components/policy/core/common/async_policy_provider.h" |
| #include "components/policy/core/common/cloud/device_management_service.h" |
| #include "components/policy/core/common/cloud/machine_level_user_cloud_policy_manager.h" |
| #include "components/policy/core/common/configuration_policy_provider.h" |
| #include "components/policy/core/common/policy_loader_ios.h" |
| #include "ios/chrome/browser/policy/chrome_browser_cloud_management_controller_ios.h" |
| #include "ios/chrome/browser/policy/device_management_service_configuration_ios.h" |
| #include "services/network/public/cpp/shared_url_loader_factory.h" |
| |
| #if !defined(__has_feature) || !__has_feature(objc_arc) |
| #error "This file requires ARC support." |
| #endif |
| |
| using policy::AsyncPolicyLoader; |
| using policy::AsyncPolicyProvider; |
| using policy::BrowserPolicyConnectorBase; |
| using policy::BrowserPolicyConnector; |
| using policy::ConfigurationPolicyProvider; |
| using policy::HandlerListFactory; |
| using policy::PolicyLoaderIOS; |
| |
| BrowserPolicyConnectorIOS::BrowserPolicyConnectorIOS( |
| const HandlerListFactory& handler_list_factory) |
| : BrowserPolicyConnector(handler_list_factory) { |
| chrome_browser_cloud_management_controller_ = std::make_unique< |
| policy::ChromeBrowserCloudManagementController>( |
| std::make_unique<policy::ChromeBrowserCloudManagementControllerIOS>()); |
| } |
| |
| BrowserPolicyConnectorIOS::~BrowserPolicyConnectorIOS() {} |
| |
| ConfigurationPolicyProvider* BrowserPolicyConnectorIOS::GetPlatformProvider() { |
| ConfigurationPolicyProvider* provider = |
| BrowserPolicyConnectorBase::GetPolicyProviderForTesting(); |
| return provider ? provider : platform_provider_; |
| } |
| |
| void BrowserPolicyConnectorIOS::Init( |
| PrefService* local_state, |
| scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory) { |
| std::unique_ptr<policy::DeviceManagementService::Configuration> configuration( |
| new policy::DeviceManagementServiceConfigurationIOS( |
| GetDeviceManagementUrl(), GetRealtimeReportingUrl(), |
| GetEncryptedReportingUrl())); |
| std::unique_ptr<policy::DeviceManagementService> device_management_service( |
| new policy::DeviceManagementService(std::move(configuration))); |
| device_management_service->ScheduleInitialization( |
| kServiceInitializationStartupDelay); |
| |
| InitInternal(local_state, std::move(device_management_service)); |
| } |
| |
| bool BrowserPolicyConnectorIOS::IsEnterpriseManaged() const { |
| NOTREACHED() << "This method is only defined for Chrome OS"; |
| return false; |
| } |
| |
| bool BrowserPolicyConnectorIOS::HasMachineLevelPolicies() { |
| return ProviderHasPolicies(GetPlatformProvider()) || |
| ProviderHasPolicies(machine_level_user_cloud_policy_manager_); |
| } |
| |
| void BrowserPolicyConnectorIOS::Shutdown() { |
| // Reset the controller before calling base class so that |
| // shutdown occurs in correct sequence. |
| chrome_browser_cloud_management_controller_.reset(); |
| |
| BrowserPolicyConnector::Shutdown(); |
| } |
| |
| bool BrowserPolicyConnectorIOS::IsCommandLineSwitchSupported() const { |
| return true; |
| } |
| |
| std::vector<std::unique_ptr<policy::ConfigurationPolicyProvider>> |
| BrowserPolicyConnectorIOS::CreatePolicyProviders() { |
| auto providers = BrowserPolicyConnector::CreatePolicyProviders(); |
| std::unique_ptr<ConfigurationPolicyProvider> platform_provider = |
| CreatePlatformProvider(); |
| if (platform_provider) { |
| DCHECK(!platform_provider_) << "CreatePolicyProviders was called twice."; |
| platform_provider_ = platform_provider.get(); |
| // PlatformProvider should be before all other providers (highest priority). |
| providers.insert(providers.begin(), std::move(platform_provider)); |
| } |
| |
| std::unique_ptr<policy::MachineLevelUserCloudPolicyManager> |
| machine_level_user_cloud_policy_manager = |
| chrome_browser_cloud_management_controller_->CreatePolicyManager( |
| platform_provider_); |
| if (machine_level_user_cloud_policy_manager) { |
| machine_level_user_cloud_policy_manager_ = |
| machine_level_user_cloud_policy_manager.get(); |
| providers.push_back(std::move(machine_level_user_cloud_policy_manager)); |
| } |
| |
| return providers; |
| } |
| |
| std::unique_ptr<ConfigurationPolicyProvider> |
| BrowserPolicyConnectorIOS::CreatePlatformProvider() { |
| auto loader = std::make_unique<PolicyLoaderIOS>( |
| GetSchemaRegistry(), |
| base::ThreadPool::CreateSequencedTaskRunner( |
| {base::MayBlock(), base::TaskPriority::BEST_EFFORT})); |
| |
| return std::make_unique<AsyncPolicyProvider>(GetSchemaRegistry(), |
| std::move(loader)); |
| } |