1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef EXTENSIONS_COMMON_FILE_UTIL_H_
6 #define EXTENSIONS_COMMON_FILE_UTIL_H_
12 #include "base/files/file_path.h"
13 #include "base/memory/ref_counted.h"
14 #include "extensions/common/manifest.h"
15 #include "extensions/common/message_bundle.h"
17 class ExtensionIconSet
;
24 namespace extensions
{
27 struct InstallWarning
;
29 // Utilities for manipulating the on-disk storage of extensions.
32 extern const base::FilePath::CharType kTempDirectoryName
[];
34 // Copies |unpacked_source_dir| into the right location under |extensions_dir|.
35 // The destination directory is returned on success, or empty path is returned
37 base::FilePath
InstallExtension(const base::FilePath
& unpacked_source_dir
,
38 const std::string
& id
,
39 const std::string
& version
,
40 const base::FilePath
& extensions_dir
);
42 // Removes all versions of the extension with |id| from |extensions_dir|.
43 void UninstallExtension(const base::FilePath
& extensions_dir
,
44 const std::string
& id
);
46 // Loads and validates an extension from the specified directory. Returns NULL
47 // on failure, with a description of the error in |error|.
48 scoped_refptr
<Extension
> LoadExtension(const base::FilePath
& extension_root
,
49 Manifest::Location location
,
53 // The same as LoadExtension except use the provided |extension_id|.
54 scoped_refptr
<Extension
> LoadExtension(const base::FilePath
& extension_root
,
55 const std::string
& extension_id
,
56 Manifest::Location location
,
60 // Loads an extension manifest from the specified directory. Returns NULL
61 // on failure, with a description of the error in |error|.
62 base::DictionaryValue
* LoadManifest(const base::FilePath
& extension_root
,
65 // Convenience overload for specifying a manifest filename.
66 base::DictionaryValue
* LoadManifest(
67 const base::FilePath
& extension_root
,
68 const base::FilePath::CharType
* manifest_filename
,
71 // Returns true if the given extension object is valid and consistent.
72 // May also append a series of warning messages to |warnings|, but they
73 // should not prevent the extension from running.
75 // Otherwise, returns false, and a description of the error is
76 // returned in |error|.
77 bool ValidateExtension(const Extension
* extension
,
79 std::vector
<InstallWarning
>* warnings
);
81 // Returns a list of files that contain private keys inside |extension_dir|.
82 std::vector
<base::FilePath
> FindPrivateKeyFiles(
83 const base::FilePath
& extension_dir
);
85 // We need to reserve the namespace of entries that start with "_" for future
87 // If any files or directories are found using "_" prefix and are not on
88 // reserved list we return false, and set error message.
89 bool CheckForIllegalFilenames(const base::FilePath
& extension_path
,
92 // We need to reserve the names of special Windows filenames, such as
94 // If any files or directories are found to be using a reserved Windows
95 // filename, we return false, and set error message.
96 bool CheckForWindowsReservedFilenames(const base::FilePath
& extension_dir
,
99 // Returns a path to a temporary directory for unpacking an extension that will
100 // be installed into |extensions_dir|. Creates the directory if necessary.
101 // The directory will be on the same file system as |extensions_dir| so
102 // that the extension directory can be efficiently renamed into place. Returns
103 // an empty file path on failure.
104 base::FilePath
GetInstallTempDir(const base::FilePath
& extensions_dir
);
106 // Helper function to delete files. This is used to avoid ugly casts which
107 // would be necessary with PostMessage since base::Delete is overloaded.
108 // TODO(skerner): Make a version of Delete that is not overloaded in file_util.
109 void DeleteFile(const base::FilePath
& path
, bool recursive
);
111 // Get a relative file path from a chrome-extension:// URL.
112 base::FilePath
ExtensionURLToRelativeFilePath(const GURL
& url
);
114 // Get a full file path from a chrome-extension-resource:// URL, If the URL
115 // points a file outside of root, this function will return empty FilePath.
116 base::FilePath
ExtensionResourceURLToFilePath(const GURL
& url
,
117 const base::FilePath
& root
);
119 // Returns true if the icons in the icon set exist. Oherwise, populates
120 // |error| with the |error_message_id| for an invalid file.
121 bool ValidateExtensionIconSet(const ExtensionIconSet
& icon_set
,
122 const Extension
* extension
,
123 int error_message_id
,
126 // Loads extension message catalogs and returns message bundle.
127 // Returns NULL on error or if the extension is not localized.
128 MessageBundle
* LoadMessageBundle(const base::FilePath
& extension_path
,
129 const std::string
& default_locale
,
132 // Loads the extension message bundle substitution map. Contains at least
133 // the extension_id item.
134 MessageBundle::SubstitutionMap
* LoadMessageBundleSubstitutionMap(
135 const base::FilePath
& extension_path
,
136 const std::string
& extension_id
,
137 const std::string
& default_locale
);
139 // Loads the extension message bundle substitution map, including messages from
140 // Shared Modules that the given extension imports. Contains at least the
141 // extension_id item.
142 MessageBundle::SubstitutionMap
* LoadMessageBundleSubstitutionMapWithImports(
143 const std::string
& extension_id
,
144 const ExtensionSet
& extension_set
);
146 // Helper functions for getting paths for files used in content verification.
147 base::FilePath
GetVerifiedContentsPath(const base::FilePath
& extension_path
);
148 base::FilePath
GetComputedHashesPath(const base::FilePath
& extension_path
);
150 } // namespace file_util
151 } // namespace extensions
153 #endif // EXTENSIONS_COMMON_FILE_UTIL_H_