Skip to content

the easiest API to deal with promises in Typescript. Currently, ↩️ Retrying πŸƒβ€β™‚οΈ looping & 😴 sleeping

Notifications You must be signed in to change notification settings

NicolasLopes7/ts-async-kit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

23 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

πŸš€ ts-async-kit

A lightweight TypeScript library that provides an easy-to-use API for dealing with common promise-related operations such as retrying and looping.

Installation

To install ts-async-kit in your project, simply run:

pnpm i ts-async-kit

Usage

Retry ↩️

Sometimes, a promise may fail due to a temporary issue such as a network error. In such cases, retrying the operation can be a useful strategy. With ts-async-kit, you can easily retry a promise until it succeeds or reaches a maximum number of attempts.

Here's an example:

import { retry } from 'ts-async-kit';

const fetchData = async () => {
  // Fetch data from an API
};

const result = await retry(fetchData, { maxRetries: 3 })

In the above example, fetchData is called up to three times, and the result is logged to the console if successful. If all attempts fail, an error is thrown.

Parameter Description
MaxRetries (Optional) How many times the function will be executed
Interval (Optional) How long the function should wait to retry it again
Timeout (Optional) How long the function should wait until stops the function execution (and fail)
backoffFactor (Optional) How much the interval should increase after each retry
onRetry (Optional) Callback function that can be called with the error when a function is retried
onFail (Optional) Callback function that can be called with the error when the function execution finishes by MaxRetries OR Timeout

Sleep 😴

Sometimes, you just want to block the current flow of execution and wait a certain time. For you don't waste time searching on StackOverflow, we shipped a function that easily does that. It's called sleep.

Here's an example:

import { sleep } from 'ts-async-kit'

await sleep(1000) // Time in ms to sleep

Loop (WIP) πŸƒβ€β™‚οΈ

Sometimes, you may need to perform a task repeatedly, such as polling an API for updates. With ts-async-kit, you can control how your loop will work. Error-tolerant, concurrent operations, until a condition is met, maximum number of iterations and so on...

Here's an example:

import { map } from 'ts-async-kit';

const data = [1, 2, 3]
const pollApi = async (id: number) => {
  // Poll an API for updates
};

const result = await map(data, pollApi, { concurrency: 2 })

In the above example, pollApi is called up until it finishes executing two promises concurrently. If all iterations fail, an error is thrown.

Contributing We welcome contributions! If you have an idea for a feature or would like to report a bug, please open an issue or submit a pull request.

License ts-async-kit is released under the MIT License.

About

the easiest API to deal with promises in Typescript. Currently, ↩️ Retrying πŸƒβ€β™‚οΈ looping & 😴 sleeping

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published