2020-02-24 19:11:06 -07:00
## Class: ServiceWorkers
> Query and receive events from a sessions active service workers.
2021-06-15 14:50:31 -06: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 19:11:06 -07:00
Instances of the `ServiceWorkers` class are accessed by using `serviceWorkers` property of
a `Session` .
For example:
2023-11-21 00:50:08 -07:00
```js
2020-02-24 19:11:06 -07: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-15 21:13:18 -07:00
* `message` string - The actual console message
* `versionId` number - The version ID of the service worker that sent the log message
2022-01-10 15:31:39 -07: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-15 21:13:18 -07: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 19:11:06 -07:00
Emitted when a service worker logs something to the console.
2021-02-11 08:58:03 -07:00
#### Event: 'registration-completed'
Returns:
* `event` Event
* `details` Object - Information about the registered service worker
2021-11-15 21:13:18 -07:00
* `scope` string - The base URL that a service worker is registered for
2021-02-11 08:58:03 -07: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.
2020-02-24 19:11:06 -07:00
### Instance Methods
The following methods are available on instances of `ServiceWorkers` :
#### `serviceWorkers.getAllRunning()`
2021-11-15 21:13:18 -07: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 19:11:06 -07:00
#### `serviceWorkers.getFromVersionID(versionId)`
2021-11-15 21:13:18 -07:00
* `versionId` number
2020-02-24 19:11:06 -07: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.