integreat-io / integreat-transporter-bull

Bull queue transporter for Integreat
Other
1 stars 0 forks source link

Bull Queue Transporter for Integreat (Redis backed queue)

This implementation is based on Bull.

npm Version Maintainability

Getting started

Prerequisits

Requires node v18 and Integreat v1.0.

Installing and using

Install from npm:

npm install integreat-transporter-bull

Example of use:

import Integreat from 'integreat'
import bullTransporter from 'integreat-transport-bull'
import defs from './config'

const great = Integreat.create(defs, {
  transporters: { bull: bullTransporter() },
})

// ... and then dispatch actions as usual

Example source configuration:

{
  id: 'store',
  transporter: 'bull',
  auth: true,
  endpoints: [
    {
      options: {
        queueId: 'bull-queue',
        maxConcurrency: 5,
      }
    }
  ]
}

Note: In the example above, auth is set to true, to let Integreat know we don't require any authenticaton for this service. This is the correct way to do it when you have a Redis database without authentication or when you include the password in the url (this is not recommended, although it is a normal convention for Redis). You may, however, pass a Redis username and/or password through an authenticator set on the auth prop of the service defintion. The expected props are key for the username and secret for the password. You may also specify the username and password on the options object (see below).

Available properties for the options object:

The available properties for the redis options object are as follow:

You may choose to set the uri or specify the individual properties.

Dispatching an action to the queue

When an action is dispatched in Integreat, in a setup with a queue, any action with meta.queue set to true will be passed to the queue. When an action is pulled from the queue, it is again dispatched to the queue service, if it is listening.

meta.queue may also be a Unix timestamp (millieseconds since epoc, aka 1970-01-01), in which case the action will be delayed until the timestamp is reached, and then dispatched as normal.

Debugging

Run Integreat with env variable DEBUG=integreat:transporter:bull, to receive debug messages.

Running the tests

The tests can be run with npm test.

Contributing

Please read CONTRIBUTING for details on our code of conduct, and the process for submitting pull requests.

License

This project is licensed under the ISC License - see the LICENSE file for details.