npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

kuyruk

v0.0.7

Published

Multifunctional Asynchronous Concurrent Queue

Downloads

60

Readme

kuyruk

ci Status snyk npm downloads/month npm downloads license

Description

kuyruk is a powerful asynchronous queue implementation for managing concurrency and controlling the flow of asynchronous tasks. It supports various modes, such as callbacks, promises, FIFO, LIFO, priority, factor and round-robin, providing flexibility for different use cases.

  • Installation
  • Usage
  • API
  • Licence & copyright

Install

npm i kuyruk

Usage (promise API)

const { Kuyruk } = require('kuyruk');

const queue = new Kuyruk({ concurrency: 3 });

queue
  .success((result) => {
    console.log(result);
  })
  .drain(() => {
    console.log('all done!');
  });

const someAsyncFn = (num) =>
  new Promise((resolve) => {
    setTimeout(() => {
      resolve(num);
    }, 0);
  });

for (let i = 0; i < 10; i++) {
  queue.add(() => someAsyncFn(i));
}

Usage (callback process API)

const { Kuyruk } = require('kuyruk');

const queue = new Kuyruk({ concurrency: 3 });

const someTaskOnCallback = (num, cb) => {
  setTimeout(() => {
    cb(null, num);
  }, 0);
};

queue
  .process(someTaskOnCallback)
  .success((result) => {
    console.log(result);
  })
  .drain(() => {
    console.log('all done!');
  });

for (let i = 0; i < 10; i++) {
  queue.add(i);
}

Usage (asynchronous process API)

const { Kuyruk } = require('kuyruk');

const queue = new Kuyruk({ concurrency: 3 });

const someAsyncTask = (num) => {
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve(num);
    }, 0);
  });
};

queue
  .process(someAsyncTask)
  .success((result) => {
    console.log(result);
  })
  .drain(() => {
    console.log('all done!');
  });

for (let i = 0; i < 10; i++) {
  queue.add(i);
}

Features

  • Concurrency Control: Define the number of tasks (concurrency) that can be processed simultaneously.
  • Queue Size Limit: Specify the maximum number of items the queue can hold (size), providing flexibility in managing task overflow.
  • Task Debouncing: Enable debouncing with a customizable interval and count limit (debounceMode). Tasks can be delayed and bundled to reduce the load on the system.
  • FIFO and LIFO Modes: Supports both FIFO (First-In-First-Out) and LIFO (Last-In-First-Out) task processing, giving you the ability to choose how tasks are prioritized in the queue.
  • Priority-Based Task Scheduling: Tasks can be prioritized within the queue (priorityMode), ensuring that critical tasks are processed first.
  • Round-Robin Scheduling: Distribute tasks across different queues using round-robin mode (roundRobinMode), ensuring equal task distribution.
  • Task Timeout: Set time limits on both task processing (processTimeout) and waiting for tasks to be processed (waitTimeout), allowing tasks to fail gracefully if they take too long.
  • Task Pipelining: The queue supports piping to another queue, allowing tasks to flow from one queue to another for further processing.
  • Pause and Resume: Control the execution of tasks by pausing the queue and resuming it at any time.
  • Task Processing Lifecycle: Customize the task lifecycle using event handlers:
    • onProcess: Define the logic for processing each task.
    • onSuccess: Callback for when a task completes successfully.
    • onFailure: Callback for when a task fails.
    • onDone: Executed after each task finishes, regardless of success or failure.
    • onDrain: Called when the queue has no more tasks to process.
    • onTimeout: Handle task timeout events.
  • Dynamic Channel Creation: Use the channels static method to create multiple queues dynamically with predefined concurrency and size settings.
  • Automatic Task Retry with Debouncing: Retry tasks automatically if debouncing is enabled, minimizing redundant operations during high-load periods.
  • Customizable Task Factor: Assign tasks to specific channels using the factor parameter, which can be helpful for task categorization or grouping.

API

  • Kuyruk()
  • queue#add()
  • queue#pause()
  • queue#resume()
  • queue#clear()
  • queue#pipe()
  • queue#timeout()
  • queue#wait()
  • queue#debounce()
  • queue#process()
  • queue#done()
  • queue#success()
  • queue#failure()
  • queue#drain()
  • queue#fifo()
  • queue#lifo()
  • queue#priority()
  • queue#roundRobin()

Kuyruk({ concurrency: 1 , size: 100 })

Creates a new kuyruk instance.

Arguments:

  • concurrency (optional): Number of tasks that can be processed simultaneously.
  • size (optional): Maximum number of tasks the queue can hold.

queue.add(task, { factor = 0, priority = 0 })

Adds a task to the queue. If the queue is full or paused, the task will wait in the queue.

Arguments:

  • task: The task to be processed, can be a function or any data type.
  • factor (optional): Used for round-robin processing.
  • priority (optional): Task priority, used when the queue is in priority mode.

queue.pause()

Pauses task processing. Tasks currently being processed will not be stopped, but new tasks won't be taken until resumed.


queue.resume()

Resumes task processing after being paused. Tasks in the queue will be processed again.


queue.clear()

Clears the queue of all waiting tasks and resets internal counters.


queue.pipe(destinationQueue)

Pipes the result of the current queue to another queue. This will pass completed tasks from the current queue to the destination queue.

Arguments:

  • destinationQueue: An instance of Kuyruk that will receive the results of completed tasks from the current queue. The tasks are passed to the destination queue for further processing or handling.

queue.timeout(msec, onTimeout)

Sets a timeout for each task in the queue. If a task takes longer than the specified time, it will be interrupted.

Arguments:

  • msec: The time in milliseconds before a task times out.
  • onTimeout (optional): A function to call when a task times out.

queue.wait(msec)

Sets a maximum wait time for tasks in the queue. If a task waits longer than this time without being processed, it will time out.

Arguments:

  • msec: The maximum time in milliseconds a task can wait in the queue.

queue.debounce(count, interval)

Debounces task execution, ensuring that a certain number of tasks (count) are processed within a specific time interval.

Arguments:

  • count: Number of tasks to process before applying the debounce delay.
  • interval: The time interval in milliseconds for the debounce effect.

queue.process(listener)

Defines the function that will process each task. The listener receives the task and a callback to signal completion.

Arguments:

  • listener: The function responsible for processing each task.

queue.done(listener)

Sets a callback to be called when a task is finished (whether successful or failed).

Arguments:

  • listener: The function to call when a task finishes, with arguments err and result.

queue.success(listener)

Defines a callback that is called when a task is successfully processed.

Arguments:

  • listener: The function to call on success, with the task result.

queue.failure(listener)

Defines a callback to handle failed tasks.

Arguments:

  • listener: The function to call on failure, with the task error.

queue.drain(listener)

Sets a function to be called when the queue has processed all tasks.

Arguments:

  • listener: The function to call when the queue is drained.

queue.fifo()

Sets the queue to FIFO (first-in-first-out) mode.


queue.lifo()

Sets the queue to LIFO (last-in-first-out) mode.


queue.priority(flag: boolean)

Enables or disables priority mode. When enabled, tasks with higher priority values will be processed first.

Arguments:

  • flag: Boolean flag to enable or disable priority mode.

queue.roundRobin(flag: boolean)

Enables or disables round-robin mode. Tasks will be processed in a round-robin fashion based on their assigned factor.

Arguments:

  • flag: Boolean flag to enable or disable round-robin mode.

License

MIT