mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Fix kube auth proxy race condition (#3458)
* fix race condition by relying on mobx when() to indicate when the kube auth proxy is ready Signed-off-by: Jim Ehrismann <jehrismann@mirantis.com> * tweak KubeAuthProxy.run() return behaviour Signed-off-by: Jim Ehrismann <jehrismann@mirantis.com>
This commit is contained in:
parent
cdb7c95b8f
commit
b5e6bc36fe
@ -146,8 +146,10 @@ export class ContextHandler {
|
|||||||
proxyEnv.HTTPS_PROXY = this.cluster.preferences.httpsProxy;
|
proxyEnv.HTTPS_PROXY = this.cluster.preferences.httpsProxy;
|
||||||
}
|
}
|
||||||
this.kubeAuthProxy = new KubeAuthProxy(this.cluster, proxyEnv);
|
this.kubeAuthProxy = new KubeAuthProxy(this.cluster, proxyEnv);
|
||||||
await this.kubeAuthProxy.run();
|
this.kubeAuthProxy.run();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
await this.kubeAuthProxy.whenReady;
|
||||||
}
|
}
|
||||||
|
|
||||||
stopServer() {
|
stopServer() {
|
||||||
|
|||||||
@ -27,6 +27,7 @@ import { Kubectl } from "./kubectl";
|
|||||||
import logger from "./logger";
|
import logger from "./logger";
|
||||||
import * as url from "url";
|
import * as url from "url";
|
||||||
import { getPortFrom } from "./utils/get-port";
|
import { getPortFrom } from "./utils/get-port";
|
||||||
|
import { makeObservable, observable, when } from "mobx";
|
||||||
|
|
||||||
export interface KubeAuthProxyLog {
|
export interface KubeAuthProxyLog {
|
||||||
data: string;
|
data: string;
|
||||||
@ -47,8 +48,11 @@ export class KubeAuthProxy {
|
|||||||
protected env: NodeJS.ProcessEnv = null;
|
protected env: NodeJS.ProcessEnv = null;
|
||||||
protected proxyProcess: ChildProcess;
|
protected proxyProcess: ChildProcess;
|
||||||
protected kubectl: Kubectl;
|
protected kubectl: Kubectl;
|
||||||
|
@observable protected ready: boolean;
|
||||||
|
|
||||||
constructor(cluster: Cluster, env: NodeJS.ProcessEnv) {
|
constructor(cluster: Cluster, env: NodeJS.ProcessEnv) {
|
||||||
|
makeObservable(this);
|
||||||
|
this.ready = false;
|
||||||
this.env = env;
|
this.env = env;
|
||||||
this.cluster = cluster;
|
this.cluster = cluster;
|
||||||
this.kubectl = Kubectl.bundled();
|
this.kubectl = Kubectl.bundled();
|
||||||
@ -58,9 +62,13 @@ export class KubeAuthProxy {
|
|||||||
return url.parse(this.cluster.apiUrl).hostname;
|
return url.parse(this.cluster.apiUrl).hostname;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get whenReady() {
|
||||||
|
return when(() => this.ready);
|
||||||
|
}
|
||||||
|
|
||||||
public async run(): Promise<void> {
|
public async run(): Promise<void> {
|
||||||
if (this.proxyProcess) {
|
if (this.proxyProcess) {
|
||||||
return;
|
return this.whenReady;
|
||||||
}
|
}
|
||||||
|
|
||||||
const proxyBin = await this.kubectl.getPath();
|
const proxyBin = await this.kubectl.getPath();
|
||||||
@ -103,7 +111,9 @@ export class KubeAuthProxy {
|
|||||||
this.sendIpcLogMessage({ data: data.toString() });
|
this.sendIpcLogMessage({ data: data.toString() });
|
||||||
});
|
});
|
||||||
|
|
||||||
return waitUntilUsed(this.port, 500, 10000);
|
await waitUntilUsed(this.port, 500, 10000);
|
||||||
|
|
||||||
|
this.ready = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected parseError(data: string) {
|
protected parseError(data: string) {
|
||||||
@ -132,6 +142,7 @@ export class KubeAuthProxy {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public exit() {
|
public exit() {
|
||||||
|
this.ready = false;
|
||||||
if (!this.proxyProcess) return;
|
if (!this.proxyProcess) return;
|
||||||
logger.debug("[KUBE-AUTH]: stopping local proxy", this.cluster.getMeta());
|
logger.debug("[KUBE-AUTH]: stopping local proxy", this.cluster.getMeta());
|
||||||
this.proxyProcess.kill();
|
this.proxyProcess.kill();
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user