configuring_event_bus_adapters
Configuring EventBus adapters
MemoryEventBusAdapter
To use the MemoryEventBusAdapter you only need to create instance of it.
import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/memory-event-bus-adapter";
const eventBusAdapter = new MemoryEventBusAdapter();
You can also provide an EventEmitter that will be used for dispatching the events in memory:
import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/memory-event-bus-adapter";
import { EventEmitter } from "node:events";
const eventEmitter = new EventEmitter<any>();
const eventBusAdapter = new MemoryEventBusAdapter(eventEmitter);
info
MemoryEventBusAdapter lets you test your app without external dependencies like Redis, ideal for local development, unit tests, integration tests and fast E2E test for the backend application.
RedisPubSubEventBusAdapter
To use the RedisPubSubEventBusAdapter, you'll need to:
- We recommend using
SuperJsonSerdeAdapterfor this purpose
import { RedisPubSubEventBusAdapter } from "@daiso-tech/core/event-bus/redis-pub-sub-event-bus-adapter";
import { Serde } from "@daiso-tech/core/serde";
import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/super-json-serde-adapter";
import Redis from "ioredis";
const client = new Redis("YOUR_REDIS_CONNECTION_STRING");
const serde = new Serde(new SuperJsonSerdeAdapter());
const eventBusAdapter = new RedisPubSubEventBusAdapter({
client,
serde,
});
NoOpEventBusAdapter
The NoOpEventBusAdapter is a no-operation implementation, it performs no actions when called.
import { NoOpEventBusAdapter } from "@daiso-tech/core/event-bus/no-op-event-bus-adapter";
const noEventBusAdapter = new NoOpEventBusAdapter();
info
The NoOpEventBusAdapter is useful when you want to mock out or disable your EventBus class.
Further information
For further information refer to @daiso-tech/core/event-bus API docs.