Header menu logo fable-electron-docs-api

protocol Type

⚠ Process Availability: Main ✔ | Renderer ❌ | Utility ❌ | Exported ✔

Register a custom protocol and intercept existing protocol requests.Process: MainAn example of implementing a protocol that has the same effect as the file:// protocol:const { app, protocol, net } = require('electron')const path = require('node:path')const url = require('node:url')app.whenReady().then(() => { protocol.handle('atom', (request) => { const filePath = request.url.slice('atom://'.length) return net.fetch(url.pathToFileURL(path.join(__dirname, filePath)).toString()) })})> [!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 sessionA protocol is registered to a specific Electron session 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.const { app, BrowserWindow, net, protocol, session } = require('electron')const path = require('node:path')const url = require('node:url')app.whenReady().then(() => { const partition = 'persist:example' const ses = session.fromPartition(partition) ses.protocol.handle('atom', (request) => { const filePath = request.url.slice('atom://'.length) return net.fetch(url.pathToFileURL(path.resolve(__dirname, filePath)).toString()) }) const mainWindow = new BrowserWindow({ webPreferences: { partition } })})

Static members

Static member Description

protocol.handle (scheme, handler)

Full Usage: protocol.handle (scheme, handler)

Parameters:
Modifiers: inline

Register a protocol handler for scheme. Requests made to URLs with this scheme will delegate to this handler to determine what response should be sent.Either a Response or a Promise can be returned.Example:See the MDN docs for Request and Response for more details.

scheme : string
handler : Request -> U2<Response, Promise<Response>>

protocol.isProtocolHandled scheme

Full Usage: protocol.isProtocolHandled scheme

Parameters:
    scheme : string

Returns: bool
Modifiers: inline

Whether scheme is already handled.

scheme : string
Returns: bool

protocol.registerSchemesAsPrivileged customSchemes

Full Usage: protocol.registerSchemesAsPrivileged customSchemes

Parameters:
Modifiers: inline

[!NOTE] This method can only be used before the ready event of the app module gets emitted and can be called only once.Registers the scheme as standard, secure, bypasses content security policy for resources, allows registering ServiceWorker, supports fetch API, streaming video/audio, and V8 code cache. Specify a privilege with the value of true to enable the capability.An example of registering a privileged scheme, that bypasses Content Security Policy:A standard scheme adheres to what RFC 3986 calls generic URI syntax. For example http and https are standard schemes, while file is not.Registering a scheme as standard allows relative and absolute resources to be resolved correctly when served. Otherwise the scheme will behave like the file protocol, but without the ability to resolve relative URLs.For example when you load following page with custom protocol without registering it as standard scheme, the image will not be loaded because non-standard schemes can not recognize relative URLs:Registering a scheme as standard will allow access to files through the FileSystem API. Otherwise the renderer will throw a security error for the scheme.By default web storage apis (localStorage, sessionStorage, webSQL, indexedDB, cookies) are disabled for non standard schemes. So in general if you want to register a custom protocol to replace the http protocol, you have to register it as a standard scheme.Protocols that use streams (http and stream protocols) should set stream: true. The

customSchemes : CustomScheme[]

protocol.unhandle scheme

Full Usage: protocol.unhandle scheme

Parameters:
    scheme : string

Modifiers: inline

Removes a protocol handler registered with protocol.handle.

scheme : string

Type something to start searching.