@node-ts/bus-postgres

A Postgres persistence adapter for workflow storage in @node-ts/bus-workflow.

Downloads in past

Stats

StarsIssuesVersionUpdatedCreatedSize
@node-ts/bus-postgres
232241.0.1517 hours ago4 years agoMinified + gzip package size for @node-ts/bus-postgres in KB

Readme

@node-ts/bus-postgres
A Postgres based persistence for workflow storage in @node-ts/bus
šŸ”„ View our docs at https://bus.node-ts.com šŸ”„
šŸ¤” Have a question? Join our Discord šŸ¤”

Installation

Install all packages and their dependencies
npm install @node-ts/bus-postgres

Configure a new Postgres persistence and register it with Bus:
import { Bus } from '@node-ts/bus-core'
import { PostgresPersistence, PostgresConfiguration } from '@node-ts/bus-postgres'

const configuration: PostgresConfiguration = {
  connection: {
    connectionString: 'postgres://postgres:password@localhost:5432/postgres'
  },
  schemaName: 'workflows'
}
const postgresPersistence = new PostgresPersistence(configuration)

// Configure bus to use postgres as a persistence
const run = async () => {
  await Bus
    .configure()
    .withPersistence(postgresPersistence)
    .initialize()
}
run.then(() => void)

Configuration Options

The Postgres persistence has the following configuration:
  • connection (required) Connection pool settings for the application to connect to the postgres instance
  • schemaName (required) The schema name to create workflow tables under. This can be the 'public' default from postgres, but it's recommended to use 'workflows' or something similar to group all workflow concerns in the one place. This schema will be created if it doesn't already exist.

Development

Local development can be done with the aid of docker to run the required infrastructure. To do so, run:
docker run --name bus-postgres -e POSTGRES_PASSWORD=password -p 6432:5432 -d postgres