From ea6641afe55ca88df31761789462a999e5814a1e Mon Sep 17 00:00:00 2001 From: Kilian Valkhof Date: Thu, 18 Apr 2019 21:40:04 +0200 Subject: [PATCH] docs: explanation on using protocols with partitions (#17759) * docs: explanation on using protocols with partitions * linting fixes * Update docs/api/protocol.md Co-Authored-By: Kilian * Update docs/api/protocol.md Co-Authored-By: Kilian * Update docs/api/protocol.md Co-Authored-By: Kilian * be more explicit about there being a default session. --- docs/api/protocol.md | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/docs/api/protocol.md b/docs/api/protocol.md index af1caa6f4aca..8f6af203365f 100644 --- a/docs/api/protocol.md +++ b/docs/api/protocol.md @@ -24,6 +24,38 @@ app.on('ready', () => { **Note:** All methods unless specified can only be used after the `ready` event of the `app` module gets emitted. +## Using `protocol` with a custom `partition` or `session` + +A protocol is registered to a specific Electron [`session`](./session.md) object. If you don't specify a session, then your `protocol` will be applied to the default session that Electron uses. However, if you define a `partition` or `session` on your `browserWindow`'s `webPreferences`, then that window will use a different session and your custom protocol will not work if you just use `electron.protocol.XXX`. + +To have your custom protocol work in combination with a custom session, you need to register it to that session explicitly. + +```javascript +const { session, app, protocol } = require('electron') +const path = require('path') + +app.on('ready', () => { + const partition = 'persist:example' + const ses = session.fromPartition(partition) + + ses.protocol.registerFileProtocol('atom', (request, callback) => { + const url = request.url.substr(7) + callback({ path: path.normalize(`${__dirname}/${url}`) }) + }, (error) => { + if (error) console.error('Failed to register protocol') + }) + + mainWindow = new BrowserWindow({ + width: 800, + height: 600, + webPreferences: { + partition: partition + } + }) +}) +``` +Using `protocol.registerStandardSchemes` without the session will still register your custom protocol as a standard scheme. + ## Methods The `protocol` module has the following methods: