@eratu/common 1.0.15 → 1.0.17
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.
- package/package.json +11 -3
- package/build/enum/roles.d.ts +0 -6
- package/build/enum/roles.js +0 -10
- package/build/errors/bad-request-error.d.ts +0 -9
- package/build/errors/bad-request-error.js +0 -16
- package/build/errors/custom-error.d.ts +0 -8
- package/build/errors/custom-error.js +0 -10
- package/build/errors/database-connection-error.d.ts +0 -9
- package/build/errors/database-connection-error.js +0 -16
- package/build/errors/not-authorized-error.d.ts +0 -8
- package/build/errors/not-authorized-error.js +0 -15
- package/build/errors/not-found-error.d.ts +0 -8
- package/build/errors/not-found-error.js +0 -15
- package/build/errors/request-validation-error.d.ts +0 -14
- package/build/errors/request-validation-error.js +0 -22
- package/build/events/event-types/auth/author-created-event.d.ts +0 -12
- package/build/events/event-types/auth/author-created-event.js +0 -2
- package/build/events/event-types/auth/author-deleted-event.d.ts +0 -10
- package/build/events/event-types/auth/author-deleted-event.js +0 -2
- package/build/events/event-types/auth/author-signed-in-event.d.ts +0 -12
- package/build/events/event-types/auth/author-signed-in-event.js +0 -2
- package/build/events/event-types/auth/author-signed-out-event.d.ts +0 -11
- package/build/events/event-types/auth/author-signed-out-event.js +0 -2
- package/build/events/event-types/auth/author-signed-up-event.d.ts +0 -13
- package/build/events/event-types/auth/author-signed-up-event.js +0 -2
- package/build/events/event-types/auth/author-updated-event.d.ts +0 -12
- package/build/events/event-types/auth/author-updated-event.js +0 -2
- package/build/events/event-types/auth/reader-created-event.d.ts +0 -12
- package/build/events/event-types/auth/reader-created-event.js +0 -2
- package/build/events/event-types/auth/reader-deleted-event.d.ts +0 -10
- package/build/events/event-types/auth/reader-deleted-event.js +0 -2
- package/build/events/event-types/auth/reader-signed-in-event.d.ts +0 -12
- package/build/events/event-types/auth/reader-signed-in-event.js +0 -2
- package/build/events/event-types/auth/reader-signed-out-event.d.ts +0 -11
- package/build/events/event-types/auth/reader-signed-out-event.js +0 -2
- package/build/events/event-types/auth/reader-signed-up-event.d.ts +0 -13
- package/build/events/event-types/auth/reader-signed-up-event.js +0 -2
- package/build/events/event-types/auth/reader-updated-event.d.ts +0 -12
- package/build/events/event-types/auth/reader-updated-event.js +0 -2
- package/build/events/event-types/books/book-created-event.d.ts +0 -11
- package/build/events/event-types/books/book-created-event.js +0 -2
- package/build/events/event-types/books/book-deleted-event.d.ts +0 -10
- package/build/events/event-types/books/book-deleted-event.js +0 -2
- package/build/events/event-types/books/book-updated-event.d.ts +0 -11
- package/build/events/event-types/books/book-updated-event.js +0 -2
- package/build/events/event-types/orders/order-created-event.d.ts +0 -12
- package/build/events/event-types/orders/order-created-event.js +0 -2
- package/build/events/listeners/base-listener.d.ts +0 -23
- package/build/events/listeners/base-listener.js +0 -96
- package/build/events/publishers/base-publisher.d.ts +0 -14
- package/build/events/publishers/base-publisher.js +0 -27
- package/build/events/streams.d.ts +0 -7
- package/build/events/streams.js +0 -11
- package/build/events/subjects.d.ts +0 -22
- package/build/events/subjects.js +0 -31
- package/build/index.d.ts +0 -32
- package/build/index.js +0 -49
- package/build/middlewares/current-user.d.ts +0 -29
- package/build/middlewares/current-user.js +0 -28
- package/build/middlewares/error-handler.d.ts +0 -2
- package/build/middlewares/error-handler.js +0 -13
- package/build/middlewares/require-auth.d.ts +0 -2
- package/build/middlewares/require-auth.js +0 -11
- package/build/middlewares/validation.d.ts +0 -3
- package/build/middlewares/validation.js +0 -57
- package/build/nats-wrapper.d.ts +0 -17
- package/build/nats-wrapper.js +0 -80
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@eratu/common",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.17",
|
|
4
4
|
"description": "A package for shared code across microservices",
|
|
5
5
|
"main": "./build/index.js",
|
|
6
6
|
"types": "./build/index.d.ts",
|
|
@@ -10,14 +10,20 @@
|
|
|
10
10
|
"scripts": {
|
|
11
11
|
"clean": "del-cli ./build/*",
|
|
12
12
|
"build": "npm run clean && tsc",
|
|
13
|
-
"pub": "git add . && git commit -m \"Updates\" && npm version patch && npm publish"
|
|
13
|
+
"pub": "git add . && git commit -m \"Updates\" && npm version patch && npm publish",
|
|
14
|
+
"test": "jest --forceExit --detectOpenHandles",
|
|
15
|
+
"test:cov": "jest --coverage --forceExit --detectOpenHandles"
|
|
14
16
|
},
|
|
15
17
|
"keywords": [],
|
|
16
18
|
"author": "",
|
|
17
19
|
"license": "ISC",
|
|
18
20
|
"type": "commonjs",
|
|
19
21
|
"devDependencies": {
|
|
22
|
+
"@types/jest": "^29.5.14",
|
|
23
|
+
"@types/node": "^22.13.1",
|
|
20
24
|
"del-cli": "^6.0.0",
|
|
25
|
+
"jest": "^29.7.0",
|
|
26
|
+
"ts-jest": "^29.2.5",
|
|
21
27
|
"typescript": "^5.7.3"
|
|
22
28
|
},
|
|
23
29
|
"dependencies": {
|
|
@@ -28,7 +34,9 @@
|
|
|
28
34
|
"cookie-session": "^2.1.0",
|
|
29
35
|
"express": "^4.21.2",
|
|
30
36
|
"express-validator": "^7.2.1",
|
|
37
|
+
"ioredis": "^5.8.2",
|
|
31
38
|
"jsonwebtoken": "^9.0.2",
|
|
32
|
-
"nats": "^2.29.3"
|
|
39
|
+
"nats": "^2.29.3",
|
|
40
|
+
"node-cache": "^5.1.2"
|
|
33
41
|
}
|
|
34
42
|
}
|
package/build/enum/roles.d.ts
DELETED
package/build/enum/roles.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.UserRoles = void 0;
|
|
4
|
-
var UserRoles;
|
|
5
|
-
(function (UserRoles) {
|
|
6
|
-
UserRoles[UserRoles["superAdmin"] = 1] = "superAdmin";
|
|
7
|
-
UserRoles[UserRoles["admin"] = 2] = "admin";
|
|
8
|
-
UserRoles[UserRoles["author"] = 3] = "author";
|
|
9
|
-
UserRoles[UserRoles["reader"] = 4] = "reader";
|
|
10
|
-
})(UserRoles || (exports.UserRoles = UserRoles = {}));
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BadRequestError = void 0;
|
|
4
|
-
const custom_error_1 = require("./custom-error");
|
|
5
|
-
class BadRequestError extends custom_error_1.CustomError {
|
|
6
|
-
constructor(message) {
|
|
7
|
-
super(message);
|
|
8
|
-
this.message = message;
|
|
9
|
-
this.statusCode = 400;
|
|
10
|
-
Object.setPrototypeOf(this, BadRequestError.prototype);
|
|
11
|
-
}
|
|
12
|
-
serializeErrors() {
|
|
13
|
-
return [{ message: this.message }];
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
exports.BadRequestError = BadRequestError;
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CustomError = void 0;
|
|
4
|
-
class CustomError extends Error {
|
|
5
|
-
constructor(message) {
|
|
6
|
-
super(message);
|
|
7
|
-
Object.setPrototypeOf(this, CustomError.prototype);
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
exports.CustomError = CustomError;
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DatabaseConnectionError = void 0;
|
|
4
|
-
const custom_error_1 = require("./custom-error");
|
|
5
|
-
class DatabaseConnectionError extends custom_error_1.CustomError {
|
|
6
|
-
constructor() {
|
|
7
|
-
super('Error connecting to db');
|
|
8
|
-
this.statusCode = 500;
|
|
9
|
-
this.reason = 'Error connecting to database';
|
|
10
|
-
Object.setPrototypeOf(this, DatabaseConnectionError.prototype);
|
|
11
|
-
}
|
|
12
|
-
serializeErrors() {
|
|
13
|
-
return [{ message: this.reason }];
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
exports.DatabaseConnectionError = DatabaseConnectionError;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NotAuthorizedError = void 0;
|
|
4
|
-
const custom_error_1 = require("./custom-error");
|
|
5
|
-
class NotAuthorizedError extends custom_error_1.CustomError {
|
|
6
|
-
constructor() {
|
|
7
|
-
super('Not Authorized');
|
|
8
|
-
this.statusCode = 401;
|
|
9
|
-
Object.setPrototypeOf(this, NotAuthorizedError.prototype);
|
|
10
|
-
}
|
|
11
|
-
serializeErrors() {
|
|
12
|
-
return [{ message: 'Not authorized' }];
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
exports.NotAuthorizedError = NotAuthorizedError;
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NotFoundError = void 0;
|
|
4
|
-
const custom_error_1 = require("./custom-error");
|
|
5
|
-
class NotFoundError extends custom_error_1.CustomError {
|
|
6
|
-
constructor() {
|
|
7
|
-
super('Route not found');
|
|
8
|
-
this.statusCode = 404;
|
|
9
|
-
Object.setPrototypeOf(this, NotFoundError.prototype);
|
|
10
|
-
}
|
|
11
|
-
serializeErrors() {
|
|
12
|
-
return [{ message: 'Not Found' }];
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
exports.NotFoundError = NotFoundError;
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { ValidationError } from 'express-validator';
|
|
2
|
-
import { CustomError } from './custom-error';
|
|
3
|
-
export declare class RequestValidationError extends CustomError {
|
|
4
|
-
errors: ValidationError[];
|
|
5
|
-
statusCode: number;
|
|
6
|
-
constructor(errors: ValidationError[]);
|
|
7
|
-
serializeErrors(): ({
|
|
8
|
-
message: any;
|
|
9
|
-
field: string;
|
|
10
|
-
} | {
|
|
11
|
-
message: any;
|
|
12
|
-
field?: undefined;
|
|
13
|
-
})[];
|
|
14
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.RequestValidationError = void 0;
|
|
4
|
-
const custom_error_1 = require("./custom-error");
|
|
5
|
-
class RequestValidationError extends custom_error_1.CustomError {
|
|
6
|
-
constructor(errors) {
|
|
7
|
-
super('Invalid request parameters');
|
|
8
|
-
this.errors = errors;
|
|
9
|
-
this.statusCode = 400;
|
|
10
|
-
// Only because we are extending a built in class
|
|
11
|
-
Object.setPrototypeOf(this, RequestValidationError.prototype);
|
|
12
|
-
}
|
|
13
|
-
serializeErrors() {
|
|
14
|
-
return this.errors.map((err) => {
|
|
15
|
-
if (err.type === 'field') {
|
|
16
|
-
return { message: err.msg, field: err.path };
|
|
17
|
-
}
|
|
18
|
-
return { message: err.msg };
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
exports.RequestValidationError = RequestValidationError;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface AuthorCreatedEvent {
|
|
4
|
-
subject: Subjects.AuthorCreated;
|
|
5
|
-
stream: Streams.AuthorServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
firstName: string;
|
|
9
|
-
lastName: string;
|
|
10
|
-
email: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface AuthorSignedInEvent {
|
|
4
|
-
subject: Subjects.AuthorSignedIn;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
userId: string;
|
|
8
|
-
email: string;
|
|
9
|
-
sessionId: string;
|
|
10
|
-
signedInAt: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface AuthorSignedOutEvent {
|
|
4
|
-
subject: Subjects.AuthorSignedOut;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
userId: string;
|
|
8
|
-
sessionId: string;
|
|
9
|
-
signedOutAt: string;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface AuthorSignedUpEvent {
|
|
4
|
-
subject: Subjects.AuthorSignedUp;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
email: string;
|
|
9
|
-
firstName: string;
|
|
10
|
-
lastName: string;
|
|
11
|
-
createdAt: string;
|
|
12
|
-
};
|
|
13
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface AuthorUpdatedEvent {
|
|
4
|
-
subject: Subjects.AuthorUpdated;
|
|
5
|
-
stream: Streams.AuthorServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
firstName: string;
|
|
9
|
-
lastName: string;
|
|
10
|
-
email: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface ReaderCreatedEvent {
|
|
4
|
-
subject: Subjects.ReaderCreated;
|
|
5
|
-
stream: Streams.ReaderServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
firstName: string;
|
|
9
|
-
lastName: string;
|
|
10
|
-
email: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface ReaderSignedInEvent {
|
|
4
|
-
subject: Subjects.ReaderSignedIn;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
userId: string;
|
|
8
|
-
email: string;
|
|
9
|
-
sessionId: string;
|
|
10
|
-
signedInAt: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface ReaderSignedOutEvent {
|
|
4
|
-
subject: Subjects.ReaderSignedOut;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
userId: string;
|
|
8
|
-
sessionId: string;
|
|
9
|
-
signedOutAt: string;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface ReaderSignedUpEvent {
|
|
4
|
-
subject: Subjects.ReaderSignedUp;
|
|
5
|
-
stream: Streams.AuthServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
email: string;
|
|
9
|
-
firstName: string;
|
|
10
|
-
lastName: string;
|
|
11
|
-
createdAt: string;
|
|
12
|
-
};
|
|
13
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface ReaderUpdatedEvent {
|
|
4
|
-
subject: Subjects.ReaderUpdated;
|
|
5
|
-
stream: Streams.ReaderServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
firstName: string;
|
|
9
|
-
lastName: string;
|
|
10
|
-
email: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface BookCreatedEvent {
|
|
4
|
-
subject: Subjects.BookCreated;
|
|
5
|
-
stream: Streams.BookServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
version: number;
|
|
9
|
-
title: string;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface BookUpdatedEvent {
|
|
4
|
-
subject: Subjects.BookUpdated;
|
|
5
|
-
stream: Streams.BookServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
version: number;
|
|
9
|
-
title: string;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Streams } from "../../streams";
|
|
2
|
-
import { Subjects } from "../../subjects";
|
|
3
|
-
export interface OrderCreatedEvent {
|
|
4
|
-
subject: Subjects.OrderCreated;
|
|
5
|
-
stream: Streams.OrderServiceStream;
|
|
6
|
-
data: {
|
|
7
|
-
id: string;
|
|
8
|
-
version: number;
|
|
9
|
-
userId: string;
|
|
10
|
-
expiresAt: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { JetStreamManager, JsMsg, Consumer, JetStreamClient } from "nats";
|
|
2
|
-
interface Event {
|
|
3
|
-
subject: string;
|
|
4
|
-
stream: string;
|
|
5
|
-
data: any;
|
|
6
|
-
}
|
|
7
|
-
export declare abstract class Listener<T extends Event> {
|
|
8
|
-
abstract subject: T["subject"];
|
|
9
|
-
abstract stream: T["stream"];
|
|
10
|
-
abstract durableName: string;
|
|
11
|
-
abstract onMessage(data: T["data"], msg: JsMsg): void;
|
|
12
|
-
protected jsm: JetStreamManager;
|
|
13
|
-
protected js: JetStreamClient;
|
|
14
|
-
protected consumer: Consumer;
|
|
15
|
-
protected ackWait: number;
|
|
16
|
-
protected codec: import("nats").Codec<unknown>;
|
|
17
|
-
constructor(js: JetStreamClient, jsm: JetStreamManager);
|
|
18
|
-
private waitForStream;
|
|
19
|
-
private createConsumerIfNotExists;
|
|
20
|
-
listen(): Promise<void>;
|
|
21
|
-
private parseMessage;
|
|
22
|
-
}
|
|
23
|
-
export {};
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __asyncValues = (this && this.__asyncValues) || function (o) {
|
|
12
|
-
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
13
|
-
var m = o[Symbol.asyncIterator], i;
|
|
14
|
-
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
|
|
15
|
-
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
|
|
16
|
-
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
|
|
17
|
-
};
|
|
18
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
exports.Listener = void 0;
|
|
20
|
-
const nats_1 = require("nats");
|
|
21
|
-
class Listener {
|
|
22
|
-
constructor(js, jsm) {
|
|
23
|
-
this.ackWait = 5 * 1000;
|
|
24
|
-
this.codec = (0, nats_1.JSONCodec)();
|
|
25
|
-
this.jsm = jsm;
|
|
26
|
-
this.js = js;
|
|
27
|
-
}
|
|
28
|
-
waitForStream() {
|
|
29
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
30
|
-
let retryCount = 0;
|
|
31
|
-
while (true) {
|
|
32
|
-
try {
|
|
33
|
-
yield this.jsm.streams.info(this.stream);
|
|
34
|
-
console.log(`✅ Stream "${this.stream}" is ready`);
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
catch (_a) {
|
|
38
|
-
console.log(`⏳ Waiting for stream "${this.stream}"...`);
|
|
39
|
-
yield new Promise((res) => setTimeout(res, 2000));
|
|
40
|
-
}
|
|
41
|
-
retryCount++;
|
|
42
|
-
if (retryCount > 5) {
|
|
43
|
-
console.error(`❌ Stream "${this.stream}" is not ready after 5 attempts`);
|
|
44
|
-
throw new Error(`Stream "${this.stream}" is not ready`);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
createConsumerIfNotExists() {
|
|
50
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
51
|
-
yield this.waitForStream();
|
|
52
|
-
// Ensure durable consumer exists
|
|
53
|
-
try {
|
|
54
|
-
yield this.jsm.consumers.info(this.stream, this.durableName);
|
|
55
|
-
}
|
|
56
|
-
catch (_a) {
|
|
57
|
-
yield this.jsm.consumers.add(this.stream, {
|
|
58
|
-
durable_name: this.durableName,
|
|
59
|
-
ack_policy: nats_1.AckPolicy.Explicit,
|
|
60
|
-
ack_wait: this.ackWait * 1000000, // nanoseconds
|
|
61
|
-
filter_subject: this.subject,
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
// Get the consumer object
|
|
65
|
-
this.consumer = yield this.js.consumers.get(this.stream, this.durableName);
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
listen() {
|
|
69
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
-
var _a, e_1, _b, _c;
|
|
71
|
-
yield this.createConsumerIfNotExists();
|
|
72
|
-
const messages = yield this.consumer.consume();
|
|
73
|
-
try {
|
|
74
|
-
for (var _d = true, messages_1 = __asyncValues(messages), messages_1_1; messages_1_1 = yield messages_1.next(), _a = messages_1_1.done, !_a; _d = true) {
|
|
75
|
-
_c = messages_1_1.value;
|
|
76
|
-
_d = false;
|
|
77
|
-
const msg = _c;
|
|
78
|
-
const data = this.parseMessage(msg);
|
|
79
|
-
yield this.onMessage(data, msg);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
83
|
-
finally {
|
|
84
|
-
try {
|
|
85
|
-
if (!_d && !_a && (_b = messages_1.return)) yield _b.call(messages_1);
|
|
86
|
-
}
|
|
87
|
-
finally { if (e_1) throw e_1.error; }
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
parseMessage(msg) {
|
|
92
|
-
const decoded = this.codec.decode(msg.data);
|
|
93
|
-
return decoded;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
exports.Listener = Listener;
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { JetStreamClient } from "nats";
|
|
2
|
-
export interface Event {
|
|
3
|
-
subject: string;
|
|
4
|
-
stream: string;
|
|
5
|
-
data: any;
|
|
6
|
-
}
|
|
7
|
-
export declare abstract class Publisher<T extends Event> {
|
|
8
|
-
abstract subject: T["subject"];
|
|
9
|
-
abstract stream: T["stream"];
|
|
10
|
-
protected jsClient: JetStreamClient;
|
|
11
|
-
protected codec: import("nats").Codec<unknown>;
|
|
12
|
-
constructor(js: JetStreamClient);
|
|
13
|
-
publish(data: T["data"]): Promise<void>;
|
|
14
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.Publisher = void 0;
|
|
13
|
-
const nats_1 = require("nats");
|
|
14
|
-
class Publisher {
|
|
15
|
-
constructor(js) {
|
|
16
|
-
this.codec = (0, nats_1.JSONCodec)();
|
|
17
|
-
this.jsClient = js;
|
|
18
|
-
}
|
|
19
|
-
publish(data) {
|
|
20
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
const message = this.codec.encode(data);
|
|
22
|
-
yield this.jsClient.publish(this.subject, message);
|
|
23
|
-
console.log(`Message published to ${this.subject}:`, data);
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
exports.Publisher = Publisher;
|
package/build/events/streams.js
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Streams = void 0;
|
|
4
|
-
var Streams;
|
|
5
|
-
(function (Streams) {
|
|
6
|
-
Streams["OrderServiceStream"] = "orders";
|
|
7
|
-
Streams["BookServiceStream"] = "books";
|
|
8
|
-
Streams["ReaderServiceStream"] = "readers";
|
|
9
|
-
Streams["AuthorServiceStream"] = "authors";
|
|
10
|
-
Streams["AuthServiceStream"] = "auth";
|
|
11
|
-
})(Streams || (exports.Streams = Streams = {}));
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export declare enum Subjects {
|
|
2
|
-
AuthorCreated = "author:created",
|
|
3
|
-
AuthorUpdated = "author:updated",
|
|
4
|
-
AuthorDeleted = "author:deleted",
|
|
5
|
-
AuthorSignedUp = "author:signed-up",
|
|
6
|
-
AuthorSignedIn = "author:signed-in",
|
|
7
|
-
AuthorSignedOut = "author:signed-out",
|
|
8
|
-
ReaderSignedUp = "reader:signed-up",
|
|
9
|
-
ReaderSignedIn = "reader:signed-in",
|
|
10
|
-
ReaderSignedOut = "reader:signed-out",
|
|
11
|
-
ReaderCreated = "reader:created",
|
|
12
|
-
ReaderUpdated = "reader:updated",
|
|
13
|
-
ReaderDeleted = "reader:deleted",
|
|
14
|
-
BookCreated = "book:created",
|
|
15
|
-
BookUpdated = "book:updated",
|
|
16
|
-
BookDeleted = "book:deleted",
|
|
17
|
-
ChapterCreated = "chapter:created",
|
|
18
|
-
ChapterUpdated = "chapter:updated",
|
|
19
|
-
ChapterDeleted = "chapter:deleted",
|
|
20
|
-
OrderCreated = "order:created",
|
|
21
|
-
OrderCancelled = "order:cancelled"
|
|
22
|
-
}
|
package/build/events/subjects.js
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Subjects = void 0;
|
|
4
|
-
var Subjects;
|
|
5
|
-
(function (Subjects) {
|
|
6
|
-
// Authors related event subjects
|
|
7
|
-
Subjects["AuthorCreated"] = "author:created";
|
|
8
|
-
Subjects["AuthorUpdated"] = "author:updated";
|
|
9
|
-
Subjects["AuthorDeleted"] = "author:deleted";
|
|
10
|
-
Subjects["AuthorSignedUp"] = "author:signed-up";
|
|
11
|
-
Subjects["AuthorSignedIn"] = "author:signed-in";
|
|
12
|
-
Subjects["AuthorSignedOut"] = "author:signed-out";
|
|
13
|
-
// Readers related event subjects
|
|
14
|
-
Subjects["ReaderSignedUp"] = "reader:signed-up";
|
|
15
|
-
Subjects["ReaderSignedIn"] = "reader:signed-in";
|
|
16
|
-
Subjects["ReaderSignedOut"] = "reader:signed-out";
|
|
17
|
-
Subjects["ReaderCreated"] = "reader:created";
|
|
18
|
-
Subjects["ReaderUpdated"] = "reader:updated";
|
|
19
|
-
Subjects["ReaderDeleted"] = "reader:deleted";
|
|
20
|
-
// Books related event subjects
|
|
21
|
-
Subjects["BookCreated"] = "book:created";
|
|
22
|
-
Subjects["BookUpdated"] = "book:updated";
|
|
23
|
-
Subjects["BookDeleted"] = "book:deleted";
|
|
24
|
-
// Chapters related event subjects
|
|
25
|
-
Subjects["ChapterCreated"] = "chapter:created";
|
|
26
|
-
Subjects["ChapterUpdated"] = "chapter:updated";
|
|
27
|
-
Subjects["ChapterDeleted"] = "chapter:deleted";
|
|
28
|
-
// Orders related event subjects
|
|
29
|
-
Subjects["OrderCreated"] = "order:created";
|
|
30
|
-
Subjects["OrderCancelled"] = "order:cancelled";
|
|
31
|
-
})(Subjects || (exports.Subjects = Subjects = {}));
|
package/build/index.d.ts
DELETED
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
export * from "./errors/bad-request-error";
|
|
2
|
-
export * from "./errors/custom-error";
|
|
3
|
-
export * from "./errors/database-connection-error";
|
|
4
|
-
export * from "./errors/not-authorized-error";
|
|
5
|
-
export * from "./errors/not-found-error";
|
|
6
|
-
export * from "./errors/request-validation-error";
|
|
7
|
-
export * from "./middlewares/current-user";
|
|
8
|
-
export * from "./middlewares/error-handler";
|
|
9
|
-
export * from "./middlewares/require-auth";
|
|
10
|
-
export * from "./middlewares/validation";
|
|
11
|
-
export * from "./enum/roles";
|
|
12
|
-
export * from "./events/listeners/base-listener";
|
|
13
|
-
export * from "./events/publishers/base-publisher";
|
|
14
|
-
export * from "./events/event-types/books/book-created-event";
|
|
15
|
-
export * from "./events/event-types/books/book-updated-event";
|
|
16
|
-
export * from "./events/event-types/books/book-deleted-event";
|
|
17
|
-
export * from "./events/event-types/auth/reader-created-event";
|
|
18
|
-
export * from "./events/event-types/auth/reader-updated-event";
|
|
19
|
-
export * from "./events/event-types/auth/reader-deleted-event";
|
|
20
|
-
export * from "./events/event-types/auth/author-created-event";
|
|
21
|
-
export * from "./events/event-types/auth/author-updated-event";
|
|
22
|
-
export * from "./events/event-types/auth/author-deleted-event";
|
|
23
|
-
export * from "./events/event-types/auth/reader-signed-up-event";
|
|
24
|
-
export * from "./events/event-types/auth/reader-signed-in-event";
|
|
25
|
-
export * from "./events/event-types/auth/reader-signed-out-event";
|
|
26
|
-
export * from "./events/event-types/auth/author-signed-up-event";
|
|
27
|
-
export * from "./events/event-types/auth/author-signed-in-event";
|
|
28
|
-
export * from "./events/event-types/auth/author-signed-out-event";
|
|
29
|
-
export * from "./events/event-types/orders/order-created-event";
|
|
30
|
-
export * from "./events/subjects";
|
|
31
|
-
export * from "./events/streams";
|
|
32
|
-
export * from "./nats-wrapper";
|
package/build/index.js
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./errors/bad-request-error"), exports);
|
|
18
|
-
__exportStar(require("./errors/custom-error"), exports);
|
|
19
|
-
__exportStar(require("./errors/database-connection-error"), exports);
|
|
20
|
-
__exportStar(require("./errors/not-authorized-error"), exports);
|
|
21
|
-
__exportStar(require("./errors/not-found-error"), exports);
|
|
22
|
-
__exportStar(require("./errors/request-validation-error"), exports);
|
|
23
|
-
__exportStar(require("./middlewares/current-user"), exports);
|
|
24
|
-
__exportStar(require("./middlewares/error-handler"), exports);
|
|
25
|
-
__exportStar(require("./middlewares/require-auth"), exports);
|
|
26
|
-
__exportStar(require("./middlewares/validation"), exports);
|
|
27
|
-
// Enums
|
|
28
|
-
__exportStar(require("./enum/roles"), exports);
|
|
29
|
-
__exportStar(require("./events/listeners/base-listener"), exports);
|
|
30
|
-
__exportStar(require("./events/publishers/base-publisher"), exports);
|
|
31
|
-
__exportStar(require("./events/event-types/books/book-created-event"), exports);
|
|
32
|
-
__exportStar(require("./events/event-types/books/book-updated-event"), exports);
|
|
33
|
-
__exportStar(require("./events/event-types/books/book-deleted-event"), exports);
|
|
34
|
-
__exportStar(require("./events/event-types/auth/reader-created-event"), exports);
|
|
35
|
-
__exportStar(require("./events/event-types/auth/reader-updated-event"), exports);
|
|
36
|
-
__exportStar(require("./events/event-types/auth/reader-deleted-event"), exports);
|
|
37
|
-
__exportStar(require("./events/event-types/auth/author-created-event"), exports);
|
|
38
|
-
__exportStar(require("./events/event-types/auth/author-updated-event"), exports);
|
|
39
|
-
__exportStar(require("./events/event-types/auth/author-deleted-event"), exports);
|
|
40
|
-
__exportStar(require("./events/event-types/auth/reader-signed-up-event"), exports);
|
|
41
|
-
__exportStar(require("./events/event-types/auth/reader-signed-in-event"), exports);
|
|
42
|
-
__exportStar(require("./events/event-types/auth/reader-signed-out-event"), exports);
|
|
43
|
-
__exportStar(require("./events/event-types/auth/author-signed-up-event"), exports);
|
|
44
|
-
__exportStar(require("./events/event-types/auth/author-signed-in-event"), exports);
|
|
45
|
-
__exportStar(require("./events/event-types/auth/author-signed-out-event"), exports);
|
|
46
|
-
__exportStar(require("./events/event-types/orders/order-created-event"), exports);
|
|
47
|
-
__exportStar(require("./events/subjects"), exports);
|
|
48
|
-
__exportStar(require("./events/streams"), exports);
|
|
49
|
-
__exportStar(require("./nats-wrapper"), exports);
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { Request, Response, NextFunction } from "express";
|
|
2
|
-
import { UserRoles } from "../enum/roles";
|
|
3
|
-
export interface UserJwtPayload {
|
|
4
|
-
id: string;
|
|
5
|
-
email: string;
|
|
6
|
-
firstName: string;
|
|
7
|
-
lastName: string;
|
|
8
|
-
role: UserRoles;
|
|
9
|
-
}
|
|
10
|
-
export interface JwtPayload {
|
|
11
|
-
email: string;
|
|
12
|
-
firstName: string;
|
|
13
|
-
lastName: string;
|
|
14
|
-
role: UserRoles;
|
|
15
|
-
sub: string;
|
|
16
|
-
aud: string;
|
|
17
|
-
iss: string;
|
|
18
|
-
iat: number;
|
|
19
|
-
exp: number;
|
|
20
|
-
jti: string;
|
|
21
|
-
}
|
|
22
|
-
declare global {
|
|
23
|
-
namespace Express {
|
|
24
|
-
interface Request {
|
|
25
|
-
currentUser?: UserJwtPayload;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
export declare const currentUser: (req: Request, res: Response, next: NextFunction) => void;
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.currentUser = void 0;
|
|
7
|
-
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
|
8
|
-
const currentUser = (req, res, next) => {
|
|
9
|
-
var _a;
|
|
10
|
-
const token = (_a = req.headers["authorization"]) === null || _a === void 0 ? void 0 : _a.split(" ")[1];
|
|
11
|
-
if (!token) {
|
|
12
|
-
return next();
|
|
13
|
-
}
|
|
14
|
-
try {
|
|
15
|
-
const payload = jsonwebtoken_1.default.verify(token, process.env.JWT_KEY);
|
|
16
|
-
const userData = {
|
|
17
|
-
id: payload.sub,
|
|
18
|
-
email: payload.email,
|
|
19
|
-
firstName: payload.firstName,
|
|
20
|
-
lastName: payload.lastName,
|
|
21
|
-
role: payload.role,
|
|
22
|
-
};
|
|
23
|
-
req.currentUser = userData;
|
|
24
|
-
}
|
|
25
|
-
catch (err) { }
|
|
26
|
-
next();
|
|
27
|
-
};
|
|
28
|
-
exports.currentUser = currentUser;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.errorHandler = void 0;
|
|
4
|
-
const custom_error_1 = require("../errors/custom-error");
|
|
5
|
-
const errorHandler = (err, req, res, next) => {
|
|
6
|
-
if (err instanceof custom_error_1.CustomError) {
|
|
7
|
-
return res.status(err.statusCode).send({ errors: err.serializeErrors() });
|
|
8
|
-
}
|
|
9
|
-
res.status(400).send({
|
|
10
|
-
errors: [{ message: 'Something went wrong' }]
|
|
11
|
-
});
|
|
12
|
-
};
|
|
13
|
-
exports.errorHandler = errorHandler;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.requireAuth = void 0;
|
|
4
|
-
const not_authorized_error_1 = require("../errors/not-authorized-error");
|
|
5
|
-
const requireAuth = (req, res, next) => {
|
|
6
|
-
if (!req.currentUser) {
|
|
7
|
-
throw new not_authorized_error_1.NotAuthorizedError();
|
|
8
|
-
}
|
|
9
|
-
next();
|
|
10
|
-
};
|
|
11
|
-
exports.requireAuth = requireAuth;
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { Request, Response, NextFunction } from 'express';
|
|
2
|
-
import { ClassConstructor } from 'class-transformer';
|
|
3
|
-
export declare function validationMiddleware<T extends object>(type: ClassConstructor<T>, skipMissingProperties?: boolean): (req: Request, res: Response, next: NextFunction) => Promise<Response<any, Record<string, any>> | undefined>;
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.validationMiddleware = validationMiddleware;
|
|
13
|
-
const class_transformer_1 = require("class-transformer");
|
|
14
|
-
const class_validator_1 = require("class-validator");
|
|
15
|
-
function validationMiddleware(type, skipMissingProperties = false) {
|
|
16
|
-
return (req, res, next) => __awaiter(this, void 0, void 0, function* () {
|
|
17
|
-
try {
|
|
18
|
-
// Transform plain object to class instance
|
|
19
|
-
const dto = (0, class_transformer_1.plainToClass)(type, req.body);
|
|
20
|
-
// Validate the DTO
|
|
21
|
-
const errors = yield (0, class_validator_1.validate)(dto, {
|
|
22
|
-
skipMissingProperties,
|
|
23
|
-
whitelist: true, // Remove properties that don't have decorators
|
|
24
|
-
forbidNonWhitelisted: true, // Throw error if non-whitelisted properties are present
|
|
25
|
-
});
|
|
26
|
-
if (errors.length > 0) {
|
|
27
|
-
// Transform validation errors to our format
|
|
28
|
-
const validationErrors = [];
|
|
29
|
-
errors.forEach((error) => {
|
|
30
|
-
if (error.constraints) {
|
|
31
|
-
Object.values(error.constraints).forEach((message) => {
|
|
32
|
-
validationErrors.push({
|
|
33
|
-
message,
|
|
34
|
-
field: error.property,
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
});
|
|
39
|
-
return res.status(400).json({
|
|
40
|
-
status: 400,
|
|
41
|
-
message: 'Validation failed',
|
|
42
|
-
errors: validationErrors,
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
// Attach the validated and transformed DTO to the request
|
|
46
|
-
req.body = dto;
|
|
47
|
-
next();
|
|
48
|
-
}
|
|
49
|
-
catch (error) {
|
|
50
|
-
console.error('Validation middleware error:', error);
|
|
51
|
-
return res.status(500).json({
|
|
52
|
-
status: 500,
|
|
53
|
-
message: 'Internal server error during validation',
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
}
|
package/build/nats-wrapper.d.ts
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { JetStreamClient, JetStreamManager, NatsConnection } from 'nats';
|
|
2
|
-
import { Streams } from './events/streams';
|
|
3
|
-
import { Subjects } from './events/subjects';
|
|
4
|
-
declare class NatsWrapper {
|
|
5
|
-
private _natsConnection;
|
|
6
|
-
private _jetStreamClient;
|
|
7
|
-
private _jetStreamManager;
|
|
8
|
-
private stream;
|
|
9
|
-
private subjects;
|
|
10
|
-
constructor(stream: Streams, subjects: Subjects[]);
|
|
11
|
-
get natsConnection(): NatsConnection;
|
|
12
|
-
get jetStreamClient(): JetStreamClient;
|
|
13
|
-
get jetStreamManager(): JetStreamManager | null;
|
|
14
|
-
private ensureStreamExists;
|
|
15
|
-
connect(server: string): Promise<void>;
|
|
16
|
-
}
|
|
17
|
-
export { NatsWrapper };
|
package/build/nats-wrapper.js
DELETED
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.NatsWrapper = void 0;
|
|
13
|
-
const nats_1 = require("nats");
|
|
14
|
-
class NatsWrapper {
|
|
15
|
-
constructor(stream, subjects) {
|
|
16
|
-
this._natsConnection = null;
|
|
17
|
-
this._jetStreamClient = null;
|
|
18
|
-
this._jetStreamManager = null;
|
|
19
|
-
this.stream = stream;
|
|
20
|
-
this.subjects = subjects;
|
|
21
|
-
}
|
|
22
|
-
get natsConnection() {
|
|
23
|
-
if (!this._natsConnection) {
|
|
24
|
-
throw new Error('Cannot access NATS client before initialization');
|
|
25
|
-
}
|
|
26
|
-
return this._natsConnection;
|
|
27
|
-
}
|
|
28
|
-
get jetStreamClient() {
|
|
29
|
-
if (!this._jetStreamClient) {
|
|
30
|
-
throw new Error('Cannot access JetStream client before initialization');
|
|
31
|
-
}
|
|
32
|
-
return this._jetStreamClient;
|
|
33
|
-
}
|
|
34
|
-
get jetStreamManager() {
|
|
35
|
-
if (!this._jetStreamClient) {
|
|
36
|
-
throw new Error('Cannot access JetStream manager before initialization');
|
|
37
|
-
}
|
|
38
|
-
return this._jetStreamManager;
|
|
39
|
-
}
|
|
40
|
-
ensureStreamExists() {
|
|
41
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
-
var _a, _b;
|
|
43
|
-
// Ensure AuthServiceStream exists for auth-specific events
|
|
44
|
-
try {
|
|
45
|
-
yield ((_a = this.jetStreamManager) === null || _a === void 0 ? void 0 : _a.streams.info(this.stream));
|
|
46
|
-
}
|
|
47
|
-
catch (_c) {
|
|
48
|
-
yield ((_b = this.jetStreamManager) === null || _b === void 0 ? void 0 : _b.streams.add({
|
|
49
|
-
name: this.stream,
|
|
50
|
-
subjects: this.subjects,
|
|
51
|
-
}));
|
|
52
|
-
}
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
connect(server) {
|
|
56
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
-
let connectionAttempts = 0;
|
|
58
|
-
while (connectionAttempts < 6) {
|
|
59
|
-
try {
|
|
60
|
-
const connection = yield (0, nats_1.connect)({
|
|
61
|
-
servers: [server],
|
|
62
|
-
});
|
|
63
|
-
this._natsConnection = connection;
|
|
64
|
-
this._jetStreamClient = connection.jetstream();
|
|
65
|
-
this._jetStreamManager = yield connection.jetstreamManager();
|
|
66
|
-
yield this.ensureStreamExists();
|
|
67
|
-
console.log('✅ Connected to NATS');
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
catch (e) {
|
|
71
|
-
console.error('❌ NATS connection failed, retrying in 3s...', e.message);
|
|
72
|
-
yield new Promise(res => setTimeout(res, 3000));
|
|
73
|
-
connectionAttempts++;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
throw new Error('NATS connection failed');
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
exports.NatsWrapper = NatsWrapper;
|