Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lukeed/saturated
A tiny (203B) utility to enqueue items for batch processing and/or satisfying rate limits.
https://github.com/lukeed/saturated
Last synced: 3 months ago
JSON representation
A tiny (203B) utility to enqueue items for batch processing and/or satisfying rate limits.
- Host: GitHub
- URL: https://github.com/lukeed/saturated
- Owner: lukeed
- License: mit
- Created: 2019-09-05T19:20:36.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-09-14T22:20:03.000Z (over 5 years ago)
- Last Synced: 2024-07-11T18:49:02.492Z (6 months ago)
- Language: JavaScript
- Homepage:
- Size: 13.7 KB
- Stars: 111
- Watchers: 5
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
- awesome - saturated - A tiny (203B) utility to enqueue items for batch processing and/or satisfying rate limits. (JavaScript)
- awesome-list - saturated
README
# saturated [![build status](https://badgen.now.sh/github/status/lukeed/saturated)](https://github.com/lukeed/saturated/actions) [![codecov](https://badgen.now.sh/codecov/c/github/lukeed/saturated)](https://codecov.io/gh/lukeed/saturated)
> A tiny (203B) utility to enqueue items for batch processing and/or satisfying rate limits.
Build a queue for your function – ideal for communicating with APIs that prefer batch/bulk processing or services that enforce rate limiting.
With `saturated` you provide a `handler` which will only be called every N items or after every X milliseconds... whichever comes first! This then allows you to [`push()`](#isaturatedpushvalue) your payload(s) into the queue, waiting for the next tick.
This module exposes three module definitions:
* **CommonJS**: `dist/saturated.js`
* **ES Module**: `dist/saturated.mjs`
* **UMD**: `dist/saturated.min.js`## Install
```
$ npm install --save saturated
```## Usage
```js
import saturated from 'saturated';// Setup an instance
const rated = saturated(arr => {
if (arr.length > 0) {
console.log('~> Received', arr);
} else {
console.log('~> Empty...');
}
}, {
max: 5, // limit
interval: 3e3 // 3s
});// Now we have a `saturated` instance that will
// call our function every 3 seconds or once it
// has 5 items in its queue – whichever comes first.// For demo purposes
const sleep = ms => new Promise(r => setTimeout(r, ms));// Demo usage
async function demo() {
rated.push('hello'); //=> 1
rated.push('world'); //=> 2
rated.push('how'); //=> 3
rated.push('are'); //=> 4
rated.push('you'); //=> 5// Queue received 5th item, immediately invoke!
// ~> Received ['hello', 'world', 'how', 'are', 'you']
rated.size(); //=> 0 (flushed)rated.push('hola'); //=> 1
rated.push('mundo'); //=> 2
rated.size(); //=> 2
await sleep(3e3);// Interval waited 3 seconds
// ~> Received ['hola', 'mundo']
rated.size(); //=> 0 (flushed)// Wait another 3s ...
await sleep(3e3);// ~> Empty...
rated.size(); //=> 0 (flushed anyway)
}// Init demo
demo().then(() => {
rated.end(); // quit
});
```## API
### saturated(handler, options)
Returns: `ISaturated`#### handler
Type: `Function`
Required: `true`The function to invoke once a threshold has been met.
It will always receive an `Array` of whatever item(s) you previously [`push`](#isaturatedpushvalue)ed.> **Note:** You may be passed an empty Array!
#### options.max
Type: `Number`
Default: `Infinity`The maximum size of the queue.
For example, with `max: 5`, your `handler` will be invoked immediately after the 5th item was pushed to queue.> **Important:** Your function will be called if `max` is met ***before*** the next `interval` tick.
#### options.interval
Type: `Number`
Default: `10000`The amount of time, in milliseconds, to wait before calling your `handler` function.
Defaults to calling your `handler` every 10 seconds, even if the queue is empty.### ISaturated.size()
Returns: `Number`Get the current size of the queue.
### ISaturated.push(value)
Returns: `Number`Add an item/value into the queue stack.
Doing so will return the current size of the queue.#### value
Type: `Any`You may push any value into queue.
> **Important:** Anything you push will be added to an Array!
> Pushing an Array will have your `handler` receive an Array of your Arrays.### ISaturated.end(toFlush)
Returns: `undefined`Cancels the internal `setInterval` timer.
#### toFlush
Type: `Boolean`
Default: `false`When `true`, will also [`flush()`](#isaturatedflush) the queue so that remaining items will be passed to your `handler` function.
### ISaturated.flush()
Returns: `undefined`Forcibly invoke your `handler` will _all_ items currently in the queue.
Calling `flush` will restart the internal `setInterval` timer and empty the queue.
## License
MIT © [Luke Edwards](https://lukeed.com)