| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | # Chrome Extension Support
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-28 11:15:18 -07:00
										 |  |  | Electron supports a subset of the [Chrome Extensions API][chrome-extensions-api-index], | 
					
						
							|  |  |  | primarily to support DevTools extensions and Chromium-internal extensions, | 
					
						
							|  |  |  | but it also happens to support some other extension capabilities. | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | [chrome-extensions-api-index]: https://developer.chrome.com/extensions/api_index | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-09 17:46:11 -05:00
										 |  |  | > [!NOTE]
 | 
					
						
							|  |  |  | > Electron does not support arbitrary Chrome extensions from the
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | > store, and it is a **non-goal** of the Electron project to be perfectly
 | 
					
						
							|  |  |  | > compatible with Chrome's implementation of Extensions.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Loading extensions
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Electron only supports loading unpacked extensions (i.e., `.crx` files do not | 
					
						
							|  |  |  | work). Extensions are installed per-`session`. To load an extension, call | 
					
						
							| 
									
										
										
										
											2025-02-21 18:36:51 -05:00
										 |  |  | [`ses.extensions.loadExtension`](extensions-api.md#extensionsloadextensionpath-options): | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | const { session } = require('electron') | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-30 11:29:02 -08:00
										 |  |  | session.defaultSession.loadExtension('path/to/unpacked/extension').then(({ id }) => { | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  |   // ... | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Loaded extensions will not be automatically remembered across exits; if you do | 
					
						
							|  |  |  | not call `loadExtension` when the app runs, the extension will not be loaded. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-10 08:28:03 -08:00
										 |  |  | Note that loading extensions is only supported in persistent sessions. | 
					
						
							|  |  |  | Attempting to load an extension into an in-memory session will throw an error. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | See the [`session`](session.md) documentation for more information about | 
					
						
							|  |  |  | loading, unloading, and querying active extensions. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Supported Extensions APIs
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | We support the following extensions APIs, with some caveats. Other APIs may | 
					
						
							|  |  |  | additionally be supported, but support for any APIs not listed here is | 
					
						
							|  |  |  | provisional and may be removed. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:02:22 +02:00
										 |  |  | ### Supported Manifest Keys
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `name` | 
					
						
							|  |  |  | - `version` | 
					
						
							|  |  |  | - `author` | 
					
						
							|  |  |  | - `permissions` | 
					
						
							|  |  |  | - `content_scripts` | 
					
						
							|  |  |  | - `default_locale` | 
					
						
							|  |  |  | - `devtools_page` | 
					
						
							|  |  |  | - `short_name` | 
					
						
							|  |  |  | - `host_permissions` (Manifest V3) | 
					
						
							|  |  |  | - `manifest_version` | 
					
						
							|  |  |  | - `background` (Manifest V2) | 
					
						
							|  |  |  | - `minimum_chrome_version` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See [Manifest file format](https://developer.chrome.com/docs/extensions/mv3/manifest/) for more information about the purpose of each possible key. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.devtools.inspectedWindow`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All features of this API are supported. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/devtools_inspectedWindow) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.devtools.network`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All features of this API are supported. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/devtools_network) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.devtools.panels`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All features of this API are supported. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/devtools_panels) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.extension`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following properties of `chrome.extension` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.extension.lastError` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following methods of `chrome.extension` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.extension.getURL` | 
					
						
							|  |  |  | - `chrome.extension.getBackgroundPage` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/extension) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### `chrome.management`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following methods of `chrome.management` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.management.getAll` | 
					
						
							|  |  |  | - `chrome.management.get` | 
					
						
							|  |  |  | - `chrome.management.getSelf` | 
					
						
							|  |  |  | - `chrome.management.getPermissionWarningsById` | 
					
						
							|  |  |  | - `chrome.management.getPermissionWarningsByManifest` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following events of `chrome.management` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.management.onEnabled` | 
					
						
							|  |  |  | - `chrome.management.onDisabled` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/management) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.runtime`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following properties of `chrome.runtime` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.runtime.lastError` | 
					
						
							|  |  |  | - `chrome.runtime.id` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following methods of `chrome.runtime` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.runtime.getBackgroundPage` | 
					
						
							|  |  |  | - `chrome.runtime.getManifest` | 
					
						
							| 
									
										
										
										
											2020-09-15 12:29:32 -04:00
										 |  |  | - `chrome.runtime.getPlatformInfo` | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | - `chrome.runtime.getURL` | 
					
						
							|  |  |  | - `chrome.runtime.connect` | 
					
						
							|  |  |  | - `chrome.runtime.sendMessage` | 
					
						
							| 
									
										
										
										
											2021-07-15 04:07:53 +05:30
										 |  |  | - `chrome.runtime.reload` | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | The following events of `chrome.runtime` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.runtime.onStartup` | 
					
						
							|  |  |  | - `chrome.runtime.onInstalled` | 
					
						
							|  |  |  | - `chrome.runtime.onSuspend` | 
					
						
							|  |  |  | - `chrome.runtime.onSuspendCanceled` | 
					
						
							|  |  |  | - `chrome.runtime.onConnect` | 
					
						
							|  |  |  | - `chrome.runtime.onMessage` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/runtime) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### `chrome.scripting`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All features of this API are supported. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/scripting) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.storage`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-09 14:47:19 +02:00
										 |  |  | The following methods of `chrome.storage` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.storage.local` | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | `chrome.storage.sync` and `chrome.storage.managed` are **not** supported. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/storage) for more information. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | ### `chrome.tabs`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The following methods of `chrome.tabs` are supported: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - `chrome.tabs.sendMessage` | 
					
						
							| 
									
										
										
										
											2022-04-11 22:51:10 +02:00
										 |  |  | - `chrome.tabs.reload` | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | - `chrome.tabs.executeScript` | 
					
						
							| 
									
										
										
										
											2023-08-09 14:47:19 +02:00
										 |  |  | - `chrome.tabs.query` (partial support) | 
					
						
							|  |  |  |   - supported properties: `url`, `title`, `audible`, `active`, `muted`. | 
					
						
							| 
									
										
										
										
											2021-07-27 13:36:22 -07:00
										 |  |  | - `chrome.tabs.update` (partial support) | 
					
						
							|  |  |  |   - supported properties: `url`, `muted`. | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-09 17:46:11 -05:00
										 |  |  | > [!NOTE]
 | 
					
						
							|  |  |  | > In Chrome, passing `-1` as a tab ID signifies the "currently active
 | 
					
						
							| 
									
										
										
										
											2020-02-06 13:36:02 -08:00
										 |  |  | > tab". Since Electron has no such concept, passing `-1` as a tab ID is not
 | 
					
						
							|  |  |  | > supported and will raise an error.
 | 
					
						
							| 
									
										
										
										
											2020-09-02 02:59:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/tabs) for more information. | 
					
						
							| 
									
										
										
										
											2020-12-19 00:11:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### `chrome.webRequest`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | All features of this API are supported. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-05-09 17:46:11 -05:00
										 |  |  | > [!NOTE]
 | 
					
						
							|  |  |  | > Electron's [`webRequest`](web-request.md) module takes precedence over `chrome.webRequest` if there are conflicting handlers.
 | 
					
						
							| 
									
										
										
										
											2023-08-28 16:39:28 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | See [official documentation](https://developer.chrome.com/docs/extensions/reference/webRequest) for more information. |