TS-simple-event-bus
A simple event bus that implements a pub / sub pattern. Fully typed.
Version 2.XX
Version 2 adds a typing that is defined once at the bus initialisation.
Use cases
Simple publish and subscribe:
import { EventBus, Callback } from "ts-simple-event-bus";
import { uuid } from "uuid";
type EventBusTyping = {
queue: {
a: string;
b: number;
}
};
const bus = new EventBus<EventBusTyping>(uuid);
bus.subscribe({ queue: "queue", callback: (message) => {
console.log(message.id, message.a, message.b);
} });
bus.publish({ queue: "queue", { a: "a", b: 1 } });
Waiting for a response:
type EventBusTyping = {
queue: {
a: string;
b: number;
}
};
const bus = new EventBus<EventBusTyping>(idGenerator);
const responseQueueName = "event-response";
bus.subscribe({
queue: "event-request",
callback: (msg, id) => {
bus.publish({ queue: responseQueueName, message: { event: "response" }, id });
},
});
const result = await bus.publishAndWaitForResponse({
queue: "event-request",
responseQueue: responseQueueName,
message: { event: "request" },
timeout: 1000,
});
Version 1.XX
Use cases
Simple publish and subscribe:
import { EventBus, Callback } from "ts-simple-event-bus";
import { uuid } from "uuid";
type MessagePayload = {
a: string;
b: number;
};
const bus = new EventBus(uuid);
const callback: Callback<MessagePayload> = (message) => {
console.log(message.id, message.a, message.b);
};
bus.subscribe<MessagePayload>({ queue: "queue", callback });
bus.publish<MessagePayload>({ queue: "queue", { a: "a", b: 1 } });
Waiting for a response:
const bus = new EventBus(idGenerator);
const responseQueueName = "event-response";
bus.subscribe({
queue: "event-request",
callback: (msg, id) => {
bus.publish({ queue: responseQueueName, message: { event: "response" }, id });
},
});
const result = await bus.publishAndWaitForResponse({
queue: "event-request",
responseQueue: responseQueueName,
message: { event: "request" },
timeout: 1000,
});