summaryrefslogtreecommitdiffstats
path: root/chrome/browser/extensions/extension.h
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/extensions/extension.h')
-rw-r--r--chrome/browser/extensions/extension.h64
1 files changed, 50 insertions, 14 deletions
diff --git a/chrome/browser/extensions/extension.h b/chrome/browser/extensions/extension.h
index 8a82547..e6a2ca8 100644
--- a/chrome/browser/extensions/extension.h
+++ b/chrome/browser/extensions/extension.h
@@ -11,12 +11,21 @@
#include "base/file_path.h"
#include "base/string16.h"
#include "base/values.h"
+#include "chrome/browser/extensions/user_script_master.h"
+#include "googleurl/src/gurl.h"
+
+// The URL schemes Chromium extensions and user scripts are served from. These
+// really should be in extension_protocols.h, but that causes link errors on
+// linux because extension_protocols.cc refers to undefined symbols.
+// TODO(aa): Move these back to extension_protocols.h when more of Linux and
+// Mac are up and running.
+extern const char kExtensionURLScheme[];
+extern const char kUserScriptURLScheme[];
// Represents a Chromium extension.
class Extension {
public:
- Extension(){};
- Extension(const FilePath& path) : path_(path) {};
+ Extension(const FilePath& path);
// The format for extension manifests that this code understands.
static const int kExpectedFormatVersion = 1;
@@ -25,26 +34,53 @@ class Extension {
static const char kManifestFilename[];
// Keys used in JSON representation of extensions.
+ static const wchar_t* kDescriptionKey;
+ static const wchar_t* kFilesKey;
static const wchar_t* kFormatVersionKey;
static const wchar_t* kIdKey;
+ static const wchar_t* kMatchesKey;
static const wchar_t* kNameKey;
- static const wchar_t* kDescriptionKey;
- static const wchar_t* kContentScriptsKey;
+ static const wchar_t* kUserScriptsKey;
static const wchar_t* kVersionKey;
// Error messages returned from InitFromValue().
+ static const char* kInvalidDescriptionError;
+ static const char* kInvalidFileCountError;
+ static const char* kInvalidFileError;
+ static const char* kInvalidFilesError;
static const char* kInvalidFormatVersionError;
- static const char* kInvalidManifestError;
static const char* kInvalidIdError;
+ static const char* kInvalidManifestError;
+ static const char* kInvalidMatchCountError;
+ static const char* kInvalidMatchError;
+ static const char* kInvalidMatchesError;
static const char* kInvalidNameError;
- static const char* kInvalidDescriptionError;
- static const char* kInvalidContentScriptsListError;
- static const char* kInvalidContentScriptError;
+ static const char* kInvalidUserScriptError;
+ static const char* kInvalidUserScriptsListError;
static const char* kInvalidVersionError;
+ // Creates an absolute url to a resource inside an extension. The
+ // |extension_url| argument should be the url() from an Extension object. The
+ // |relative_path| can be untrusted user input. The returned URL will either
+ // be invalid() or a child of |extension_url|.
+ // NOTE: Static so that it can be used from multiple threads.
+ static GURL GetResourceURL(const GURL& extension_url,
+ const std::string& relative_path);
+
+ // Creates an absolute path to a resource inside an extension. The
+ // |extension_path| argument should be the path() from an Extension object.
+ // The |relative_path| can be untrusted user input. The returned path will
+ // either be empty or a child of extension_path.
+ // NOTE: Static so that it can be used from multiple threads.
+ static FilePath GetResourcePath(const FilePath& extension_path,
+ const std::string& relative_path);
+
// The path to the folder the extension is stored in.
const FilePath& path() const { return path_; }
+ // The base URL for the extension.
+ const GURL& url() const { return extension_url_; }
+
// A human-readable ID for the extension. The convention is to use something
// like 'com.example.myextension', but this is not currently enforced. An
// extension's ID is used in things like directory structures and URLs, and
@@ -63,20 +99,20 @@ class Extension {
const std::string& description() const { return description_; }
// Paths to the content scripts that the extension contains.
- const std::vector<std::string>& content_scripts() const {
- return content_scripts_;
+ const UserScriptList& user_scripts() const {
+ return user_scripts_;
}
// Initialize the extension from a parsed manifest.
bool InitFromValue(const DictionaryValue& value, std::string* error);
- // Serialize the extension to a DictionaryValue.
- void CopyToValue(DictionaryValue* value);
-
private:
// The path to the directory the extension is stored in.
FilePath path_;
+ // The base extension url for the extension.
+ GURL extension_url_;
+
// The extension's ID.
std::string id_;
@@ -90,7 +126,7 @@ class Extension {
std::string description_;
// Paths to the content scripts the extension contains.
- std::vector<std::string> content_scripts_;
+ UserScriptList user_scripts_;
DISALLOW_COPY_AND_ASSIGN(Extension);
};