bemoore-be-ticketing-common 3.0.6 → 3.0.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,13 @@
1
+ import { Message, Stan } from "node-nats-streaming";
2
+ import { IEvent } from "../models/interfaces";
3
+ export declare abstract class Listener<T extends IEvent> {
4
+ abstract subject: T['subject'];
5
+ abstract queueGroupName: string;
6
+ abstract onMessage(data: T['data'], msg: Message): void;
7
+ private client;
8
+ protected ackWait: number;
9
+ constructor(client: Stan);
10
+ getSubscriptionOptions(): import("node-nats-streaming").SubscriptionOptions;
11
+ listen(): void;
12
+ parseMessage(msg: Message): any;
13
+ }
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Listener = void 0;
4
+ class Listener {
5
+ constructor(client) {
6
+ this.ackWait = 5 * 1000;
7
+ this.client = client;
8
+ }
9
+ getSubscriptionOptions() {
10
+ return this.client
11
+ .subscriptionOptions()
12
+ .setDeliverAllAvailable()
13
+ .setManualAckMode(true)
14
+ .setAckWait(this.ackWait)
15
+ .setDurableName(this.queueGroupName);
16
+ }
17
+ listen() {
18
+ const sub = this.client.subscribe(this.subject, this.queueGroupName, this.getSubscriptionOptions());
19
+ sub.on('message', (msg) => {
20
+ console.log(`Message received: ${this.subject} / ${this.queueGroupName}`);
21
+ const parsed = this.parseMessage(msg);
22
+ this.onMessage(parsed, msg);
23
+ });
24
+ }
25
+ parseMessage(msg) {
26
+ const data = msg.getData();
27
+ return typeof data === 'string'
28
+ ? JSON.parse(data)
29
+ : JSON.parse(data.toString("utf8"));
30
+ }
31
+ }
32
+ exports.Listener = Listener;
@@ -0,0 +1,8 @@
1
+ import { Stan } from "node-nats-streaming";
2
+ import { IEvent } from "../models/interfaces";
3
+ export declare abstract class Publisher<T extends IEvent> {
4
+ abstract subject: T['subject'];
5
+ private client;
6
+ constructor(client: Stan);
7
+ publish(data: T['data']): Promise<void>;
8
+ }
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Publisher = void 0;
4
+ class Publisher {
5
+ constructor(client) {
6
+ this.client = client;
7
+ }
8
+ publish(data) {
9
+ return new Promise((resolve, reject) => {
10
+ this.client.publish(this.subject, JSON.stringify(data), (err) => {
11
+ if (err) {
12
+ return reject(err);
13
+ }
14
+ console.log(`Event published to subject ${this.subject}`);
15
+ resolve();
16
+ });
17
+ });
18
+ }
19
+ }
20
+ exports.Publisher = Publisher;
package/dist/index.d.ts CHANGED
@@ -8,3 +8,7 @@ export * from './middlewares/current-user';
8
8
  export * from './middlewares/error-handler';
9
9
  export * from './middlewares/require-auth';
10
10
  export * from './middlewares/validate-request';
11
+ export * from './events/base-listener';
12
+ export * from './events/base-publisher';
13
+ export * from './models/enums';
14
+ export * from './models/interfaces';
package/dist/index.js CHANGED
@@ -24,3 +24,7 @@ __exportStar(require("./middlewares/current-user"), exports);
24
24
  __exportStar(require("./middlewares/error-handler"), exports);
25
25
  __exportStar(require("./middlewares/require-auth"), exports);
26
26
  __exportStar(require("./middlewares/validate-request"), exports);
27
+ __exportStar(require("./events/base-listener"), exports);
28
+ __exportStar(require("./events/base-publisher"), exports);
29
+ __exportStar(require("./models/enums"), exports);
30
+ __exportStar(require("./models/interfaces"), exports);
@@ -6,6 +6,7 @@ const errorHandler = (err, req, res, next) => {
6
6
  if (err instanceof custom_error_1.CustomError) {
7
7
  return res.status(err.statusCode).send({ errors: err.serializeErrors() });
8
8
  }
9
+ console.error(err);
9
10
  res.status(400).send({
10
11
  errors: [{ message: 'Something went wrong' }],
11
12
  });
@@ -0,0 +1,4 @@
1
+ export declare enum ENUM_SUBJECTS {
2
+ TICKET_CREATED = "ticket:created",
3
+ TICKET_UPDATED = "ticket:updated"
4
+ }
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ENUM_SUBJECTS = void 0;
4
+ var ENUM_SUBJECTS;
5
+ (function (ENUM_SUBJECTS) {
6
+ ENUM_SUBJECTS["TICKET_CREATED"] = "ticket:created";
7
+ ENUM_SUBJECTS["TICKET_UPDATED"] = "ticket:updated";
8
+ })(ENUM_SUBJECTS || (exports.ENUM_SUBJECTS = ENUM_SUBJECTS = {}));
@@ -0,0 +1,23 @@
1
+ import { ENUM_SUBJECTS } from "./enums";
2
+ export interface IEvent {
3
+ subject: ENUM_SUBJECTS;
4
+ data: any;
5
+ }
6
+ export interface ITicketCreatedEvent {
7
+ subject: ENUM_SUBJECTS.TICKET_CREATED;
8
+ data: {
9
+ id: string;
10
+ title: string;
11
+ price: number;
12
+ userId: string;
13
+ };
14
+ }
15
+ export interface ITicketUPdated {
16
+ subject: ENUM_SUBJECTS.TICKET_UPDATED;
17
+ data: {
18
+ id: string;
19
+ title: string;
20
+ price: number;
21
+ userId: string;
22
+ };
23
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bemoore-be-ticketing-common",
3
- "version": "3.0.6",
3
+ "version": "3.0.13",
4
4
  "description": "",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",
@@ -26,6 +26,7 @@
26
26
  "cookie-session": "^2.1.0",
27
27
  "express": "^4.21.0",
28
28
  "express-validator": "^7.2.0",
29
- "jsonwebtoken": "^9.0.2"
29
+ "jsonwebtoken": "^9.0.2",
30
+ "node-nats-streaming": "^0.3.2"
30
31
  }
31
32
  }