// 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 chrome.scripting API to execute script in different // contexts. namespace scripting { callback InjectedFunction = void(); // The origin for a style change. // See style origins // 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 IDs // of specific frames to inject into. long[]? frameIds; // The IDs // of specific documentIds to inject into. This must not be set if // frameIds is set. DOMString[]? documentIds; // Whether the script should inject into all frames within the tab. Defaults // to false. // This must not be true if frameIds 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. // Exactly one of files and func must be // specified. [serializableFunction]InjectedFunction? func; // The arguments to curry into a provided function. This is only valid if // the func 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. // Exactly one of files and func must be // 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 // ISOLATED. 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 files and css must be // specified. DOMString? css; // The path of the CSS files to inject, relative to the extension's root // directory. // Exactly one of files and css must be // specified. DOMString[]? files; // The style origin for the injection. Defaults to 'AUTHOR'. 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 // Match Patterns for more details on the // syntax of these strings. Must be specified for // $(ref:registerContentScripts). DOMString[]? matches; // Excludes pages that this content script would otherwise be injected into. // See Match Patterns for more details on the // syntax of these strings. 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; // TODO(devlin): Add documentation once the implementation is complete. See // crbug.com/55084. [nodoc] boolean? matchOriginAsFallback; // Specifies when JavaScript files are injected into the web page. The // preferred and default value is document_idle. 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 // ISOLATED. 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. // TODO(crbug.com/1054624): Enable this once implementation is complete. [nodoc, nocompile] static long globalParams(); }; interface Functions { // Injects a script into a target context. The script will be run at // document_idle. If the script evaluates to a promise, // the browser will wait for the promise to settle and return the // resulting value. // |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. [supportsPromises] static void executeScript( 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. [supportsPromises] static void insertCSS( 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 // css, files, and origin 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. [supportsPromises] static void removeCSS( 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. [supportsPromises] static void registerContentScripts( 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. [supportsPromises] static void getRegisteredContentScripts( 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. [supportsPromises] static void unregisterContentScripts( 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. [supportsPromises] static void updateContentScripts( RegisteredContentScript[] scripts, optional RegisterContentScriptsCallback callback); }; };