2023-08-28 14:39:28 +00:00
|
|
|
// Copyright 2020 The Chromium Authors
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
// Use the <code>chrome.scripting</code> API to execute script in different
|
|
|
|
// contexts.
|
|
|
|
namespace scripting {
|
|
|
|
callback InjectedFunction = void();
|
|
|
|
|
|
|
|
// The origin for a style change.
|
|
|
|
// See <a href="https://developer.mozilla.org/en-US/docs/Glossary/Style_origin">style origins</a>
|
|
|
|
// for more info.
|
|
|
|
enum StyleOrigin {
|
|
|
|
AUTHOR,
|
|
|
|
USER
|
|
|
|
};
|
|
|
|
|
|
|
|
// The JavaScript world for a script to execute within.
|
|
|
|
enum ExecutionWorld {
|
|
|
|
// Specifies the isolated world, which is the execution environment unique
|
|
|
|
// to this extension.
|
|
|
|
ISOLATED,
|
|
|
|
// Specifies the main world of the DOM, which is the execution environment
|
|
|
|
// shared with the host page's JavaScript.
|
|
|
|
MAIN
|
|
|
|
};
|
|
|
|
|
|
|
|
dictionary InjectionTarget {
|
|
|
|
// The ID of the tab into which to inject.
|
|
|
|
long tabId;
|
|
|
|
|
|
|
|
// The <a href="https://developer.chrome.com/extensions/webNavigation#frame_ids">IDs</a>
|
|
|
|
// of specific frames to inject into.
|
|
|
|
long[]? frameIds;
|
|
|
|
|
|
|
|
// The <a href="https://developer.chrome.com/extensions/webNavigation#document_ids">IDs</a>
|
|
|
|
// of specific documentIds to inject into. This must not be set if
|
|
|
|
// <code>frameIds</code> is set.
|
|
|
|
DOMString[]? documentIds;
|
|
|
|
|
|
|
|
// Whether the script should inject into all frames within the tab. Defaults
|
|
|
|
// to false.
|
|
|
|
// This must not be true if <code>frameIds</code> is specified.
|
|
|
|
boolean? allFrames;
|
|
|
|
};
|
|
|
|
|
|
|
|
dictionary ScriptInjection {
|
|
|
|
// A JavaScript function to inject. This function will be serialized, and
|
|
|
|
// then deserialized for injection. This means that any bound parameters
|
|
|
|
// and execution context will be lost.
|
2024-08-11 19:31:37 +00:00
|
|
|
// Exactly one of <code>files</code> or <code>func</code> must be
|
2023-08-28 14:39:28 +00:00
|
|
|
// specified.
|
|
|
|
[serializableFunction]InjectedFunction? func;
|
|
|
|
|
2024-08-11 19:31:37 +00:00
|
|
|
// The arguments to pass to the provided function. This is only valid if
|
2023-08-28 14:39:28 +00:00
|
|
|
// the <code>func</code> parameter is specified. These arguments must be
|
|
|
|
// JSON-serializable.
|
|
|
|
any[]? args;
|
|
|
|
|
|
|
|
// We used to call the injected function `function`, but this is
|
|
|
|
// incompatible with JavaScript's object declaration shorthand (see
|
|
|
|
// https://crbug.com/1166438). We leave this silently in for backwards
|
|
|
|
// compatibility.
|
|
|
|
// TODO(devlin): Remove this in M95.
|
|
|
|
[nodoc, serializableFunction]InjectedFunction? function;
|
|
|
|
|
|
|
|
// The path of the JS or CSS files to inject, relative to the extension's
|
|
|
|
// root directory.
|
2024-08-11 19:31:37 +00:00
|
|
|
// Exactly one of <code>files</code> or <code>func</code> must be
|
2023-08-28 14:39:28 +00:00
|
|
|
// specified.
|
|
|
|
DOMString[]? files;
|
|
|
|
|
|
|
|
// Details specifying the target into which to inject the script.
|
|
|
|
InjectionTarget target;
|
|
|
|
|
|
|
|
// The JavaScript "world" to run the script in. Defaults to
|
|
|
|
// <code>ISOLATED</code>.
|
|
|
|
ExecutionWorld? world;
|
|
|
|
|
|
|
|
// Whether the injection should be triggered in the target as soon as
|
|
|
|
// possible. Note that this is not a guarantee that injection will occur
|
|
|
|
// prior to page load, as the page may have already loaded by the time the
|
|
|
|
// script reaches the target.
|
|
|
|
boolean? injectImmediately;
|
|
|
|
};
|
|
|
|
|
|
|
|
dictionary CSSInjection {
|
|
|
|
// Details specifying the target into which to insert the CSS.
|
|
|
|
InjectionTarget target;
|
|
|
|
|
|
|
|
// A string containing the CSS to inject.
|
|
|
|
// Exactly one of <code>files</code> and <code>css</code> must be
|
|
|
|
// specified.
|
|
|
|
DOMString? css;
|
|
|
|
|
|
|
|
// The path of the CSS files to inject, relative to the extension's root
|
|
|
|
// directory.
|
|
|
|
// Exactly one of <code>files</code> and <code>css</code> must be
|
|
|
|
// specified.
|
|
|
|
DOMString[]? files;
|
|
|
|
|
|
|
|
// The style origin for the injection. Defaults to <code>'AUTHOR'</code>.
|
|
|
|
StyleOrigin? origin;
|
|
|
|
};
|
|
|
|
|
|
|
|
dictionary InjectionResult {
|
|
|
|
// The result of the script execution.
|
|
|
|
any? result;
|
|
|
|
|
|
|
|
// The frame associated with the injection.
|
|
|
|
long frameId;
|
|
|
|
|
|
|
|
// The document associated with the injection.
|
|
|
|
DOMString documentId;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Describes a content script to be injected into a web page registered
|
|
|
|
// through this API.
|
|
|
|
dictionary RegisteredContentScript {
|
|
|
|
// The id of the content script, specified in the API call. Must not start
|
|
|
|
// with a '_' as it's reserved as a prefix for generated script IDs.
|
|
|
|
DOMString id;
|
|
|
|
// Specifies which pages this content script will be injected into. See
|
2024-08-11 19:31:37 +00:00
|
|
|
// <a href="develop/concepts/match-patterns">Match Patterns</a> for more
|
|
|
|
// details on the syntax of these strings. Must be specified for
|
2023-08-28 14:39:28 +00:00
|
|
|
// $(ref:registerContentScripts).
|
|
|
|
DOMString[]? matches;
|
|
|
|
// Excludes pages that this content script would otherwise be injected into.
|
2024-08-11 19:31:37 +00:00
|
|
|
// See <a href="develop/concepts/match-patterns">Match Patterns</a> for
|
|
|
|
// more details on the syntax of these strings.
|
2023-08-28 14:39:28 +00:00
|
|
|
DOMString[]? excludeMatches;
|
|
|
|
// The list of CSS files to be injected into matching pages. These are
|
|
|
|
// injected in the order they appear in this array, before any DOM is
|
|
|
|
// constructed or displayed for the page.
|
|
|
|
DOMString[]? css;
|
|
|
|
// The list of JavaScript files to be injected into matching pages. These
|
|
|
|
// are injected in the order they appear in this array.
|
|
|
|
DOMString[]? js;
|
|
|
|
// If specified true, it will inject into all frames, even if the frame is
|
|
|
|
// not the top-most frame in the tab. Each frame is checked independently
|
|
|
|
// for URL requirements; it will not inject into child frames if the URL
|
|
|
|
// requirements are not met. Defaults to false, meaning that only the top
|
|
|
|
// frame is matched.
|
|
|
|
boolean? allFrames;
|
2024-08-11 19:31:37 +00:00
|
|
|
// Indicates whether the script can be injected into frames where the URL
|
|
|
|
// contains an unsupported scheme; specifically: about:, data:, blob:, or
|
|
|
|
// filesystem:. In these cases, the URL's origin is checked to determine if
|
|
|
|
// the script should be injected. If the origin is `null` (as is the case
|
|
|
|
// for data: URLs) then the used origin is either the frame that created
|
|
|
|
// the current frame or the frame that initiated the navigation to this
|
|
|
|
// frame. Note that this may not be the parent frame.
|
2023-08-28 14:39:28 +00:00
|
|
|
boolean? matchOriginAsFallback;
|
|
|
|
// Specifies when JavaScript files are injected into the web page. The
|
|
|
|
// preferred and default value is <code>document_idle</code>.
|
|
|
|
extensionTypes.RunAt? runAt;
|
|
|
|
// Specifies if this content script will persist into future sessions. The
|
|
|
|
// default is true.
|
|
|
|
boolean? persistAcrossSessions;
|
|
|
|
// The JavaScript "world" to run the script in. Defaults to
|
|
|
|
// <code>ISOLATED</code>.
|
|
|
|
ExecutionWorld? world;
|
|
|
|
};
|
|
|
|
|
|
|
|
// An object used to filter content scripts for
|
|
|
|
// ${ref:getRegisteredContentScripts}.
|
|
|
|
dictionary ContentScriptFilter {
|
|
|
|
// If specified, $(ref:getRegisteredContentScripts) will only return scripts
|
|
|
|
// with an id specified in this list.
|
|
|
|
DOMString[]? ids;
|
|
|
|
};
|
|
|
|
|
|
|
|
callback ScriptInjectionCallback = void(InjectionResult[] results);
|
|
|
|
|
|
|
|
callback CSSInjectionCallback = void();
|
|
|
|
|
|
|
|
callback RegisterContentScriptsCallback = void();
|
|
|
|
|
|
|
|
callback GetRegisteredContentScriptsCallback = void(
|
|
|
|
RegisteredContentScript[] scripts);
|
|
|
|
|
|
|
|
callback UnregisterContentScriptsCallback = void();
|
|
|
|
|
|
|
|
callback UpdateContentScriptsCallback = void();
|
|
|
|
|
|
|
|
interface Properties {
|
|
|
|
// An object available for content scripts running in isolated worlds to use
|
|
|
|
// and modify as a JS object. One instance exists per frame and is shared
|
|
|
|
// between all content scripts for a given extension. This object is
|
|
|
|
// initialized when the frame is created, before document_start.
|
2024-08-11 19:31:37 +00:00
|
|
|
// TODO(crbug.com/40119604): Enable this once implementation is complete.
|
2023-08-28 14:39:28 +00:00
|
|
|
[nodoc, nocompile] static long globalParams();
|
|
|
|
};
|
|
|
|
|
|
|
|
interface Functions {
|
2024-08-11 19:31:37 +00:00
|
|
|
// Injects a script into a target context. By default, the script will be run
|
|
|
|
// at <code>document_idle</code>, or immediately if the page has already
|
|
|
|
// loaded. If the <code>injectImmediately</code> property is set, the script
|
|
|
|
// will inject without waiting, even if the page has not finished loading. If
|
|
|
|
// the script evaluates to a promise, the browser will wait for the promise to
|
|
|
|
// settle and return the resulting value.
|
2023-08-28 14:39:28 +00:00
|
|
|
// |injection|: The details of the script which to inject.
|
|
|
|
// |callback|: Invoked upon completion of the injection. The resulting
|
|
|
|
// array contains the result of execution for each frame where the
|
|
|
|
// injection succeeded.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void executeScript(
|
2023-08-28 14:39:28 +00:00
|
|
|
ScriptInjection injection,
|
|
|
|
optional ScriptInjectionCallback callback);
|
|
|
|
|
|
|
|
// Inserts a CSS stylesheet into a target context.
|
|
|
|
// If multiple frames are specified, unsuccessful injections are ignored.
|
|
|
|
// |injection|: The details of the styles to insert.
|
|
|
|
// |callback|: Invoked upon completion of the insertion.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void insertCSS(
|
2023-08-28 14:39:28 +00:00
|
|
|
CSSInjection injection,
|
|
|
|
optional CSSInjectionCallback callback);
|
|
|
|
|
|
|
|
// Removes a CSS stylesheet that was previously inserted by this extension
|
|
|
|
// from a target context.
|
|
|
|
// |injection|: The details of the styles to remove. Note that the
|
|
|
|
// <code>css</code>, <code>files</code>, and <code>origin</code> properties
|
|
|
|
// must exactly match the stylesheet inserted through $(ref:insertCSS).
|
|
|
|
// Attempting to remove a non-existent stylesheet is a no-op.
|
|
|
|
// |callback|: A callback to be invoked upon the completion of the removal.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void removeCSS(
|
2023-08-28 14:39:28 +00:00
|
|
|
CSSInjection injection,
|
|
|
|
optional CSSInjectionCallback callback);
|
|
|
|
|
|
|
|
// Registers one or more content scripts for this extension.
|
|
|
|
// |scripts|: Contains a list of scripts to be registered. If there are
|
|
|
|
// errors during script parsing/file validation, or if the IDs specified
|
|
|
|
// already exist, then no scripts are registered.
|
|
|
|
// |callback|: A callback to be invoked once scripts have been fully
|
|
|
|
// registered or if an error has occurred.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void registerContentScripts(
|
2023-08-28 14:39:28 +00:00
|
|
|
RegisteredContentScript[] scripts,
|
|
|
|
optional RegisterContentScriptsCallback callback);
|
|
|
|
|
|
|
|
// Returns all dynamically registered content scripts for this extension
|
|
|
|
// that match the given filter.
|
|
|
|
// |filter|: An object to filter the extension's dynamically registered
|
|
|
|
// scripts.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void getRegisteredContentScripts(
|
2023-08-28 14:39:28 +00:00
|
|
|
optional ContentScriptFilter filter,
|
|
|
|
GetRegisteredContentScriptsCallback callback);
|
|
|
|
|
|
|
|
// Unregisters content scripts for this extension.
|
|
|
|
// |filter|: If specified, only unregisters dynamic content scripts which
|
|
|
|
// match the filter. Otherwise, all of the extension's dynamic content
|
|
|
|
// scripts are unregistered.
|
|
|
|
// |callback|: A callback to be invoked once scripts have been unregistered
|
|
|
|
// or if an error has occurred.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void unregisterContentScripts(
|
2023-08-28 14:39:28 +00:00
|
|
|
optional ContentScriptFilter filter,
|
|
|
|
optional UnregisterContentScriptsCallback callback);
|
|
|
|
|
|
|
|
// Updates one or more content scripts for this extension.
|
|
|
|
// |scripts|: Contains a list of scripts to be updated. A property is only
|
|
|
|
// updated for the existing script if it is specified in this object. If
|
|
|
|
// there are errors during script parsing/file validation, or if the IDs
|
|
|
|
// specified do not correspond to a fully registered script, then no scripts
|
|
|
|
// are updated.
|
|
|
|
// |callback|: A callback to be invoked once scripts have been updated or
|
|
|
|
// if an error has occurred.
|
2024-08-11 19:31:37 +00:00
|
|
|
static void updateContentScripts(
|
2023-08-28 14:39:28 +00:00
|
|
|
RegisteredContentScript[] scripts,
|
|
|
|
optional RegisterContentScriptsCallback callback);
|
|
|
|
};
|
|
|
|
};
|