mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
- requestNamespaceListPermissions is infallable so no need to have the extra try/catch - Refactor isMetricHidden method away from Cluster - Refactor shouldShowResource out of Cluster - Refactor isInLocalKubeconfig out of Cluster - Remove depecrated and unused workspace from Cluster - Refactor out kubectl as a dependency of Cluster - Remove from cluster getter used only once - Split out ClusterConnection from Cluster - Also split out KubeAuthProxyServer from ContextHandler - Rename ContextHandler to PrometheusHandler - Cleanup onNetworkOffline/Online impls within ClusterManager - Remove annotations from ClusterConnection - Remove mobx annotations from Cluster - Rename loadConfigFromFileInjectable - Remove all uses of dead createClusterInjectionToken - Fix type errors related to broadcastConnectionUpdate Signed-off-by: Sebastian Malton <sebastian@malton.name>
71 lines
1.6 KiB
TypeScript
71 lines
1.6 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import type { AsyncResult } from "./async-result";
|
|
import { delay } from "./delay";
|
|
import { noop } from "./noop";
|
|
|
|
/**
|
|
* @param error The error that resulted in the failure
|
|
* @param attempt The 1-index attempt count
|
|
*/
|
|
export type OnIntermediateError<E> = (error: E, attempt: number) => void;
|
|
|
|
export interface BackoffCallerOptions<E> {
|
|
/**
|
|
* Called when an attempt fails
|
|
*/
|
|
onIntermediateError?: OnIntermediateError<E>;
|
|
|
|
/**
|
|
* @default 5
|
|
*/
|
|
maxAttempts?: number;
|
|
|
|
/**
|
|
* In milliseconds
|
|
* @default 1000
|
|
*/
|
|
initialTimeout?: number;
|
|
|
|
/**
|
|
* @default 2
|
|
*/
|
|
scaleFactor?: number;
|
|
}
|
|
|
|
/**
|
|
* Calls `fn` once and then again (with exponential delay between each attempt) up to `options.maxAttempts` times.
|
|
* @param fn The function to repeatedly attempt
|
|
* @returns The first success or the last failure
|
|
*/
|
|
export const backoffCaller = async <T, E, R extends AsyncResult<T, E>>(fn: () => Promise<R>, options?: BackoffCallerOptions<E>): Promise<R> => {
|
|
const {
|
|
initialTimeout = 1000,
|
|
maxAttempts = 5,
|
|
onIntermediateError = noop as OnIntermediateError<E>,
|
|
scaleFactor = 2,
|
|
} = options ?? {};
|
|
|
|
let timeout = initialTimeout;
|
|
let attempt = 0;
|
|
let result: R;
|
|
|
|
do {
|
|
result = await fn();
|
|
|
|
if (result.callWasSuccessful) {
|
|
return result;
|
|
}
|
|
|
|
onIntermediateError(result.error, attempt + 1);
|
|
|
|
await delay(timeout);
|
|
timeout *= scaleFactor;
|
|
} while (attempt += 1, attempt < maxAttempts);
|
|
|
|
return result;
|
|
};
|