From 6c98dbed0ed38d1978516f5aa3149fd2e611d382 Mon Sep 17 00:00:00 2001 From: Michael Telatynski <7t3chguy@gmail.com> Date: Mon, 13 May 2024 11:25:13 +0100 Subject: [PATCH] Add support for io.element.desktop scheme for OIDC (#1662) --- electron-builder.ts | 9 ++------- src/protocol.ts | 17 ++++++++++------- 2 files changed, 12 insertions(+), 14 deletions(-) diff --git a/electron-builder.ts b/electron-builder.ts index dedb5f7..88c4f56 100644 --- a/electron-builder.ts +++ b/electron-builder.ts @@ -39,9 +39,7 @@ const pkg: Pkg = JSON.parse(fs.readFileSync("package.json", "utf8")); interface Configuration extends BaseConfiguration { extraMetadata: Partial> & Omit; - linux: { - desktop: Record; - } & BaseConfiguration["linux"]; + linux: BaseConfiguration["linux"]; win: BaseConfiguration["win"]; mac: BaseConfiguration["mac"]; deb: { @@ -118,9 +116,6 @@ const config: Writable = { category: "Network;InstantMessaging;Chat", maintainer: "support@element.io", icon: "build/icons", - desktop: { - MimeType: "x-scheme-handler/element", - }, }, deb: { packageCategory: "net", @@ -167,7 +162,7 @@ const config: Writable = { protocols: [ { name: "element", - schemes: ["element"], + schemes: ["io.element.desktop", "element"], }, ], }; diff --git a/src/protocol.ts b/src/protocol.ts index 0487309..39b32a8 100644 --- a/src/protocol.ts +++ b/src/protocol.ts @@ -19,7 +19,8 @@ import { URL } from "url"; import path from "path"; import fs from "fs"; -const PROTOCOL = "element:"; +const LEGACY_PROTOCOL = "element"; +const PROTOCOL = "io.element.desktop"; const SEARCH_PARAM = "element-desktop-ssoid"; const STORE_FILE_NAME = "sso-sessions.json"; @@ -33,7 +34,7 @@ function processUrl(url: string): void { // sanity check: we only register for the one protocol, so we shouldn't // be getting anything else unless the user is forcing a URL to open // with the Element app. - if (parsed.protocol !== PROTOCOL) { + if (parsed.protocol !== `${PROTOCOL}:` && parsed.protocol !== `${LEGACY_PROTOCOL}:`) { console.log("Ignoring unexpected protocol: ", parsed.protocol); return; } @@ -82,10 +83,10 @@ export function recordSSOSession(sessionID: string): void { export function getProfileFromDeeplink(args: string[]): string | undefined { // check if we are passed a profile in the SSO callback url - const deeplinkUrl = args.find((arg) => arg.startsWith(PROTOCOL + "//")); + const deeplinkUrl = args.find((arg) => arg.startsWith(`${PROTOCOL}://`) || arg.startsWith(`${LEGACY_PROTOCOL}://`)); if (deeplinkUrl?.includes(SEARCH_PARAM)) { const parsedUrl = new URL(deeplinkUrl); - if (parsedUrl.protocol === PROTOCOL) { + if (parsedUrl.protocol === `${PROTOCOL}:` || parsedUrl.protocol === `${LEGACY_PROTOCOL}:`) { const store = readStore(); let ssoID = parsedUrl.searchParams.get(SEARCH_PARAM); if (!ssoID) { @@ -105,11 +106,13 @@ export function protocolInit(): void { // --profile/--profile-dir are passed via the SEARCH_PARAM var in the callback url const args = process.argv.slice(1).filter((arg) => arg !== "--hidden" && arg !== "-hidden"); if (app.isPackaged) { - app.setAsDefaultProtocolClient("element", process.execPath, args); + app.setAsDefaultProtocolClient(PROTOCOL, process.execPath, args); + app.setAsDefaultProtocolClient(LEGACY_PROTOCOL, process.execPath, args); } else if (process.platform === "win32") { // on Mac/Linux this would just cause the electron binary to open // special handler for running without being packaged, e.g `electron .` by passing our app path to electron - app.setAsDefaultProtocolClient("element", process.execPath, [app.getAppPath(), ...args]); + app.setAsDefaultProtocolClient(PROTOCOL, process.execPath, [app.getAppPath(), ...args]); + app.setAsDefaultProtocolClient(LEGACY_PROTOCOL, process.execPath, [app.getAppPath(), ...args]); } if (process.platform === "darwin") { @@ -122,7 +125,7 @@ export function protocolInit(): void { // Protocol handler for win32/Linux app.on("second-instance", (ev, commandLine) => { const url = commandLine[commandLine.length - 1]; - if (!url.startsWith(PROTOCOL + "//")) return; + if (!url.startsWith(`${PROTOCOL}://`) && !url.startsWith(`${LEGACY_PROTOCOL}://`)) return; processUrl(url); }); }