@eratu/common 1.0.17 → 1.0.19
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/build/__tests__/enum/roles.test.d.ts +1 -0
- package/build/__tests__/enum/roles.test.js +31 -0
- package/build/__tests__/errors/bad-request-error.test.d.ts +1 -0
- package/build/__tests__/errors/bad-request-error.test.js +30 -0
- package/build/__tests__/errors/database-connection-error.test.d.ts +1 -0
- package/build/__tests__/errors/database-connection-error.test.js +28 -0
- package/build/__tests__/errors/forbidden-error.test.d.ts +1 -0
- package/build/__tests__/errors/forbidden-error.test.js +39 -0
- package/build/__tests__/errors/not-authorized-error.test.d.ts +1 -0
- package/build/__tests__/errors/not-authorized-error.test.js +39 -0
- package/build/__tests__/errors/not-found-error.test.d.ts +1 -0
- package/build/__tests__/errors/not-found-error.test.js +39 -0
- package/build/__tests__/errors/request-validation-error.test.d.ts +1 -0
- package/build/__tests__/errors/request-validation-error.test.js +101 -0
- package/build/__tests__/events/base-listener.test.d.ts +1 -0
- package/build/__tests__/events/base-listener.test.js +222 -0
- package/build/__tests__/events/base-publisher.test.d.ts +1 -0
- package/build/__tests__/events/base-publisher.test.js +85 -0
- package/build/__tests__/events/streams.test.d.ts +1 -0
- package/build/__tests__/events/streams.test.js +24 -0
- package/build/__tests__/events/subjects.test.d.ts +1 -0
- package/build/__tests__/events/subjects.test.js +79 -0
- package/build/__tests__/middlewares/allow-roles.test.d.ts +1 -0
- package/build/__tests__/middlewares/allow-roles.test.js +112 -0
- package/build/__tests__/middlewares/current-user.test.d.ts +1 -0
- package/build/__tests__/middlewares/current-user.test.js +261 -0
- package/build/__tests__/middlewares/error-handler.test.d.ts +1 -0
- package/build/__tests__/middlewares/error-handler.test.js +102 -0
- package/build/__tests__/middlewares/require-auth.test.d.ts +1 -0
- package/build/__tests__/middlewares/require-auth.test.js +57 -0
- package/build/__tests__/middlewares/validation.test.d.ts +1 -0
- package/build/__tests__/middlewares/validation.test.js +198 -0
- package/build/__tests__/nats-wrapper.test.d.ts +1 -0
- package/build/__tests__/nats-wrapper.test.js +158 -0
- package/build/__tests__/redis-wrapper.test.d.ts +1 -0
- package/build/__tests__/redis-wrapper.test.js +158 -0
- package/build/enum/roles.d.ts +6 -0
- package/build/enum/roles.js +10 -0
- package/build/errors/bad-request-error.d.ts +9 -0
- package/build/errors/bad-request-error.js +16 -0
- package/build/errors/custom-error.d.ts +8 -0
- package/build/errors/custom-error.js +10 -0
- package/build/errors/database-connection-error.d.ts +9 -0
- package/build/errors/database-connection-error.js +16 -0
- package/build/errors/forbidden-error.d.ts +9 -0
- package/build/errors/forbidden-error.js +16 -0
- package/build/errors/not-authorized-error.d.ts +8 -0
- package/build/errors/not-authorized-error.js +15 -0
- package/build/errors/not-found-error.d.ts +9 -0
- package/build/errors/not-found-error.js +16 -0
- package/build/errors/request-validation-error.d.ts +14 -0
- package/build/errors/request-validation-error.js +22 -0
- package/build/events/event-types/auth/admin-deleted-event.d.ts +11 -0
- package/build/events/event-types/auth/admin-deleted-event.js +2 -0
- package/build/events/event-types/auth/admin-signed-up-event.d.ts +13 -0
- package/build/events/event-types/auth/admin-signed-up-event.js +2 -0
- package/build/events/event-types/auth/admin-updated-event.d.ts +14 -0
- package/build/events/event-types/auth/admin-updated-event.js +2 -0
- package/build/events/event-types/auth/author-deleted-event.d.ts +11 -0
- package/build/events/event-types/auth/author-deleted-event.js +2 -0
- package/build/events/event-types/auth/author-signed-in-event.d.ts +12 -0
- package/build/events/event-types/auth/author-signed-in-event.js +2 -0
- package/build/events/event-types/auth/author-signed-out-event.d.ts +11 -0
- package/build/events/event-types/auth/author-signed-out-event.js +2 -0
- package/build/events/event-types/auth/author-signed-up-event.d.ts +13 -0
- package/build/events/event-types/auth/author-signed-up-event.js +2 -0
- package/build/events/event-types/auth/author-updated-event.d.ts +14 -0
- package/build/events/event-types/auth/author-updated-event.js +2 -0
- package/build/events/event-types/auth/author-verified-event.d.ts +14 -0
- package/build/events/event-types/auth/author-verified-event.js +2 -0
- package/build/events/event-types/auth/reader-deleted-event.d.ts +11 -0
- package/build/events/event-types/auth/reader-deleted-event.js +2 -0
- package/build/events/event-types/auth/reader-signed-in-event.d.ts +13 -0
- package/build/events/event-types/auth/reader-signed-in-event.js +2 -0
- package/build/events/event-types/auth/reader-signed-out-event.d.ts +11 -0
- package/build/events/event-types/auth/reader-signed-out-event.js +2 -0
- package/build/events/event-types/auth/reader-signed-up-event.d.ts +13 -0
- package/build/events/event-types/auth/reader-signed-up-event.js +2 -0
- package/build/events/event-types/auth/reader-updated-event.d.ts +14 -0
- package/build/events/event-types/auth/reader-updated-event.js +2 -0
- package/build/events/event-types/auth/reader-verified-event.d.ts +14 -0
- package/build/events/event-types/auth/reader-verified-event.js +2 -0
- package/build/events/event-types/books/book-created-event.d.ts +11 -0
- package/build/events/event-types/books/book-created-event.js +2 -0
- package/build/events/event-types/books/book-deleted-event.d.ts +10 -0
- package/build/events/event-types/books/book-deleted-event.js +2 -0
- package/build/events/event-types/books/book-updated-event.d.ts +11 -0
- package/build/events/event-types/books/book-updated-event.js +2 -0
- package/build/events/event-types/orders/order-created-event.d.ts +12 -0
- package/build/events/event-types/orders/order-created-event.js +2 -0
- package/build/events/listeners/base-listener.d.ts +23 -0
- package/build/events/listeners/base-listener.js +96 -0
- package/build/events/publishers/base-publisher.d.ts +14 -0
- package/build/events/publishers/base-publisher.js +27 -0
- package/build/events/streams.d.ts +7 -0
- package/build/events/streams.js +11 -0
- package/build/events/subjects.d.ts +25 -0
- package/build/events/subjects.js +35 -0
- package/build/index.d.ts +38 -0
- package/build/index.js +60 -0
- package/build/middlewares/allow-roles.d.ts +3 -0
- package/build/middlewares/allow-roles.js +18 -0
- package/build/middlewares/current-user.d.ts +40 -0
- package/build/middlewares/current-user.js +86 -0
- package/build/middlewares/error-handler.d.ts +2 -0
- package/build/middlewares/error-handler.js +13 -0
- package/build/middlewares/require-auth.d.ts +2 -0
- package/build/middlewares/require-auth.js +11 -0
- package/build/middlewares/validation.d.ts +3 -0
- package/build/middlewares/validation.js +57 -0
- package/build/nats-wrapper.d.ts +17 -0
- package/build/nats-wrapper.js +80 -0
- package/build/redis-wrapper.d.ts +20 -0
- package/build/redis-wrapper.js +77 -0
- package/build/test/setup.d.ts +8 -0
- package/build/test/setup.js +45 -0
- package/package.json +1 -1
|
@@ -0,0 +1,15 @@
|
|
|
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(message = "Not Authorized") {
|
|
7
|
+
super(message);
|
|
8
|
+
this.statusCode = 401;
|
|
9
|
+
Object.setPrototypeOf(this, NotAuthorizedError.prototype);
|
|
10
|
+
}
|
|
11
|
+
serializeErrors() {
|
|
12
|
+
return [{ message: this.message }];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.NotAuthorizedError = NotAuthorizedError;
|
|
@@ -0,0 +1,16 @@
|
|
|
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(message = "Not Found") {
|
|
7
|
+
super("Route not found");
|
|
8
|
+
this.message = message;
|
|
9
|
+
this.statusCode = 404;
|
|
10
|
+
Object.setPrototypeOf(this, NotFoundError.prototype);
|
|
11
|
+
}
|
|
12
|
+
serializeErrors() {
|
|
13
|
+
return [{ message: this.message }];
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.NotFoundError = NotFoundError;
|
|
@@ -0,0 +1,14 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
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;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AdminDeletedEvent {
|
|
4
|
+
subject: Subjects.AdminDeleted;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
version: number;
|
|
9
|
+
adminVersion?: number;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AdminSignedUpEvent {
|
|
4
|
+
subject: Subjects.AdminSignedUp;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
email: string;
|
|
9
|
+
firstName: string;
|
|
10
|
+
lastName: string;
|
|
11
|
+
createdAt: string;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AdminUpdatedEvent {
|
|
4
|
+
subject: Subjects.AdminUpdated;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
firstName: string;
|
|
9
|
+
lastName: string;
|
|
10
|
+
email: string;
|
|
11
|
+
version: number;
|
|
12
|
+
adminVersion?: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AuthorDeletedEvent {
|
|
4
|
+
subject: Subjects.AuthorDeleted;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
version: number;
|
|
9
|
+
authorVersion: number;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
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
|
+
version: number;
|
|
10
|
+
authorVersion: number;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AuthorUpdatedEvent {
|
|
4
|
+
subject: Subjects.AuthorUpdated;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
firstName: string;
|
|
9
|
+
lastName: string;
|
|
10
|
+
email: string;
|
|
11
|
+
version: number;
|
|
12
|
+
authorVersion: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface AuthorVerifiedEvent {
|
|
4
|
+
subject: Subjects.AuthorVerified;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
firstName: string;
|
|
9
|
+
lastName: string;
|
|
10
|
+
email: string;
|
|
11
|
+
version: number;
|
|
12
|
+
authorVersion: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface ReaderDeletedEvent {
|
|
4
|
+
subject: Subjects.ReaderDeleted;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
version: number;
|
|
9
|
+
readerVersion: number;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
signedInAt: string;
|
|
10
|
+
version: number;
|
|
11
|
+
readerVersion: number;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface ReaderUpdatedEvent {
|
|
4
|
+
subject: Subjects.ReaderUpdated;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
firstName: string;
|
|
9
|
+
lastName: string;
|
|
10
|
+
email: string;
|
|
11
|
+
version: number;
|
|
12
|
+
readerVersion: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Streams } from "../../streams";
|
|
2
|
+
import { Subjects } from "../../subjects";
|
|
3
|
+
export interface ReaderVerifiedEvent {
|
|
4
|
+
subject: Subjects.ReaderVerified;
|
|
5
|
+
stream: Streams.AuthServiceStream;
|
|
6
|
+
data: {
|
|
7
|
+
id: string;
|
|
8
|
+
firstName: string;
|
|
9
|
+
lastName: string;
|
|
10
|
+
email: string;
|
|
11
|
+
version: number;
|
|
12
|
+
readerVersion: number;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
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 {};
|
|
@@ -0,0 +1,96 @@
|
|
|
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;
|
|
@@ -0,0 +1,14 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
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;
|
|
@@ -0,0 +1,11 @@
|
|
|
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 = {}));
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export declare enum Subjects {
|
|
2
|
+
AuthorUpdated = "author:updated",
|
|
3
|
+
AuthorDeleted = "author:deleted",
|
|
4
|
+
AuthorSignedUp = "author:signed-up",
|
|
5
|
+
AuthorSignedIn = "author:signed-in",
|
|
6
|
+
AuthorSignedOut = "author:signed-out",
|
|
7
|
+
AuthorVerified = "author:verified",
|
|
8
|
+
ReaderSignedUp = "reader:signed-up",
|
|
9
|
+
ReaderSignedIn = "reader:signed-in",
|
|
10
|
+
ReaderSignedOut = "reader:signed-out",
|
|
11
|
+
ReaderUpdated = "reader:updated",
|
|
12
|
+
ReaderDeleted = "reader:deleted",
|
|
13
|
+
ReaderVerified = "reader:verified",
|
|
14
|
+
AdminSignedUp = "admin:signed-up",
|
|
15
|
+
AdminDeleted = "admin:deleted",
|
|
16
|
+
AdminUpdated = "admin:updated",
|
|
17
|
+
BookCreated = "book:created",
|
|
18
|
+
BookUpdated = "book:updated",
|
|
19
|
+
BookDeleted = "book:deleted",
|
|
20
|
+
ChapterCreated = "chapter:created",
|
|
21
|
+
ChapterUpdated = "chapter:updated",
|
|
22
|
+
ChapterDeleted = "chapter:deleted",
|
|
23
|
+
OrderCreated = "order:created",
|
|
24
|
+
OrderCancelled = "order:cancelled"
|
|
25
|
+
}
|