// Copyright 2013 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. #ifndef EXTENSIONS_COMMON_FILE_UTIL_H_ #define EXTENSIONS_COMMON_FILE_UTIL_H_ #include #include #include #include "base/files/file_path.h" #include "base/memory/ref_counted.h" #include "extensions/common/manifest.h" #include "extensions/common/message_bundle.h" class ExtensionIconSet; class GURL; namespace base { class FilePath; } namespace extensions { class Extension; class ExtensionSet; struct InstallWarning; // Utilities for manipulating the on-disk storage of extensions. namespace file_util { extern const base::FilePath::CharType kTempDirectoryName[]; // Sets the flag to enable safe installation (i.e. flush all installed files). void SetUseSafeInstallation(bool use_safe_installation); // Copies |unpacked_source_dir| into the right location under |extensions_dir|. // The destination directory is returned on success, or empty path is returned // on failure. base::FilePath InstallExtension(const base::FilePath& unpacked_source_dir, const std::string& id, const std::string& version, const base::FilePath& extensions_dir); // Removes all versions of the extension with |id| from |extensions_dir|. void UninstallExtension(const base::FilePath& extensions_dir, const std::string& id); // Loads and validates an extension from the specified directory. Returns NULL // on failure, with a description of the error in |error|. scoped_refptr LoadExtension(const base::FilePath& extension_root, Manifest::Location location, int flags, std::string* error); // The same as LoadExtension except use the provided |extension_id|. scoped_refptr LoadExtension(const base::FilePath& extension_root, const std::string& extension_id, Manifest::Location location, int flags, std::string* error); // Loads an extension manifest from the specified directory. Returns NULL // on failure, with a description of the error in |error|. scoped_ptr LoadManifest( const base::FilePath& extension_root, std::string* error); // Convenience overload for specifying a manifest filename. scoped_ptr LoadManifest( const base::FilePath& extension_root, const base::FilePath::CharType* manifest_filename, std::string* error); // Returns true if the given extension object is valid and consistent. // May also append a series of warning messages to |warnings|, but they // should not prevent the extension from running. // // Otherwise, returns false, and a description of the error is // returned in |error|. bool ValidateExtension(const Extension* extension, std::string* error, std::vector* warnings); // Returns a list of files that contain private keys inside |extension_dir|. std::vector FindPrivateKeyFiles( const base::FilePath& extension_dir); // We need to reserve the namespace of entries that start with "_" for future // use by Chrome. // If any files or directories are found using "_" prefix and are not on // reserved list we return false, and set error message. bool CheckForIllegalFilenames(const base::FilePath& extension_path, std::string* error); // We need to reserve the names of special Windows filenames, such as // "com2.zip." // If any files or directories are found to be using a reserved Windows // filename, we return false, and set error message. bool CheckForWindowsReservedFilenames(const base::FilePath& extension_dir, std::string* error); // Returns a path to a temporary directory for unpacking an extension that will // be installed into |extensions_dir|. Creates the directory if necessary. // The directory will be on the same file system as |extensions_dir| so // that the extension directory can be efficiently renamed into place. Returns // an empty file path on failure. base::FilePath GetInstallTempDir(const base::FilePath& extensions_dir); // Helper function to delete files. This is used to avoid ugly casts which // would be necessary with PostMessage since base::Delete is overloaded. // TODO(skerner): Make a version of Delete that is not overloaded in file_util. void DeleteFile(const base::FilePath& path, bool recursive); // Get a relative file path from a chrome-extension:// URL. base::FilePath ExtensionURLToRelativeFilePath(const GURL& url); // Get a full file path from a chrome-extension-resource:// URL, If the URL // points a file outside of root, this function will return empty FilePath. base::FilePath ExtensionResourceURLToFilePath(const GURL& url, const base::FilePath& root); // Returns true if the icons in the icon set exist. Oherwise, populates // |error| with the |error_message_id| for an invalid file. bool ValidateExtensionIconSet(const ExtensionIconSet& icon_set, const Extension* extension, int error_message_id, std::string* error); // Loads extension message catalogs and returns message bundle. // Returns NULL on error or if the extension is not localized. MessageBundle* LoadMessageBundle(const base::FilePath& extension_path, const std::string& default_locale, std::string* error); // Loads the extension message bundle substitution map. Contains at least // the extension_id item. MessageBundle::SubstitutionMap* LoadMessageBundleSubstitutionMap( const base::FilePath& extension_path, const std::string& extension_id, const std::string& default_locale); // Loads the extension message bundle substitution map, including messages from // Shared Modules that the given extension imports. Contains at least the // extension_id item. MessageBundle::SubstitutionMap* LoadMessageBundleSubstitutionMapWithImports( const std::string& extension_id, const ExtensionSet& extension_set); // Helper functions for getting paths for files used in content verification. base::FilePath GetVerifiedContentsPath(const base::FilePath& extension_path); base::FilePath GetComputedHashesPath(const base::FilePath& extension_path); } // namespace file_util } // namespace extensions #endif // EXTENSIONS_COMMON_FILE_UTIL_H_