mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Inject handlers into LensProxy to remove circular-deps (#3546)
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
2b3351bf9b
commit
476aa74101
@ -28,7 +28,7 @@ import * as LensExtensionsMainApi from "../extensions/main-api";
|
|||||||
import { app, autoUpdater, dialog, powerMonitor } from "electron";
|
import { app, autoUpdater, dialog, powerMonitor } from "electron";
|
||||||
import { appName, isMac, productName } from "../common/vars";
|
import { appName, isMac, productName } from "../common/vars";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
import { LensProxy } from "./proxy/lens-proxy";
|
import { LensProxy } from "./lens-proxy";
|
||||||
import { WindowManager } from "./window-manager";
|
import { WindowManager } from "./window-manager";
|
||||||
import { ClusterManager } from "./cluster-manager";
|
import { ClusterManager } from "./cluster-manager";
|
||||||
import { shellSync } from "./shell-sync";
|
import { shellSync } from "./shell-sync";
|
||||||
@ -49,7 +49,6 @@ import { pushCatalogToRenderer } from "./catalog-pusher";
|
|||||||
import { catalogEntityRegistry } from "./catalog";
|
import { catalogEntityRegistry } from "./catalog";
|
||||||
import { HelmRepoManager } from "./helm/helm-repo-manager";
|
import { HelmRepoManager } from "./helm/helm-repo-manager";
|
||||||
import { syncGeneralEntities, syncWeblinks, KubeconfigSyncManager } from "./catalog-sources";
|
import { syncGeneralEntities, syncWeblinks, KubeconfigSyncManager } from "./catalog-sources";
|
||||||
import { handleWsUpgrade } from "./proxy/ws-upgrade";
|
|
||||||
import configurePackages from "../common/configure-packages";
|
import configurePackages from "../common/configure-packages";
|
||||||
import { PrometheusProviderRegistry } from "./prometheus";
|
import { PrometheusProviderRegistry } from "./prometheus";
|
||||||
import * as initializers from "./initializers";
|
import * as initializers from "./initializers";
|
||||||
@ -61,6 +60,10 @@ import { ExtensionsStore } from "../extensions/extensions-store";
|
|||||||
import { FilesystemProvisionerStore } from "./extension-filesystem";
|
import { FilesystemProvisionerStore } from "./extension-filesystem";
|
||||||
import { SentryInit } from "../common/sentry";
|
import { SentryInit } from "../common/sentry";
|
||||||
import { ensureDir } from "fs-extra";
|
import { ensureDir } from "fs-extra";
|
||||||
|
import { Router } from "./router";
|
||||||
|
import { initMenu } from "./menu";
|
||||||
|
import { initTray } from "./tray";
|
||||||
|
import { kubeApiRequest, shellApiRequest } from "./proxy-functions";
|
||||||
|
|
||||||
SentryInit();
|
SentryInit();
|
||||||
|
|
||||||
@ -158,10 +161,11 @@ app.on("ready", async () => {
|
|||||||
|
|
||||||
HelmRepoManager.createInstance(); // create the instance
|
HelmRepoManager.createInstance(); // create the instance
|
||||||
|
|
||||||
const lensProxy = LensProxy.createInstance(
|
const lensProxy = LensProxy.createInstance(new Router(), {
|
||||||
handleWsUpgrade,
|
getClusterForRequest: req => ClusterManager.getInstance().getClusterForRequest(req),
|
||||||
req => ClusterManager.getInstance().getClusterForRequest(req),
|
kubeApiRequest,
|
||||||
);
|
shellApiRequest,
|
||||||
|
});
|
||||||
|
|
||||||
ClusterManager.createInstance().init();
|
ClusterManager.createInstance().init();
|
||||||
KubeconfigSyncManager.createInstance();
|
KubeconfigSyncManager.createInstance();
|
||||||
@ -205,6 +209,11 @@ app.on("ready", async () => {
|
|||||||
logger.info("🖥️ Starting WindowManager");
|
logger.info("🖥️ Starting WindowManager");
|
||||||
const windowManager = WindowManager.createInstance();
|
const windowManager = WindowManager.createInstance();
|
||||||
|
|
||||||
|
cleanup.push(
|
||||||
|
initMenu(windowManager),
|
||||||
|
initTray(windowManager),
|
||||||
|
);
|
||||||
|
|
||||||
installDeveloperTools();
|
installDeveloperTools();
|
||||||
|
|
||||||
if (!startHidden) {
|
if (!startHidden) {
|
||||||
|
|||||||
@ -22,7 +22,7 @@
|
|||||||
import request, { RequestPromiseOptions } from "request-promise-native";
|
import request, { RequestPromiseOptions } from "request-promise-native";
|
||||||
import { apiKubePrefix } from "../common/vars";
|
import { apiKubePrefix } from "../common/vars";
|
||||||
import type { IMetricsReqParams } from "../renderer/api/endpoints/metrics.api";
|
import type { IMetricsReqParams } from "../renderer/api/endpoints/metrics.api";
|
||||||
import { LensProxy } from "./proxy/lens-proxy";
|
import { LensProxy } from "./lens-proxy";
|
||||||
import type { Cluster } from "./cluster";
|
import type { Cluster } from "./cluster";
|
||||||
|
|
||||||
export async function k8sRequest<T = any>(cluster: Cluster, path: string, options: RequestPromiseOptions = {}): Promise<T> {
|
export async function k8sRequest<T = any>(cluster: Cluster, path: string, options: RequestPromiseOptions = {}): Promise<T> {
|
||||||
|
|||||||
@ -27,7 +27,7 @@ import path from "path";
|
|||||||
import fs from "fs-extra";
|
import fs from "fs-extra";
|
||||||
import { dumpConfigYaml } from "../common/kube-helpers";
|
import { dumpConfigYaml } from "../common/kube-helpers";
|
||||||
import logger from "./logger";
|
import logger from "./logger";
|
||||||
import { LensProxy } from "./proxy/lens-proxy";
|
import { LensProxy } from "./lens-proxy";
|
||||||
|
|
||||||
export class KubeconfigManager {
|
export class KubeconfigManager {
|
||||||
protected configDir = app.getPath("temp");
|
protected configDir = app.getPath("temp");
|
||||||
|
|||||||
@ -19,33 +19,42 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import net from "net";
|
import type net from "net";
|
||||||
import type http from "http";
|
import type http from "http";
|
||||||
import spdy from "spdy";
|
import spdy from "spdy";
|
||||||
import httpProxy from "http-proxy";
|
import httpProxy from "http-proxy";
|
||||||
import url from "url";
|
import { apiPrefix, apiKubePrefix } from "../common/vars";
|
||||||
import { apiPrefix, apiKubePrefix } from "../../common/vars";
|
import type { Router } from "./router";
|
||||||
import { Router } from "../router";
|
import type { ContextHandler } from "./context-handler";
|
||||||
import type { ContextHandler } from "../context-handler";
|
import logger from "./logger";
|
||||||
import logger from "../logger";
|
import { Singleton } from "../common/utils";
|
||||||
import { Singleton } from "../../common/utils";
|
import type { Cluster } from "./cluster";
|
||||||
import type { Cluster } from "../cluster";
|
import type { ProxyApiRequestArgs } from "./proxy-functions";
|
||||||
|
|
||||||
type WSUpgradeHandler = (req: http.IncomingMessage, socket: net.Socket, head: Buffer) => void;
|
type GetClusterForRequest = (req: http.IncomingMessage) => Cluster | null;
|
||||||
|
|
||||||
|
export interface LensProxyFunctions {
|
||||||
|
getClusterForRequest: GetClusterForRequest,
|
||||||
|
shellApiRequest: (args: ProxyApiRequestArgs) => void | Promise<void>;
|
||||||
|
kubeApiRequest: (args: ProxyApiRequestArgs) => void | Promise<void>;
|
||||||
|
}
|
||||||
|
|
||||||
export class LensProxy extends Singleton {
|
export class LensProxy extends Singleton {
|
||||||
protected origin: string;
|
protected origin: string;
|
||||||
protected proxyServer: http.Server;
|
protected proxyServer: http.Server;
|
||||||
protected router = new Router();
|
|
||||||
protected closed = false;
|
protected closed = false;
|
||||||
protected retryCounters = new Map<string, number>();
|
protected retryCounters = new Map<string, number>();
|
||||||
|
protected proxy = this.createProxy();
|
||||||
|
protected getClusterForRequest: GetClusterForRequest;
|
||||||
|
|
||||||
public port: number;
|
public port: number;
|
||||||
|
|
||||||
constructor(handleWsUpgrade: WSUpgradeHandler, protected getClusterForRequest: (req: http.IncomingMessage) => Cluster | undefined) {
|
constructor(protected router: Router, functions: LensProxyFunctions) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
const proxy = this.createProxy();
|
const { shellApiRequest, kubeApiRequest } = functions;
|
||||||
|
|
||||||
|
this.getClusterForRequest = functions.getClusterForRequest;
|
||||||
|
|
||||||
this.proxyServer = spdy.createServer({
|
this.proxyServer = spdy.createServer({
|
||||||
spdy: {
|
spdy: {
|
||||||
@ -53,17 +62,16 @@ export class LensProxy extends Singleton {
|
|||||||
protocols: ["http/1.1", "spdy/3.1"]
|
protocols: ["http/1.1", "spdy/3.1"]
|
||||||
}
|
}
|
||||||
}, (req: http.IncomingMessage, res: http.ServerResponse) => {
|
}, (req: http.IncomingMessage, res: http.ServerResponse) => {
|
||||||
this.handleRequest(proxy, req, res);
|
this.handleRequest(req, res);
|
||||||
});
|
});
|
||||||
|
|
||||||
this.proxyServer
|
this.proxyServer
|
||||||
.on("upgrade", (req: http.IncomingMessage, socket: net.Socket, head: Buffer) => {
|
.on("upgrade", (req: http.IncomingMessage, socket: net.Socket, head: Buffer) => {
|
||||||
if (req.url.startsWith(`${apiPrefix}?`)) {
|
const isInternal = req.url.startsWith(`${apiPrefix}?`);
|
||||||
handleWsUpgrade(req, socket, head);
|
const reqHandler = isInternal ? shellApiRequest : kubeApiRequest;
|
||||||
} else {
|
|
||||||
this.handleProxyUpgrade(proxy, req, socket, head)
|
(async () => reqHandler({ req, socket, head }))()
|
||||||
.catch(error => logger.error(`[LENS-PROXY]: failed to handle proxy upgrade: ${error}`));
|
.catch(error => logger.error(logger.error(`[LENS-PROXY]: failed to handle proxy upgrade: ${error}`)));
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,58 +112,6 @@ export class LensProxy extends Singleton {
|
|||||||
this.closed = true;
|
this.closed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected async handleProxyUpgrade(proxy: httpProxy, req: http.IncomingMessage, socket: net.Socket, head: Buffer) {
|
|
||||||
const cluster = this.getClusterForRequest(req);
|
|
||||||
|
|
||||||
if (cluster) {
|
|
||||||
const proxyUrl = await cluster.contextHandler.resolveAuthProxyUrl() + req.url.replace(apiKubePrefix, "");
|
|
||||||
const apiUrl = url.parse(cluster.apiUrl);
|
|
||||||
const pUrl = url.parse(proxyUrl);
|
|
||||||
const connectOpts = { port: parseInt(pUrl.port), host: pUrl.hostname };
|
|
||||||
const proxySocket = new net.Socket();
|
|
||||||
|
|
||||||
proxySocket.connect(connectOpts, () => {
|
|
||||||
proxySocket.write(`${req.method} ${pUrl.path} HTTP/1.1\r\n`);
|
|
||||||
proxySocket.write(`Host: ${apiUrl.host}\r\n`);
|
|
||||||
|
|
||||||
for (let i = 0; i < req.rawHeaders.length; i += 2) {
|
|
||||||
const key = req.rawHeaders[i];
|
|
||||||
|
|
||||||
if (key !== "Host" && key !== "Authorization") {
|
|
||||||
proxySocket.write(`${req.rawHeaders[i]}: ${req.rawHeaders[i+1]}\r\n`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
proxySocket.write("\r\n");
|
|
||||||
proxySocket.write(head);
|
|
||||||
});
|
|
||||||
|
|
||||||
proxySocket.setKeepAlive(true);
|
|
||||||
socket.setKeepAlive(true);
|
|
||||||
proxySocket.setTimeout(0);
|
|
||||||
socket.setTimeout(0);
|
|
||||||
|
|
||||||
proxySocket.on("data", function (chunk) {
|
|
||||||
socket.write(chunk);
|
|
||||||
});
|
|
||||||
proxySocket.on("end", function () {
|
|
||||||
socket.end();
|
|
||||||
});
|
|
||||||
proxySocket.on("error", function () {
|
|
||||||
socket.write(`HTTP/${req.httpVersion} 500 Connection error\r\n\r\n`);
|
|
||||||
socket.end();
|
|
||||||
});
|
|
||||||
socket.on("data", function (chunk) {
|
|
||||||
proxySocket.write(chunk);
|
|
||||||
});
|
|
||||||
socket.on("end", function () {
|
|
||||||
proxySocket.end();
|
|
||||||
});
|
|
||||||
socket.on("error", function () {
|
|
||||||
proxySocket.end();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected createProxy(): httpProxy {
|
protected createProxy(): httpProxy {
|
||||||
const proxy = httpProxy.createProxyServer();
|
const proxy = httpProxy.createProxyServer();
|
||||||
|
|
||||||
@ -195,7 +151,7 @@ export class LensProxy extends Singleton {
|
|||||||
logger.debug(`Retrying proxy request to url: ${reqId}`);
|
logger.debug(`Retrying proxy request to url: ${reqId}`);
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
this.retryCounters.set(reqId, retryCount + 1);
|
this.retryCounters.set(reqId, retryCount + 1);
|
||||||
this.handleRequest(proxy, req, res)
|
this.handleRequest(req, res)
|
||||||
.catch(error => logger.error(`[LENS-PROXY]: failed to handle request on proxy error: ${error}`));
|
.catch(error => logger.error(`[LENS-PROXY]: failed to handle request on proxy error: ${error}`));
|
||||||
}, timeoutMs);
|
}, timeoutMs);
|
||||||
}
|
}
|
||||||
@ -226,7 +182,7 @@ export class LensProxy extends Singleton {
|
|||||||
return req.headers.host + req.url;
|
return req.headers.host + req.url;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected async handleRequest(proxy: httpProxy, req: http.IncomingMessage, res: http.ServerResponse) {
|
protected async handleRequest(req: http.IncomingMessage, res: http.ServerResponse) {
|
||||||
const cluster = this.getClusterForRequest(req);
|
const cluster = this.getClusterForRequest(req);
|
||||||
|
|
||||||
if (cluster) {
|
if (cluster) {
|
||||||
@ -237,7 +193,7 @@ export class LensProxy extends Singleton {
|
|||||||
// this should be safe because we have already validated cluster uuid
|
// this should be safe because we have already validated cluster uuid
|
||||||
res.setHeader("Access-Control-Allow-Origin", "*");
|
res.setHeader("Access-Control-Allow-Origin", "*");
|
||||||
|
|
||||||
return proxy.web(req, res, proxyTarget);
|
return this.proxy.web(req, res, proxyTarget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.router.route(cluster, req, res);
|
this.router.route(cluster, req, res);
|
||||||
@ -19,7 +19,6 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Don't export the contents here
|
export * from "./shell-api-request";
|
||||||
// It will break the extension webpack
|
export * from "./kube-api-request";
|
||||||
|
export * from "./types";
|
||||||
export default {};
|
|
||||||
84
src/main/proxy-functions/kube-api-request.ts
Normal file
84
src/main/proxy-functions/kube-api-request.ts
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 OpenLens Authors
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
* this software and associated documentation files (the "Software"), to deal in
|
||||||
|
* the Software without restriction, including without limitation the rights to
|
||||||
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
* subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all
|
||||||
|
* copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { chunk } from "lodash";
|
||||||
|
import net from "net";
|
||||||
|
import url from "url";
|
||||||
|
import { apiKubePrefix } from "../../common/vars";
|
||||||
|
import { ClusterManager } from "../cluster-manager";
|
||||||
|
import type { ProxyApiRequestArgs } from "./types";
|
||||||
|
|
||||||
|
const skipRawHeaders = new Set(["Host", "Authorization"]);
|
||||||
|
|
||||||
|
export async function kubeApiRequest({ req, socket, head }: ProxyApiRequestArgs) {
|
||||||
|
const cluster = ClusterManager.getInstance().getClusterForRequest(req);
|
||||||
|
|
||||||
|
if (!cluster) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const proxyUrl = await cluster.contextHandler.resolveAuthProxyUrl() + req.url.replace(apiKubePrefix, "");
|
||||||
|
const apiUrl = url.parse(cluster.apiUrl);
|
||||||
|
const pUrl = url.parse(proxyUrl);
|
||||||
|
const connectOpts = { port: parseInt(pUrl.port), host: pUrl.hostname };
|
||||||
|
const proxySocket = new net.Socket();
|
||||||
|
|
||||||
|
proxySocket.connect(connectOpts, () => {
|
||||||
|
proxySocket.write(`${req.method} ${pUrl.path} HTTP/1.1\r\n`);
|
||||||
|
proxySocket.write(`Host: ${apiUrl.host}\r\n`);
|
||||||
|
|
||||||
|
for (const [key, value] of chunk(req.rawHeaders, 2)) {
|
||||||
|
if (skipRawHeaders.has(key)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
proxySocket.write(`${key}: ${value}\r\n`);
|
||||||
|
}
|
||||||
|
|
||||||
|
proxySocket.write("\r\n");
|
||||||
|
proxySocket.write(head);
|
||||||
|
});
|
||||||
|
|
||||||
|
proxySocket.setKeepAlive(true);
|
||||||
|
socket.setKeepAlive(true);
|
||||||
|
proxySocket.setTimeout(0);
|
||||||
|
socket.setTimeout(0);
|
||||||
|
|
||||||
|
proxySocket.on("data", function (chunk) {
|
||||||
|
socket.write(chunk);
|
||||||
|
});
|
||||||
|
proxySocket.on("end", function () {
|
||||||
|
socket.end();
|
||||||
|
});
|
||||||
|
proxySocket.on("error", function () {
|
||||||
|
socket.write(`HTTP/${req.httpVersion} 500 Connection error\r\n\r\n`);
|
||||||
|
socket.end();
|
||||||
|
});
|
||||||
|
socket.on("data", function (chunk) {
|
||||||
|
proxySocket.write(chunk);
|
||||||
|
});
|
||||||
|
socket.on("end", function () {
|
||||||
|
proxySocket.end();
|
||||||
|
});
|
||||||
|
socket.on("error", function () {
|
||||||
|
proxySocket.end();
|
||||||
|
});
|
||||||
|
}
|
||||||
@ -19,24 +19,18 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
|
||||||
* This file is here so that the "../shell-session" import can be injected into
|
|
||||||
* LensProxy at creation time. So that the `pty.node` extension isn't loaded
|
|
||||||
* into Lens Extension webpack bundle.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import * as WebSocket from "ws";
|
|
||||||
import type http from "http";
|
import type http from "http";
|
||||||
import type net from "net";
|
|
||||||
import url from "url";
|
import url from "url";
|
||||||
import { NodeShellSession, LocalShellSession } from "../shell-session";
|
|
||||||
import { ClusterManager } from "../cluster-manager";
|
|
||||||
import logger from "../logger";
|
import logger from "../logger";
|
||||||
|
import * as WebSocket from "ws";
|
||||||
|
import { NodeShellSession, LocalShellSession } from "../shell-session";
|
||||||
|
import type { ProxyApiRequestArgs } from "./types";
|
||||||
|
import { ClusterManager } from "../cluster-manager";
|
||||||
|
|
||||||
function createWsListener(): WebSocket.Server {
|
export function shellApiRequest({ req, socket, head }: ProxyApiRequestArgs) {
|
||||||
const ws = new WebSocket.Server({ noServer: true });
|
const ws = new WebSocket.Server({ noServer: true });
|
||||||
|
|
||||||
return ws.on("connection", ((socket: WebSocket, req: http.IncomingMessage) => {
|
ws.on("connection", ((socket: WebSocket, req: http.IncomingMessage) => {
|
||||||
const cluster = ClusterManager.getInstance().getClusterForRequest(req);
|
const cluster = ClusterManager.getInstance().getClusterForRequest(req);
|
||||||
const nodeParam = url.parse(req.url, true).query["node"]?.toString();
|
const nodeParam = url.parse(req.url, true).query["node"]?.toString();
|
||||||
const shell = nodeParam
|
const shell = nodeParam
|
||||||
@ -46,12 +40,8 @@ function createWsListener(): WebSocket.Server {
|
|||||||
shell.open()
|
shell.open()
|
||||||
.catch(error => logger.error(`[SHELL-SESSION]: failed to open: ${error}`, { error }));
|
.catch(error => logger.error(`[SHELL-SESSION]: failed to open: ${error}`, { error }));
|
||||||
}));
|
}));
|
||||||
}
|
|
||||||
|
|
||||||
export async function handleWsUpgrade(req: http.IncomingMessage, socket: net.Socket, head: Buffer) {
|
ws.handleUpgrade(req, socket, head, (con) => {
|
||||||
const wsServer = createWsListener();
|
ws.emit("connection", con, req);
|
||||||
|
|
||||||
wsServer.handleUpgrade(req, socket, head, (con) => {
|
|
||||||
wsServer.emit("connection", con, req);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
29
src/main/proxy-functions/types.ts
Normal file
29
src/main/proxy-functions/types.ts
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 OpenLens Authors
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
* this software and associated documentation files (the "Software"), to deal in
|
||||||
|
* the Software without restriction, including without limitation the rights to
|
||||||
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
* subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all
|
||||||
|
* copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import type http from "http";
|
||||||
|
import type net from "net";
|
||||||
|
|
||||||
|
export interface ProxyApiRequestArgs {
|
||||||
|
req: http.IncomingMessage,
|
||||||
|
socket: net.Socket,
|
||||||
|
head: Buffer,
|
||||||
|
}
|
||||||
@ -25,14 +25,12 @@ import { app, BrowserWindow, dialog, ipcMain, shell, webContents } from "electro
|
|||||||
import windowStateKeeper from "electron-window-state";
|
import windowStateKeeper from "electron-window-state";
|
||||||
import { appEventBus } from "../common/event-bus";
|
import { appEventBus } from "../common/event-bus";
|
||||||
import { ipcMainOn } from "../common/ipc";
|
import { ipcMainOn } from "../common/ipc";
|
||||||
import { initMenu } from "./menu";
|
|
||||||
import { initTray } from "./tray";
|
|
||||||
import { delay, iter, Singleton } from "../common/utils";
|
import { delay, iter, Singleton } from "../common/utils";
|
||||||
import { ClusterFrameInfo, clusterFrameMap } from "../common/cluster-frames";
|
import { ClusterFrameInfo, clusterFrameMap } from "../common/cluster-frames";
|
||||||
import { IpcRendererNavigationEvents } from "../renderer/navigation/events";
|
import { IpcRendererNavigationEvents } from "../renderer/navigation/events";
|
||||||
import logger from "./logger";
|
import logger from "./logger";
|
||||||
import { productName } from "../common/vars";
|
import { productName } from "../common/vars";
|
||||||
import { LensProxy } from "./proxy/lens-proxy";
|
import { LensProxy } from "./lens-proxy";
|
||||||
|
|
||||||
function isHideable(window: BrowserWindow | null): boolean {
|
function isHideable(window: BrowserWindow | null): boolean {
|
||||||
return Boolean(window && !window.isDestroyed());
|
return Boolean(window && !window.isDestroyed());
|
||||||
@ -56,8 +54,6 @@ export class WindowManager extends Singleton {
|
|||||||
super();
|
super();
|
||||||
makeObservable(this);
|
makeObservable(this);
|
||||||
this.bindEvents();
|
this.bindEvents();
|
||||||
this.initMenu();
|
|
||||||
this.initTray();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
get mainUrl() {
|
get mainUrl() {
|
||||||
@ -136,14 +132,6 @@ export class WindowManager extends Singleton {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected async initMenu() {
|
|
||||||
this.disposers.menuAutoUpdater = initMenu(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected initTray() {
|
|
||||||
this.disposers.trayAutoUpdater = initTray(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected bindEvents() {
|
protected bindEvents() {
|
||||||
// track visible cluster from ui
|
// track visible cluster from ui
|
||||||
ipcMainOn(IpcRendererNavigationEvents.CLUSTER_VIEW_CURRENT_ID, (event, clusterId: ClusterId) => {
|
ipcMainOn(IpcRendererNavigationEvents.CLUSTER_VIEW_CURRENT_ID, (event, clusterId: ClusterId) => {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user