bull-stepfunction
TypeScript icon, indicating that this package has built-in type declarations

1.0.17 • Public • Published

bull-stepfunction

GitHub License GitHub Issues

A Node.js module for controlling queues and jobs using StepFunction JSON format with Bull queues.

Table of Contents

Introduction

bull-stepfunction is a Node.js module that provides the ability to control queues and jobs using StepFunction JSON format. It leverages the power of Bull queues to manage asynchronous tasks and offers an intuitive way to structure job execution using StepFunction-like syntax.

Features

  • Define job sequences using StepFunction JSON format.
  • Integrate with Bull queues for efficient job processing.
  • Improved control over complex job workflows.

Installation

You can install bull-stepfunction using npm:

npm install bull-stepfunction

Usage

const {StepFunction} =require("bull-stepfunction");
const Queue =require("bull");
const path =require("path");

const testjobQ = require("./testJob")
const testjobQ1 = require("./testJob1")
const testjobQ2 = require("./testJob2")

const testQ = new Queue("fetch", "redis://127.0.0.1:6381");
const testQ1 = new Queue("fetch1", "redis://127.0.0.1:6381");
const testQ2 = new Queue("fetch2", "redis://127.0.0.1:6381");


testQ.process(20, testjobQ)
testQ1.process(20, testjobQ1)
testQ2.process(20, testjobQ2)

let sf = new StepFunction(path.join(__dirname, './simple.asl.json'),{testjob:testQ,testjob1:testQ1,testjob2:testQ2},{loging:false,redis:"redis://127.0.0.1:6381"})
sf.init({d:[{ss:"ss"},{dd:"dd"},{ff:"ff"}]})

sf.on('complete',(result)=>{
    console.log("step function process has been finished , final result is :",result)
})

first we import package with

const {StepFunction} =require("bull-stepfunction");

after that we define it with new StepFunction

let sf = new StepFunction(path.join(__dirname, './simple.asl.json'),{testjob:testQ,testjob1:testQ1,testjob2:testQ2},{loging:false,redis:"redis://127.0.0.1:6381"})

this will get three arguments

  • path of stepfunction json
  • the object map job from asl.json to job queue you defined in code
  • redis and loging configuration

after that we init the class with data we want to pass to it

sf.init({d:[{ss:"ss"},{dd:"dd"},{ff:"ff"}]})

and we could run code in complete event

sf.on('complete',({workflowId,data})=>{
    console.log("step function process has been finished ")
})

Examples

For more examples, please check the examples directory.

Contributing

Contributions are welcome! Please read the Contributing Guidelines for more information.

Package Sidebar

Install

npm i bull-stepfunction

Weekly Downloads

5

Version

1.0.17

License

ISC

Unpacked Size

192 kB

Total Files

31

Last publish

Collaborators

  • naimi.92