// Copyright (c) 2011 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 "chrome/browser/policy/browser_policy_connector.h" #include "base/command_line.h" #include "base/path_service.h" #include "chrome/browser/browser_process.h" #include "chrome/browser/policy/cloud_policy_subsystem.h" #include "chrome/browser/policy/configuration_policy_pref_store.h" #include "chrome/browser/policy/configuration_policy_provider.h" #include "chrome/browser/policy/dummy_configuration_policy_provider.h" #include "chrome/common/chrome_paths.h" #include "chrome/common/chrome_switches.h" #if defined(OS_WIN) #include "chrome/browser/policy/configuration_policy_provider_win.h" #elif defined(OS_MACOSX) #include "chrome/browser/policy/configuration_policy_provider_mac.h" #elif defined(OS_POSIX) #include "chrome/browser/policy/config_dir_policy_provider.h" #endif #if defined(OS_CHROMEOS) #include "chrome/browser/chromeos/cros/cros_library.h" #include "chrome/browser/policy/device_policy_cache.h" #include "chrome/browser/policy/device_policy_identity_strategy.h" #include "chrome/browser/policy/enterprise_install_attributes.h" #endif namespace policy { BrowserPolicyConnector::BrowserPolicyConnector() : ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) { managed_platform_provider_.reset(CreateManagedPlatformProvider()); recommended_platform_provider_.reset(CreateRecommendedPlatformProvider()); #if defined(OS_CHROMEOS) CommandLine* command_line = CommandLine::ForCurrentProcess(); if (command_line->HasSwitch(switches::kEnableDevicePolicy)) { identity_strategy_.reset(new DevicePolicyIdentityStrategy()); install_attributes_.reset(new EnterpriseInstallAttributes( chromeos::CrosLibrary::Get()->GetCryptohomeLibrary())); cloud_policy_subsystem_.reset(new CloudPolicySubsystem( identity_strategy_.get(), new DevicePolicyCache(identity_strategy_.get(), install_attributes_.get()))); // Initialize the subsystem once the message loops are spinning. MessageLoop::current()->PostTask( FROM_HERE, method_factory_.NewRunnableMethod(&BrowserPolicyConnector::Initialize)); } #endif } BrowserPolicyConnector::BrowserPolicyConnector( ConfigurationPolicyProvider* managed_platform_provider, ConfigurationPolicyProvider* recommended_platform_provider) : managed_platform_provider_(managed_platform_provider), recommended_platform_provider_(recommended_platform_provider), ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) {} BrowserPolicyConnector::~BrowserPolicyConnector() { if (cloud_policy_subsystem_.get()) cloud_policy_subsystem_->Shutdown(); cloud_policy_subsystem_.reset(); #if defined(OS_CHROMEOS) identity_strategy_.reset(); #endif } ConfigurationPolicyProvider* BrowserPolicyConnector::GetManagedPlatformProvider() const { return managed_platform_provider_.get(); } ConfigurationPolicyProvider* BrowserPolicyConnector::GetManagedCloudProvider() const { if (cloud_policy_subsystem_.get()) return cloud_policy_subsystem_->GetManagedPolicyProvider(); return NULL; } ConfigurationPolicyProvider* BrowserPolicyConnector::GetRecommendedPlatformProvider() const { return recommended_platform_provider_.get(); } ConfigurationPolicyProvider* BrowserPolicyConnector::GetRecommendedCloudProvider() const { if (cloud_policy_subsystem_.get()) return cloud_policy_subsystem_->GetRecommendedPolicyProvider(); return NULL; } ConfigurationPolicyProvider* BrowserPolicyConnector::CreateManagedPlatformProvider() { const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list = ConfigurationPolicyPrefStore::GetChromePolicyDefinitionList(); #if defined(OS_WIN) return new ConfigurationPolicyProviderWin(policy_list); #elif defined(OS_MACOSX) return new ConfigurationPolicyProviderMac(policy_list); #elif defined(OS_POSIX) FilePath config_dir_path; if (PathService::Get(chrome::DIR_POLICY_FILES, &config_dir_path)) { return new ConfigDirPolicyProvider( policy_list, config_dir_path.Append(FILE_PATH_LITERAL("managed"))); } else { return new DummyConfigurationPolicyProvider(policy_list); } #else return new DummyConfigurationPolicyProvider(policy_list); #endif } ConfigurationPolicyProvider* BrowserPolicyConnector::CreateRecommendedPlatformProvider() { const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list = ConfigurationPolicyPrefStore::GetChromePolicyDefinitionList(); #if defined(OS_POSIX) && !defined(OS_MACOSX) FilePath config_dir_path; if (PathService::Get(chrome::DIR_POLICY_FILES, &config_dir_path)) { return new ConfigDirPolicyProvider( policy_list, config_dir_path.Append(FILE_PATH_LITERAL("recommended"))); } else { return new DummyConfigurationPolicyProvider(policy_list); } #else return new DummyConfigurationPolicyProvider(policy_list); #endif } void BrowserPolicyConnector::SetCredentials(const std::string& owner_email, const std::string& gaia_token) { #if defined(OS_CHROMEOS) if (identity_strategy_.get()) identity_strategy_->SetAuthCredentials(owner_email, gaia_token); #endif } bool BrowserPolicyConnector::IsEnterpriseManaged() { #if defined(OS_CHROMEOS) return install_attributes_.get() && install_attributes_->IsEnterpriseDevice(); #else return false; #endif } EnterpriseInstallAttributes::LockResult BrowserPolicyConnector::LockDevice(const std::string& user) { #if defined(OS_CHROMEOS) if (install_attributes_.get()) return install_attributes_->LockDevice(user); #endif return EnterpriseInstallAttributes::LOCK_BACKEND_ERROR; } std::string BrowserPolicyConnector::GetEnterpriseDomain() { #if defined(OS_CHROMEOS) if (install_attributes_.get()) return install_attributes_->GetDomain(); #endif return std::string(); } void BrowserPolicyConnector::StopAutoRetry() { if (cloud_policy_subsystem_.get()) cloud_policy_subsystem_->StopAutoRetry(); } void BrowserPolicyConnector::FetchPolicy() { #if defined(OS_CHROMEOS) if (identity_strategy_.get()) return identity_strategy_->FetchPolicy(); #endif } void BrowserPolicyConnector::Initialize() { // TODO(jkummerow, mnissler): Move this out of the browser startup path. if (cloud_policy_subsystem_.get()) { cloud_policy_subsystem_->Initialize( g_browser_process->local_state(), g_browser_process->system_request_context()); } } } // namespace