mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-07 11:56:51 +00:00
1c3e10afc5
Differential Revision: https://phabricator.services.mozilla.com/D23771 --HG-- extra : moz-landing-system : lando
230 lines
6.7 KiB
Plaintext
230 lines
6.7 KiB
Plaintext
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
interface URI;
|
|
interface WindowProxy;
|
|
|
|
callback WebExtensionLocalizeCallback = DOMString (DOMString unlocalizedText);
|
|
|
|
/**
|
|
* Defines the platform-level policies for a WebExtension, including its
|
|
* permissions and the characteristics of its moz-extension: URLs.
|
|
*/
|
|
[Constructor(WebExtensionInit options), ChromeOnly, Exposed=Window]
|
|
interface WebExtensionPolicy {
|
|
/**
|
|
* The add-on's internal ID, as specified in its manifest.json file or its
|
|
* XPI signature.
|
|
*/
|
|
[Constant, StoreInSlot]
|
|
readonly attribute DOMString id;
|
|
|
|
/**
|
|
* The hostname part of the extension's moz-extension: URLs. This value is
|
|
* generated randomly at install time.
|
|
*/
|
|
[Constant, StoreInSlot]
|
|
readonly attribute ByteString mozExtensionHostname;
|
|
|
|
/**
|
|
* The file: or jar: URL to use for the base of the extension's
|
|
* moz-extension: URL root.
|
|
*/
|
|
[Constant]
|
|
readonly attribute ByteString baseURL;
|
|
|
|
/**
|
|
* The extension's user-visible name.
|
|
*/
|
|
[Constant]
|
|
readonly attribute DOMString name;
|
|
|
|
/**
|
|
* The content security policy string to apply to all pages loaded from the
|
|
* extension's moz-extension: protocol.
|
|
*/
|
|
[Constant]
|
|
readonly attribute DOMString contentSecurityPolicy;
|
|
|
|
|
|
/**
|
|
* The list of currently-active permissions for the extension, as specified
|
|
* in its manifest.json file. May be updated to reflect changes in the
|
|
* extension's optional permissions.
|
|
*/
|
|
[Cached, Frozen, Pure]
|
|
attribute sequence<DOMString> permissions;
|
|
|
|
/**
|
|
* Match patterns for the set of web origins to which the extension is
|
|
* currently allowed access. May be updated to reflect changes in the
|
|
* extension's optional permissions.
|
|
*/
|
|
[Pure]
|
|
attribute MatchPatternSet allowedOrigins;
|
|
|
|
/**
|
|
* The set of content scripts active for this extension.
|
|
*/
|
|
[Cached, Frozen, Pure]
|
|
readonly attribute sequence<WebExtensionContentScript> contentScripts;
|
|
|
|
/**
|
|
* True if the extension is currently active, false otherwise. When active,
|
|
* the extension's moz-extension: protocol will point to the given baseURI,
|
|
* and the set of policies for this object will be active for its ID.
|
|
*
|
|
* Only one extension policy with a given ID or hostname may be active at a
|
|
* time. Attempting to activate a policy while a conflicting policy is
|
|
* active will raise an error.
|
|
*/
|
|
[Affects=Everything, SetterThrows]
|
|
attribute boolean active;
|
|
|
|
/**
|
|
* True if both e10s and webextensions.remote are enabled. This must be
|
|
* used instead of checking the remote pref directly since remote extensions
|
|
* require both to be enabled.
|
|
*/
|
|
static readonly attribute boolean useRemoteWebExtensions;
|
|
|
|
/**
|
|
* True if the calling process is an extension process.
|
|
*/
|
|
static readonly attribute boolean isExtensionProcess;
|
|
|
|
/**
|
|
* Set based on the manifest.incognito value:
|
|
* If "spanning" or "split" will be true.
|
|
* If "not_allowed" will be false.
|
|
*/
|
|
[Pure]
|
|
readonly attribute boolean privateBrowsingAllowed;
|
|
|
|
/**
|
|
* Returns true if the extension can access a window. Access is
|
|
* determined by matching the windows private browsing context
|
|
* with privateBrowsingMode. This does not, and is not meant to
|
|
* handle specific differences between spanning and split mode.
|
|
*/
|
|
[Affects=Nothing]
|
|
boolean canAccessWindow(WindowProxy window);
|
|
|
|
/**
|
|
* Returns true if the extension has cross-origin access to the given URI.
|
|
*/
|
|
boolean canAccessURI(URI uri, optional boolean explicit = false);
|
|
|
|
/**
|
|
* Returns true if the extension currently has the given permission.
|
|
*/
|
|
boolean hasPermission(DOMString permission);
|
|
|
|
/**
|
|
* Returns true if the given path relative to the extension's moz-extension:
|
|
* URL root may be accessed by web content.
|
|
*/
|
|
boolean isPathWebAccessible(DOMString pathname);
|
|
|
|
/**
|
|
* Replaces localization placeholders in the given string with localized
|
|
* text from the extension's currently active locale.
|
|
*/
|
|
DOMString localize(DOMString unlocalizedText);
|
|
|
|
/**
|
|
* Returns the moz-extension: URL for the given path.
|
|
*/
|
|
[Throws]
|
|
DOMString getURL(optional DOMString path = "");
|
|
|
|
/**
|
|
* Register a new content script programmatically.
|
|
*/
|
|
[Throws]
|
|
void registerContentScript(WebExtensionContentScript script);
|
|
|
|
/**
|
|
* Unregister a content script.
|
|
*/
|
|
[Throws]
|
|
void unregisterContentScript(WebExtensionContentScript script);
|
|
|
|
/**
|
|
* Injects the extension's content script into all existing matching windows.
|
|
*/
|
|
[Throws]
|
|
void injectContentScripts();
|
|
|
|
/**
|
|
* Returns the list of currently active extension policies.
|
|
*/
|
|
static sequence<WebExtensionPolicy> getActiveExtensions();
|
|
|
|
/**
|
|
* Returns the currently-active policy for the extension with the given ID,
|
|
* or null if no policy is active for that ID.
|
|
*/
|
|
static WebExtensionPolicy? getByID(DOMString id);
|
|
|
|
/**
|
|
* Returns the currently-active policy for the extension with the given
|
|
* moz-extension: hostname, or null if no policy is active for that
|
|
* hostname.
|
|
*/
|
|
static WebExtensionPolicy? getByHostname(ByteString hostname);
|
|
|
|
/**
|
|
* Returns the currently-active policy for the extension extension URI, or
|
|
* null if the URI is not an extension URI, or no policy is currently active
|
|
* for it.
|
|
*/
|
|
static WebExtensionPolicy? getByURI(URI uri);
|
|
|
|
/**
|
|
* Returns true if the URI is restricted for any extension.
|
|
*/
|
|
static boolean isRestrictedURI(URI uri);
|
|
|
|
/**
|
|
* When present, the extension is not yet ready to load URLs. In that case,
|
|
* this policy object is a stub, and the attribute contains a promise which
|
|
* resolves to a new, non-stub policy object when the extension is ready.
|
|
*
|
|
* This may be used to delay operations, such as loading extension pages,
|
|
* which depend on extensions being fully initialized.
|
|
*
|
|
* Note: This will always be either a Promise<WebExtensionPolicy> or null,
|
|
* but the WebIDL grammar does not allow us to specify a nullable Promise
|
|
* type.
|
|
*/
|
|
readonly attribute object? readyPromise;
|
|
};
|
|
|
|
dictionary WebExtensionInit {
|
|
required DOMString id;
|
|
|
|
required ByteString mozExtensionHostname;
|
|
|
|
required DOMString baseURL;
|
|
|
|
DOMString name = "";
|
|
|
|
required WebExtensionLocalizeCallback localizeCallback;
|
|
|
|
required MatchPatternSetOrStringSequence allowedOrigins;
|
|
|
|
sequence<DOMString> permissions = [];
|
|
|
|
sequence<MatchGlobOrString> webAccessibleResources = [];
|
|
|
|
sequence<WebExtensionContentScriptInit> contentScripts = [];
|
|
|
|
DOMString? contentSecurityPolicy = null;
|
|
|
|
sequence<DOMString>? backgroundScripts = null;
|
|
|
|
Promise<WebExtensionPolicy> readyPromise;
|
|
};
|