@eratu/common 1.0.16 → 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.
Files changed (73) hide show
  1. package/package.json +8 -2
  2. package/build/enum/roles.d.ts +0 -6
  3. package/build/enum/roles.js +0 -10
  4. package/build/errors/bad-request-error.d.ts +0 -9
  5. package/build/errors/bad-request-error.js +0 -16
  6. package/build/errors/custom-error.d.ts +0 -8
  7. package/build/errors/custom-error.js +0 -10
  8. package/build/errors/database-connection-error.d.ts +0 -9
  9. package/build/errors/database-connection-error.js +0 -16
  10. package/build/errors/forbidden-error.d.ts +0 -9
  11. package/build/errors/forbidden-error.js +0 -16
  12. package/build/errors/not-authorized-error.d.ts +0 -8
  13. package/build/errors/not-authorized-error.js +0 -15
  14. package/build/errors/not-found-error.d.ts +0 -9
  15. package/build/errors/not-found-error.js +0 -16
  16. package/build/errors/request-validation-error.d.ts +0 -14
  17. package/build/errors/request-validation-error.js +0 -22
  18. package/build/events/event-types/auth/author-deleted-event.d.ts +0 -11
  19. package/build/events/event-types/auth/author-deleted-event.js +0 -2
  20. package/build/events/event-types/auth/author-signed-in-event.d.ts +0 -12
  21. package/build/events/event-types/auth/author-signed-in-event.js +0 -2
  22. package/build/events/event-types/auth/author-signed-out-event.d.ts +0 -11
  23. package/build/events/event-types/auth/author-signed-out-event.js +0 -2
  24. package/build/events/event-types/auth/author-signed-up-event.d.ts +0 -13
  25. package/build/events/event-types/auth/author-signed-up-event.js +0 -2
  26. package/build/events/event-types/auth/author-updated-event.d.ts +0 -14
  27. package/build/events/event-types/auth/author-updated-event.js +0 -2
  28. package/build/events/event-types/auth/author-verified-event.d.ts +0 -14
  29. package/build/events/event-types/auth/author-verified-event.js +0 -2
  30. package/build/events/event-types/auth/reader-deleted-event.d.ts +0 -11
  31. package/build/events/event-types/auth/reader-deleted-event.js +0 -2
  32. package/build/events/event-types/auth/reader-signed-in-event.d.ts +0 -13
  33. package/build/events/event-types/auth/reader-signed-in-event.js +0 -2
  34. package/build/events/event-types/auth/reader-signed-out-event.d.ts +0 -11
  35. package/build/events/event-types/auth/reader-signed-out-event.js +0 -2
  36. package/build/events/event-types/auth/reader-signed-up-event.d.ts +0 -13
  37. package/build/events/event-types/auth/reader-signed-up-event.js +0 -2
  38. package/build/events/event-types/auth/reader-updated-event.d.ts +0 -14
  39. package/build/events/event-types/auth/reader-updated-event.js +0 -2
  40. package/build/events/event-types/auth/reader-verified-event.d.ts +0 -14
  41. package/build/events/event-types/auth/reader-verified-event.js +0 -2
  42. package/build/events/event-types/books/book-created-event.d.ts +0 -11
  43. package/build/events/event-types/books/book-created-event.js +0 -2
  44. package/build/events/event-types/books/book-deleted-event.d.ts +0 -10
  45. package/build/events/event-types/books/book-deleted-event.js +0 -2
  46. package/build/events/event-types/books/book-updated-event.d.ts +0 -11
  47. package/build/events/event-types/books/book-updated-event.js +0 -2
  48. package/build/events/event-types/orders/order-created-event.d.ts +0 -12
  49. package/build/events/event-types/orders/order-created-event.js +0 -2
  50. package/build/events/listeners/base-listener.d.ts +0 -23
  51. package/build/events/listeners/base-listener.js +0 -96
  52. package/build/events/publishers/base-publisher.d.ts +0 -14
  53. package/build/events/publishers/base-publisher.js +0 -27
  54. package/build/events/streams.d.ts +0 -7
  55. package/build/events/streams.js +0 -11
  56. package/build/events/subjects.d.ts +0 -22
  57. package/build/events/subjects.js +0 -31
  58. package/build/index.d.ts +0 -35
  59. package/build/index.js +0 -56
  60. package/build/middlewares/allow-roles.d.ts +0 -3
  61. package/build/middlewares/allow-roles.js +0 -18
  62. package/build/middlewares/current-user.d.ts +0 -40
  63. package/build/middlewares/current-user.js +0 -86
  64. package/build/middlewares/error-handler.d.ts +0 -2
  65. package/build/middlewares/error-handler.js +0 -13
  66. package/build/middlewares/require-auth.d.ts +0 -2
  67. package/build/middlewares/require-auth.js +0 -11
  68. package/build/middlewares/validation.d.ts +0 -3
  69. package/build/middlewares/validation.js +0 -57
  70. package/build/nats-wrapper.d.ts +0 -17
  71. package/build/nats-wrapper.js +0 -80
  72. package/build/redis-wrapper.d.ts +0 -20
  73. package/build/redis-wrapper.js +0 -77
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@eratu/common",
3
- "version": "1.0.16",
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": {
@@ -1,6 +0,0 @@
1
- export declare enum UserRoles {
2
- superAdmin = 1,
3
- admin = 2,
4
- author = 3,
5
- reader = 4
6
- }
@@ -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,9 +0,0 @@
1
- import { CustomError } from './custom-error';
2
- export declare class BadRequestError extends CustomError {
3
- message: string;
4
- statusCode: number;
5
- constructor(message: string);
6
- serializeErrors(): {
7
- message: string;
8
- }[];
9
- }
@@ -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,8 +0,0 @@
1
- export declare abstract class CustomError extends Error {
2
- abstract statusCode: number;
3
- constructor(message: string);
4
- abstract serializeErrors(): {
5
- message: string;
6
- field?: string;
7
- }[];
8
- }
@@ -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,9 +0,0 @@
1
- import { CustomError } from './custom-error';
2
- export declare class DatabaseConnectionError extends CustomError {
3
- statusCode: number;
4
- reason: string;
5
- constructor();
6
- serializeErrors(): {
7
- message: string;
8
- }[];
9
- }
@@ -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,9 +0,0 @@
1
- import { CustomError } from "./custom-error";
2
- export declare class ForbiddenError extends CustomError {
3
- message: string;
4
- statusCode: number;
5
- constructor(message?: string);
6
- serializeErrors(): {
7
- message: string;
8
- }[];
9
- }
@@ -1,16 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ForbiddenError = void 0;
4
- const custom_error_1 = require("./custom-error");
5
- class ForbiddenError extends custom_error_1.CustomError {
6
- constructor(message = "Forbidden") {
7
- super(message);
8
- this.message = message;
9
- this.statusCode = 403;
10
- Object.setPrototypeOf(this, ForbiddenError.prototype);
11
- }
12
- serializeErrors() {
13
- return [{ message: this.message }];
14
- }
15
- }
16
- exports.ForbiddenError = ForbiddenError;
@@ -1,8 +0,0 @@
1
- import { CustomError } from "./custom-error";
2
- export declare class NotAuthorizedError extends CustomError {
3
- statusCode: number;
4
- constructor(message?: string);
5
- serializeErrors(): {
6
- message: string;
7
- }[];
8
- }
@@ -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(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;
@@ -1,9 +0,0 @@
1
- import { CustomError } from "./custom-error";
2
- export declare class NotFoundError extends CustomError {
3
- message: string;
4
- statusCode: number;
5
- constructor(message?: string);
6
- serializeErrors(): {
7
- message: string;
8
- }[];
9
- }
@@ -1,16 +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(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;
@@ -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,11 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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
- version: number;
10
- authorVersion: number;
11
- };
12
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,14 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,14 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,11 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,13 +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
- signedInAt: string;
10
- version: number;
11
- readerVersion: number;
12
- };
13
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,14 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,14 +0,0 @@
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
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,10 +0,0 @@
1
- import { Streams } from "../../streams";
2
- import { Subjects } from "../../subjects";
3
- export interface BookDeletedEvent {
4
- subject: Subjects.BookDeleted;
5
- stream: Streams.BookServiceStream;
6
- data: {
7
- id: string;
8
- version: number;
9
- };
10
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -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 {};