mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
- Add lens:// protocol handling with a routing mechanism - document the methods in an extension guide - remove handlers when an extension is deactivated or removed - make sure that the found extension when routing a request is currently enabled (as a backup) - added documentation about the above behaviour to the guide - tweaked the naming convention so that it is clearer that the router uses extension names as not IDs (which currently are folder paths) - Convert the extension API to use an array for registering handlers - switch design to execute both main and renderer handlers simultaneously, without any overlap checking - change open to be a dev dep - improve docs, export types for extensions, skip integration tests - switch to event emitting renderer being ready - Add logging and fix renderer:loaded send to main Signed-off-by: Sebastian Malton <sebastian@malton.name>
41 lines
1.2 KiB
TypeScript
41 lines
1.2 KiB
TypeScript
import { ipcRenderer } from "electron";
|
|
import * as proto from "../../common/protocol-handler";
|
|
import logger from "../../main/logger";
|
|
import Url from "url-parse";
|
|
import { autobind } from "../utils";
|
|
|
|
export class LensProtocolRouterRenderer extends proto.LensProtocolRouter {
|
|
/**
|
|
* This function is needed to be called early on in the renderers lifetime.
|
|
*/
|
|
public init(): void {
|
|
ipcRenderer
|
|
.on(proto.ProtocolHandlerInternal, this.ipcInternalHandler)
|
|
.on(proto.ProtocolHandlerExtension, this.ipcExtensionHandler);
|
|
}
|
|
|
|
@autobind()
|
|
private ipcInternalHandler(event: Electron.IpcRendererEvent, ...args: any[]): void {
|
|
if (args.length !== 1) {
|
|
return void logger.warn(`${proto.LensProtocolRouter.LoggingPrefix}: unexpected number of args`, { args });
|
|
}
|
|
|
|
const [rawUrl] = args;
|
|
const url = new Url(rawUrl, true);
|
|
|
|
this._routeToInternal(url);
|
|
}
|
|
|
|
@autobind()
|
|
private ipcExtensionHandler(event: Electron.IpcRendererEvent, ...args: any[]): void {
|
|
if (args.length !== 1) {
|
|
return void logger.warn(`${proto.LensProtocolRouter.LoggingPrefix}: unexpected number of args`, { args });
|
|
}
|
|
|
|
const [rawUrl] = args;
|
|
const url = new Url(rawUrl, true);
|
|
|
|
this._routeToExtension(url);
|
|
}
|
|
}
|