// Copyright (c) 2010 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/config_dir_policy_provider.h"
#include <set>
#include "base/file_util.h"
#include "base/values.h"
#include "content/common/json_value_serializer.h"
namespace policy {
ConfigDirPolicyProviderDelegate::ConfigDirPolicyProviderDelegate(
const FilePath& config_dir)
: FileBasedPolicyProvider::ProviderDelegate(config_dir) {
}
DictionaryValue* ConfigDirPolicyProviderDelegate::Load() {
// Enumerate the files and sort them lexicographically.
std::set<FilePath> files;
file_util::FileEnumerator file_enumerator(config_file_path(), false,
file_util::FileEnumerator::FILES);
for (FilePath config_file_path = file_enumerator.Next();
!config_file_path.empty(); config_file_path = file_enumerator.Next())
files.insert(config_file_path);
// Start with an empty dictionary and merge the files' contents.
DictionaryValue* policy = new DictionaryValue;
for (std::set<FilePath>::iterator config_file_iter = files.begin();
config_file_iter != files.end(); ++config_file_iter) {
JSONFileValueSerializer deserializer(*config_file_iter);
int error_code = 0;
std::string error_msg;
scoped_ptr<Value> value(deserializer.Deserialize(&error_code, &error_msg));
if (!value.get()) {
LOG(WARNING) << "Failed to read configuration file "
<< config_file_iter->value() << ": " << error_msg;
continue;
}
if (!value->IsType(Value::TYPE_DICTIONARY)) {
LOG(WARNING) << "Expected JSON dictionary in configuration file "
<< config_file_iter->value();
continue;
}
policy->MergeDictionary(static_cast<DictionaryValue*>(value.get()));
}
return policy;
}
base::Time ConfigDirPolicyProviderDelegate::GetLastModification() {
base::Time last_modification = base::Time();
base::PlatformFileInfo file_info;
// If the path does not exist or points to a directory, it's safe to load.
if (!file_util::GetFileInfo(config_file_path(), &file_info) ||
!file_info.is_directory) {
return last_modification;
}
// Enumerate the files and find the most recent modification timestamp.
file_util::FileEnumerator file_enumerator(config_file_path(),
false,
file_util::FileEnumerator::FILES);
for (FilePath config_file = file_enumerator.Next();
!config_file.empty();
config_file = file_enumerator.Next()) {
if (file_util::GetFileInfo(config_file, &file_info) &&
!file_info.is_directory) {
last_modification = std::max(last_modification, file_info.last_modified);
}
}
return last_modification;
}
ConfigDirPolicyProvider::ConfigDirPolicyProvider(
const ConfigurationPolicyProvider::PolicyDefinitionList* policy_list,
const FilePath& config_dir)
: FileBasedPolicyProvider(
policy_list,
new ConfigDirPolicyProviderDelegate(config_dir)) {
}
} // namespace policy