@aleios-cloud/eventbridge-toolbox
TypeScript icon, indicating that this package has built-in type declarations

0.2.0 • Public • Published

eventbridge-toolbox

Eventbridge Toolbox is a lightweight eventbridge adapter that can help you enforce good practicies in your event driven architectures.

Eventbridge Contracts

Within event-driven architectures, events facilitate communication between loosely connected services in an application. EventBridge is AWS's tool for implementing asynchronous event-driven workflows.

Event emitters are responsible for broadcasting events to event channels, while event consumers are responsible for executing business logic whenever they encounter a relevant event.

EventBridge contracts ensure a stable and reliable interaction emitters and consumers. These contract acts as a guiding agreement which guarantees that emitters' published events will consistently trigger the corresponding business logic on the consumer side.

Creating an EventBridge contract

To create an EventBridge Contract, define a type for your contract. Your contract type must extend the interface Contract, with Contract being importable from the eventbridge-toolbox package. This typing will force you to add an event version to your contract. If you ever alter your contract (for instance, to add a new field), please create a copy of the contract in a new file, and give it a version number higher that you previous version of your contract. The detailType field stays consistent, and allows you to link together all versions of your contract.

Create an Contract type:

export interface PersonRegisteredContractV1 extends Contract {
  version: 1;
  detailType: "PersonRegisteredContract";
  detail: {
    firstName: string;
    lastName: string;
  };
}

As version and detailType are set as constants in the type, when we create an object of type PersonRegisteredContractV1, the version and detailType must match what is defined here otherwise you will see an error.

Create an Contract type:

const ourEvent: PersonRegisteredContractV1 = {
  version: 1;
  detailType: "PersonRegisteredContract";
  detail: {
    firstName: 'testFirstName';
    lastName: 'testLastName';
  };
}

Creating an Event

The Event class bakes in a lot of best practices. To instantiate an eventbridge-toolbox event, create a new Event and pass in your event detail and event detail type.

You can see an example below:

import Event from "@eventbridge-toolbox";

const loggedInData: LoggedInContractV1 = {
  version: 1;
  detailType: "LoggedInContract";
  detail: {
    firstName: "Lucy",
    lastName: "Example",
    timeLoggedIn: "2023-01-01T13:00:00.000Z",
  };
}


const myEvent = new Event(loggedInData);

//equal to the 'loggedInData' object
const myEventDetail = myEvent.getDetail();

//equal to 'loggedIn'
const myEventDetailType = myEvent.getDetailType():

You can then publish your event by calling the publish function, passing in the ARN of the EventBus which you want to publish your event to and your event source.

You can see an example below for the scenario where the event source is a lambda:

const EVENT_BUS_ARN = getEnvVariable("EVENT_BUS_ARN");

await myEvent.publish(EVENT_BUS_ARN, "lambda.amazonaws.com");

Key Features

  • An event construct
  • Contracts to enforce types between producers and consumers
  • Event versioning

Getting Started

Prerequisites

Installation

With npm:

npm install --save-dev eventbridge-toolbox

With yarn:

yarn add -D eventbridge-toolbox

With pnpm:

pnpm add -D eventbridge-toolbox

Usage

User Documentation

Full docs are available at ...

Contributors

Luke Yianni
Luke Yianni
April Bates
April Bates
Ryan Schuller
Ryan Schuller

Readme

Keywords

none

Package Sidebar

Install

npm i @aleios-cloud/eventbridge-toolbox

Weekly Downloads

4

Version

0.2.0

License

ISC

Unpacked Size

15.5 kB

Total Files

19

Last publish

Collaborators

  • lukey-aleios
  • aiden-walton
  • ryanschuller
  • aleios-npm