2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Class: ServiceWorkers
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>  Query and receive events from a sessions active service workers.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-06-15 13:50:31 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Process: [Main ](../glossary.md#main-process )< br  /> 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								_This class is not exported from the `'electron'`  module. It is only available as a return value of other methods in the Electron API._
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Instances of the `ServiceWorkers`  class are accessed by using `serviceWorkers`  property of
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								a `Session` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For example:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-20 23:50:08 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								const { session } = require('electron')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Get all service workers.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								console.log(session.defaultSession.serviceWorkers.getAllRunning())
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Handle logs and get service worker info
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								session.defaultSession.serviceWorkers.on('console-message', (event, messageDetails) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  console.log(
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'Got service worker message',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    messageDetails,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'from',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    session.defaultSession.serviceWorkers.getFromVersionID(messageDetails.versionId)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Instance Events
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The following events are available on instances of `ServiceWorkers` :
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Event: 'console-message'
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `event`  Event 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `messageDetails`  Object - Information about the console message 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `message`  string - The actual console message
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `versionId`  number - The version ID of the service worker that sent the log message
							 
						 
					
						
							
								
									
										
										
										
											2022-01-10 17:31:39 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `source`  string - The type of source for this message.  Can be `javascript` , `xml` , `network` , `console-api` , `storage` , `rendering` , `security` , `deprecation` , `worker` , `violation` , `intervention` , `recommendation`  or `other` .
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `level`  number - The log level, from 0 to 3. In order it matches `verbose` , `info` , `warning`  and `error` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `sourceUrl`  string - The URL the message came from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `lineNumber`  number - The line number of the source that triggered this console message
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Emitted when a service worker logs something to the console.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-02-11 10:58:03 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### Event: 'registration-completed'
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `event`  Event 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `details`  Object - Information about the registered service worker 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  *  `scope`  string - The base URL that a service worker is registered for
							 
						 
					
						
							
								
									
										
										
										
											2021-02-11 10:58:03 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Emitted when a service worker has been registered. Can occur after a call to [`navigator.serviceWorker.register('/sw.js')` ](https://developer.mozilla.org/en-US/docs/Web/API/ServiceWorkerContainer/register ) successfully resolves or when a Chrome extension is loaded.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-31 12:40:19 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### Event: 'running-status-changed' _Experimental_
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `details`  Event\<\> 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `versionId`  number - ID of the updated service worker version
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  *  `runningStatus`  string - Running status.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Possible values include `starting` , `running` , `stopping` , or `stopped` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Emitted when a service worker's running status has changed.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Instance Methods
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The following methods are available on instances of `ServiceWorkers` :
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `serviceWorkers.getAllRunning()`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-16 05:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns `Record<number, ServiceWorkerInfo>`  - A [ServiceWorkerInfo ](structures/service-worker-info.md ) object where the keys are the service worker version ID and the values are the information about that service worker.
							 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-31 12:40:19 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### `serviceWorkers.getInfoFromVersionID(versionId)`
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `versionId`  number - ID of the service worker version 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-31 12:40:19 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Returns [`ServiceWorkerInfo` ](structures/service-worker-info.md ) - Information about this service worker
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If the service worker does not exist or is not running this method will throw an exception.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `serviceWorkers.getFromVersionID(versionId)` _Deprecated_
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `versionId`  number - ID of the service worker version 
						 
					
						
							
								
									
										
										
										
											2020-02-24 18:11:06 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns [`ServiceWorkerInfo` ](structures/service-worker-info.md ) - Information about this service worker
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If the service worker does not exist or is not running this method will throw an exception.
							 
						 
					
						
							
								
									
										
										
										
											2025-01-31 12:40:19 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								**Deprecated:** Use the new `serviceWorkers.getInfoFromVersionID`  API.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `serviceWorkers.getWorkerFromVersionID(versionId)` _Experimental_
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `versionId`  number - ID of the service worker version 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns [`ServiceWorkerMain | undefined` ](service-worker-main.md ) - Instance of the service worker associated with the given version ID. If there's no associated version, or its running status has changed to 'stopped', this will return `undefined` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### `serviceWorkers.startWorkerForScope(scope)` _Experimental_
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `scope`  string - The scope of the service worker to start. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Returns `Promise<ServiceWorkerMain>`  - Resolves with the service worker when it's started.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Starts the service worker or does nothing if already running.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								<!--  TODO(samuelmaddock): extend example to send IPC after starting worker  -->  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```js
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const { app, session } = require('electron')
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const { serviceWorkers } = session.defaultSession
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Collect service workers scopes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								const workerScopes = Object.values(serviceWorkers.getAllRunning()).map((info) => info.scope)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								app.on('browser-window-created', async (event, window) => {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  for (const scope of workerScopes) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    try {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      // Ensure worker is started
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      await serviceWorkers.startWorkerForScope(scope)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } catch (error) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      console.error(`Failed to start service worker for ${scope}` )
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      console.error(error)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```