ttl-queue

Queue items with a specific timeout

Usage no npm install needed!

<script type="module">
  import ttlQueue from 'https://cdn.skypack.dev/ttl-queue';
</script>

README

ee-ttl-queue

A queue wich holds items not longer than a specified amount of time. It Wwll never fill your memmory thanks to the ttl-queue.

npm Travis node

API

You may specify a maximum of items items that may be stored aas well as a ttl value.

var TTLQueue = require('ttl-queue');

let q = new TTLQueue();

or

let q = new TTLQueue({
      ttl: 3000 // 3 seconds, defaults to unlimited
    , max: 1000 // max 1'000 items in the queue, defaults to unlimited
});

Adding Items

When adding items you will get an unique id returned that later can bve used to remove items again. If the method returns the value false the item could not be added because the queue is full or the memory is full.

let itemId = q.push(myItem);


if (itemId === false) {
    // the item could not be queued
}

Getting Items

When getting an item from the queue it is removed from it

var item = q.get();

Removing Items

You may remove items using the id returned by the push method

let itemId = q.push(myItem);
let item = q.remove(itemId);

Drain Event

The drain event is emitted as soon there is no item left in the queue

q.on('drain', () => {

});

Overflow Event

This event is emitted if an item could not be added because the queue or the memory is full

q.on('overflow', (item, error) => {

});

Timeout event

This event is emitted if an item times out because of the ttl value set

q.on('timeout', (item) => {

});

Length property

This property indicates how many items are queued

var l = q.length;