@parzh/retryable
TypeScript icon, indicating that this package has built-in type declarations

1.7.0 • Public • Published

@parzh/retryable

Convenience function to retry executing an action, until a desired result is achieved

Installation

npm i @parzh/retryable
yarn add @parzh/retryable

Usage

const content = await retryable((resolve, reject, retry) => {
  fs.readfile("/path/to/file", (err, data) => {
    if (!err)
      // no errors occured
      return resolve(data);

    // here: an error occured

    if (retry.count >= RETRY_LIMIT)
      if (SHOULD_IGNORE_RETRY_LIMIT)
        // retry limit reached, but ignored
        retry.setCount(0);

      else
        // retry limit reached
        return reject("Retry limit reached!");

    // here: retry limit is ignored or not reached

    if (SHOULD_RETRY_IMMEDIATELY)
      // retrying immediately
      retry();

    else
      // retrying after exponential backoff (see https://en.wikipedia.org/wiki/Exponential_backoff)
      retry.after("exponential"); // same as: retry.after(2 ** retry.count * 100);
  });
});

Dependencies (0)

    Dev Dependencies (10)

    Package Sidebar

    Install

    npm i @parzh/retryable

    Weekly Downloads

    0

    Version

    1.7.0

    License

    MIT

    Unpacked Size

    30.6 kB

    Total Files

    24

    Last publish

    Collaborators

    • parzhitsky