sqs-consumer
Version:
Build SQS-based Node applications without the boilerplate
56 lines (49 loc) • 1.69 kB
text/typescript
import { EventEmitter } from "node:events";
import { logger } from "./logger.js";
import { Events, QueueMetadata } from "./types.js";
export class TypedEventEmitter extends EventEmitter {
protected queueUrl?: string;
/**
* @param queueUrl - The URL of the SQS queue this emitter is associated with
*/
constructor(queueUrl?: string) {
super();
this.queueUrl = queueUrl;
}
/**
* Trigger a listener on all emitted events
* @param event The name of the event to listen to
* @param listener A function to trigger when the event is emitted
*/
on<E extends keyof Events>(
event: E,
listener: (...args: [...Events[E], QueueMetadata]) => void,
): this {
return super.on(event, listener);
}
/**
* Trigger a listener only once for an emitted event
* @param event The name of the event to listen to
* @param listener A function to trigger when the event is emitted
*/
once<E extends keyof Events>(
event: E,
listener: (...args: [...Events[E], QueueMetadata]) => void,
): this {
return super.once(event, listener);
}
/**
* Emits an event with the provided arguments and adds queue metadata
* @param event The name of the event to emit
* @param args The arguments to pass to the event listeners
* @returns {boolean} Returns true if the event had listeners, false otherwise
* @example
* // Inside a method:
* this.emit('message_received', message);
*/
emit<E extends keyof Events>(event: E, ...args: Events[E]): boolean {
const metadata: QueueMetadata = { queueUrl: this.queueUrl };
logger.debug(event, ...args, metadata);
return super.emit(event, ...args, metadata);
}
}