1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
Signed-off-by: Hung-Han (Henry) Chen <chenhungh@gmail.com>
This commit is contained in:
Hung-Han (Henry) Chen 2021-11-23 14:09:20 +02:00
parent 37eef77d4b
commit 21e0fc7bba
No known key found for this signature in database
GPG Key ID: 54B44603D251B788

View File

@ -545,38 +545,6 @@ export class KubeApi<T extends KubeObject> {
return retry(() => dns.lookup(url), retryOptions);
}
private suspendListener(opts: KubeApiWatchOptions, abort: AbortController["abort"], watchId: string, watchUrl: string) {
logger.info(`[KUBE-API] system suspended, abort watching of ${watchUrl}...`);
try {
if (typeof opts.abortController?.abort === "function") {
opts.abortController.abort();
} else if (typeof abort === "function") {
abort();
}
} catch (error) {
logger.error(`[KUBE-API] error aborting watch (${watchId})`, error);
}
electron.powerMonitor.once("resume", () => {
const url = "k8slens.dev"; // url to check if domain names are resolvable.
this.whenCanResolveDomainName(url, { retries: 50, maxTimeout: 3000 }).then(() => {
logger.info(`[KUBE-API] domain name can be resolved.`);
let abortController = opts.abortController;
if (opts.abortController.signal.aborted) {
abortController = new AbortController();
}
logger.info(`[KUBE-API] system resumed, resume watching of ${watchUrl}...`);
this.watch({ ...opts, abortController });
}).catch((error) => {
logger.warn(`[KUBE-API] error resolving domain name ${url}`, error);
});
});
}
watch(opts: KubeApiWatchOptions = { namespace: "", retry: false }): () => void {
let errorReceived = false;
let timedRetry: NodeJS.Timeout;
@ -598,10 +566,37 @@ export class KubeApi<T extends KubeObject> {
this.watchSystemStatus();
}
electron.powerMonitor.removeListener("suspend", this.suspendListener);
electron.powerMonitor.addListener("suspend", this.suspendListener.bind(
{ ...opts, namespace, callback, watchId, retry: true }, abort, watchId, watchUrl),
);
electron.powerMonitor.once("suspend", () => {
logger.info(`[KUBE-API] system suspended, abort watching of ${watchUrl}...`);
try {
if (opts.abortController) {
opts.abortController.abort?.();
} else {
abort?.();
}
} catch (error) {
logger.error(`[KUBE-API] error aborting watch (${watchId})`, error);
}
electron.powerMonitor.once("resume", () => {
const url = "k8slens.dev"; // url to check if domain names are resolvable.
this.whenCanResolveDomainName(url, { retries: 50, maxTimeout: 3000 }).then(() => {
logger.info(`[KUBE-API] domain name can be resolved.`);
let abortController = opts.abortController;
if (opts.abortController.signal.aborted) {
abortController = new AbortController();
}
logger.info(`[KUBE-API] system resumed, resume watching of ${watchUrl}...`);
this.watch({ ...opts, abortController, namespace, callback, watchId, retry: true });
}).catch((error) => {
logger.warn(`[KUBE-API] error resolving domain name ${url}`, error);
});
});
});
responsePromise
.then(response => {