// 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