UNPKG

@ckeditor/ckeditor5-utils

Version:

Miscellaneous utilities used by CKEditor 5.

35 lines (34 loc) 1.64 kB
/** * @license Copyright (c) 2003-2025, CKSource Holding sp. z o.o. All rights reserved. * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options */ /** * Tries calling the given callback until it sucessfully resolves. * * If the callback fails `maxAttempts` times, the returned promise is rejected with the last error. * * @typeParam TResult The result of a successful callback invocation. * @param callback The function to call until it succeeds. * @param options Configuration options. * @param options.maxAttempts Maximum number of attempts. * @param options.retryDelay The time in milliseconds between attempts. By default it implements exponential back-off policy. * @param options.signal The signal to abort further retries. The callback itself is not aborted automatically. */ export default function retry<TResult>(callback: () => Promise<TResult>, options?: { maxAttempts?: number; retryDelay?: (attempt: number) => number; signal?: AbortSignal; }): Promise<TResult>; /** * Creates a function that calculates exponential back-off delay. Pass it as `options.retryDelay` to {@link ~retry}. * * @param options.delay Base delay between invocations. Defaults to 1s. * @param options.factor How much to increase the delay. Defaults to 2x. * @param options.maxDelay Maximum timeout. Even if higher timeout is calculated, it cannot get higher than this value. Default to 10s. * @returns The function calculating the delay. */ export declare function exponentialDelay(options?: { delay?: number; factor?: number; maxDelay?: number; }): (attempt: number) => number;