// Copyright 2014 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 "extensions/common/manifest_handler_helpers.h"
#include "base/logging.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/utf_string_conversions.h"
#include "base/values.h"
#include "extensions/common/error_utils.h"
#include "extensions/common/extension.h"
#include "extensions/common/extension_icon_set.h"
#include "extensions/common/manifest_constants.h"
namespace extensions {
namespace errors = manifest_errors;
namespace manifest_handler_helpers {
bool NormalizeAndValidatePath(std::string* path) {
size_t first_non_slash = path->find_first_not_of('/');
if (first_non_slash == std::string::npos) {
*path = "";
return false;
}
*path = path->substr(first_non_slash);
return true;
}
bool LoadIconsFromDictionary(const base::DictionaryValue* icons_value,
const int* icon_sizes,
size_t num_icon_sizes,
ExtensionIconSet* icons,
base::string16* error) {
DCHECK(icons);
for (size_t i = 0; i < num_icon_sizes; ++i) {
std::string key = base::IntToString(icon_sizes[i]);
if (icons_value->HasKey(key)) {
std::string icon_path;
if (!icons_value->GetString(key, &icon_path)) {
*error = ErrorUtils::FormatErrorMessageUTF16(
errors::kInvalidIconPath, key);
return false;
}
if (!NormalizeAndValidatePath(&icon_path)) {
*error = ErrorUtils::FormatErrorMessageUTF16(
errors::kInvalidIconPath, key);
return false;
}
icons->Add(icon_sizes[i], icon_path);
}
}
return true;
}
} // namespace manifest_handler_helpers
} // namespace extensions