@eratu/common 1.0.21 → 1.0.22
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 +1 -1
- package/build/__tests__/enum/roles.test.d.ts +0 -1
- package/build/__tests__/enum/roles.test.js +0 -31
- package/build/__tests__/errors/bad-request-error.test.d.ts +0 -1
- package/build/__tests__/errors/bad-request-error.test.js +0 -30
- package/build/__tests__/errors/database-connection-error.test.d.ts +0 -1
- package/build/__tests__/errors/database-connection-error.test.js +0 -28
- package/build/__tests__/errors/forbidden-error.test.d.ts +0 -1
- package/build/__tests__/errors/forbidden-error.test.js +0 -39
- package/build/__tests__/errors/not-authorized-error.test.d.ts +0 -1
- package/build/__tests__/errors/not-authorized-error.test.js +0 -39
- package/build/__tests__/errors/not-found-error.test.d.ts +0 -1
- package/build/__tests__/errors/not-found-error.test.js +0 -39
- package/build/__tests__/errors/request-validation-error.test.d.ts +0 -1
- package/build/__tests__/errors/request-validation-error.test.js +0 -99
- package/build/__tests__/events/base-listener.test.d.ts +0 -1
- package/build/__tests__/events/base-listener.test.js +0 -223
- package/build/__tests__/events/base-publisher.test.d.ts +0 -1
- package/build/__tests__/events/base-publisher.test.js +0 -85
- package/build/__tests__/events/streams.test.d.ts +0 -1
- package/build/__tests__/events/streams.test.js +0 -18
- package/build/__tests__/events/subjects.test.d.ts +0 -1
- package/build/__tests__/events/subjects.test.js +0 -79
- package/build/__tests__/middlewares/allow-roles.test.d.ts +0 -1
- package/build/__tests__/middlewares/allow-roles.test.js +0 -112
- package/build/__tests__/middlewares/current-user.test.d.ts +0 -1
- package/build/__tests__/middlewares/current-user.test.js +0 -261
- package/build/__tests__/middlewares/error-handler.test.d.ts +0 -1
- package/build/__tests__/middlewares/error-handler.test.js +0 -102
- package/build/__tests__/middlewares/require-auth.test.d.ts +0 -1
- package/build/__tests__/middlewares/require-auth.test.js +0 -57
- package/build/__tests__/middlewares/validation.test.d.ts +0 -1
- package/build/__tests__/middlewares/validation.test.js +0 -198
- package/build/__tests__/nats-wrapper.test.d.ts +0 -1
- package/build/__tests__/nats-wrapper.test.js +0 -159
- package/build/__tests__/redis-wrapper.test.d.ts +0 -1
- package/build/__tests__/redis-wrapper.test.js +0 -159
- package/build/enum/image.d.ts +0 -14
- package/build/enum/image.js +0 -18
- 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/conflict-error.d.ts +0 -9
- package/build/errors/conflict-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/forbidden-error.d.ts +0 -9
- package/build/errors/forbidden-error.js +0 -16
- package/build/errors/internal-error.d.ts +0 -9
- package/build/errors/internal-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 -9
- package/build/errors/not-found-error.js +0 -16
- 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/admin-deleted-event.d.ts +0 -11
- package/build/events/event-types/auth/admin-deleted-event.js +0 -2
- package/build/events/event-types/auth/admin-signed-up-event.d.ts +0 -13
- package/build/events/event-types/auth/admin-signed-up-event.js +0 -2
- package/build/events/event-types/auth/admin-updated-event.d.ts +0 -14
- package/build/events/event-types/auth/admin-updated-event.js +0 -2
- package/build/events/event-types/auth/author-deleted-event.d.ts +0 -11
- 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 -14
- package/build/events/event-types/auth/author-updated-event.js +0 -2
- package/build/events/event-types/auth/author-verified-event.d.ts +0 -14
- package/build/events/event-types/auth/author-verified-event.js +0 -2
- package/build/events/event-types/auth/reader-deleted-event.d.ts +0 -11
- 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 -13
- 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 -14
- package/build/events/event-types/auth/reader-updated-event.js +0 -2
- package/build/events/event-types/auth/reader-verified-event.d.ts +0 -14
- package/build/events/event-types/auth/reader-verified-event.js +0 -2
- package/build/events/event-types/books/book-created-event.d.ts +0 -34
- 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 -35
- package/build/events/event-types/books/book-updated-event.js +0 -2
- package/build/events/event-types/books/chapter-created-event.d.ts +0 -16
- package/build/events/event-types/books/chapter-created-event.js +0 -2
- package/build/events/event-types/books/chapter-deleted-event.d.ts +0 -10
- package/build/events/event-types/books/chapter-deleted-event.js +0 -2
- package/build/events/event-types/books/chapter-updated-event.d.ts +0 -17
- package/build/events/event-types/books/chapter-updated-event.js +0 -2
- package/build/events/event-types/books/genre-created-event.d.ts +0 -13
- package/build/events/event-types/books/genre-created-event.js +0 -2
- package/build/events/event-types/books/genre-deleted-event.d.ts +0 -9
- package/build/events/event-types/books/genre-deleted-event.js +0 -2
- package/build/events/event-types/books/genre-updated-event.d.ts +0 -13
- package/build/events/event-types/books/genre-updated-event.js +0 -2
- package/build/events/event-types/books/subgenre-created-event.d.ts +0 -14
- package/build/events/event-types/books/subgenre-created-event.js +0 -2
- package/build/events/event-types/books/subgenre-deleted-event.d.ts +0 -9
- package/build/events/event-types/books/subgenre-deleted-event.js +0 -2
- package/build/events/event-types/books/subgenre-updated-event.d.ts +0 -14
- package/build/events/event-types/books/subgenre-updated-event.js +0 -2
- package/build/events/event-types/books/tag-created-event.d.ts +0 -12
- package/build/events/event-types/books/tag-created-event.js +0 -2
- package/build/events/event-types/books/tag-deleted-event.d.ts +0 -9
- package/build/events/event-types/books/tag-deleted-event.js +0 -2
- package/build/events/event-types/books/tag-updated-event.d.ts +0 -12
- package/build/events/event-types/books/tag-updated-event.js +0 -2
- package/build/events/event-types/books/trigger-created-event.d.ts +0 -12
- package/build/events/event-types/books/trigger-created-event.js +0 -2
- package/build/events/event-types/books/trigger-deleted-event.d.ts +0 -9
- package/build/events/event-types/books/trigger-deleted-event.js +0 -2
- package/build/events/event-types/books/trigger-updated-event.d.ts +0 -12
- package/build/events/event-types/books/trigger-updated-event.js +0 -2
- package/build/events/event-types/books/trope-created-event.d.ts +0 -12
- package/build/events/event-types/books/trope-created-event.js +0 -2
- package/build/events/event-types/books/trope-deleted-event.d.ts +0 -9
- package/build/events/event-types/books/trope-deleted-event.js +0 -2
- package/build/events/event-types/books/trope-updated-event.d.ts +0 -12
- package/build/events/event-types/books/trope-updated-event.js +0 -2
- package/build/events/event-types/media/avatar-uploaded-event.d.ts +0 -14
- package/build/events/event-types/media/avatar-uploaded-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 -97
- 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 -6
- package/build/events/streams.js +0 -10
- package/build/events/subjects.d.ts +0 -41
- package/build/events/subjects.js +0 -52
- package/build/index.d.ts +0 -60
- package/build/index.js +0 -89
- package/build/middlewares/allow-roles.d.ts +0 -3
- package/build/middlewares/allow-roles.js +0 -18
- package/build/middlewares/current-user.d.ts +0 -40
- package/build/middlewares/current-user.js +0 -88
- package/build/middlewares/error-handler.d.ts +0 -2
- package/build/middlewares/error-handler.js +0 -14
- 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 -92
- package/build/redis-wrapper.d.ts +0 -20
- package/build/redis-wrapper.js +0 -77
- package/build/test/setup.d.ts +0 -8
- package/build/test/setup.js +0 -45
package/build/index.js
DELETED
|
@@ -1,89 +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
|
-
// Errors
|
|
18
|
-
__exportStar(require("./errors/bad-request-error"), exports);
|
|
19
|
-
__exportStar(require("./errors/custom-error"), exports);
|
|
20
|
-
__exportStar(require("./errors/database-connection-error"), exports);
|
|
21
|
-
__exportStar(require("./errors/not-authorized-error"), exports);
|
|
22
|
-
__exportStar(require("./errors/not-found-error"), exports);
|
|
23
|
-
__exportStar(require("./errors/request-validation-error"), exports);
|
|
24
|
-
__exportStar(require("./errors/forbidden-error"), exports);
|
|
25
|
-
__exportStar(require("./errors/internal-error"), exports);
|
|
26
|
-
__exportStar(require("./errors/conflict-error"), exports);
|
|
27
|
-
// Middlewares
|
|
28
|
-
__exportStar(require("./middlewares/current-user"), exports);
|
|
29
|
-
__exportStar(require("./middlewares/require-auth"), exports);
|
|
30
|
-
__exportStar(require("./middlewares/validation"), exports);
|
|
31
|
-
__exportStar(require("./middlewares/error-handler"), exports);
|
|
32
|
-
__exportStar(require("./middlewares/allow-roles"), exports);
|
|
33
|
-
// Enums
|
|
34
|
-
__exportStar(require("./enum/roles"), exports);
|
|
35
|
-
__exportStar(require("./enum/image"), exports);
|
|
36
|
-
__exportStar(require("./events/listeners/base-listener"), exports);
|
|
37
|
-
__exportStar(require("./events/publishers/base-publisher"), exports);
|
|
38
|
-
__exportStar(require("./events/event-types/books/book-created-event"), exports);
|
|
39
|
-
__exportStar(require("./events/event-types/books/book-updated-event"), exports);
|
|
40
|
-
__exportStar(require("./events/event-types/books/book-deleted-event"), exports);
|
|
41
|
-
// Genre events
|
|
42
|
-
__exportStar(require("./events/event-types/books/genre-created-event"), exports);
|
|
43
|
-
__exportStar(require("./events/event-types/books/genre-updated-event"), exports);
|
|
44
|
-
__exportStar(require("./events/event-types/books/genre-deleted-event"), exports);
|
|
45
|
-
// Subgenre events
|
|
46
|
-
__exportStar(require("./events/event-types/books/subgenre-created-event"), exports);
|
|
47
|
-
__exportStar(require("./events/event-types/books/subgenre-updated-event"), exports);
|
|
48
|
-
__exportStar(require("./events/event-types/books/subgenre-deleted-event"), exports);
|
|
49
|
-
// Tag events
|
|
50
|
-
__exportStar(require("./events/event-types/books/tag-created-event"), exports);
|
|
51
|
-
__exportStar(require("./events/event-types/books/tag-updated-event"), exports);
|
|
52
|
-
__exportStar(require("./events/event-types/books/tag-deleted-event"), exports);
|
|
53
|
-
// Trope events
|
|
54
|
-
__exportStar(require("./events/event-types/books/trope-created-event"), exports);
|
|
55
|
-
__exportStar(require("./events/event-types/books/trope-updated-event"), exports);
|
|
56
|
-
__exportStar(require("./events/event-types/books/trope-deleted-event"), exports);
|
|
57
|
-
// Trigger events
|
|
58
|
-
__exportStar(require("./events/event-types/books/trigger-created-event"), exports);
|
|
59
|
-
__exportStar(require("./events/event-types/books/trigger-updated-event"), exports);
|
|
60
|
-
__exportStar(require("./events/event-types/books/trigger-deleted-event"), exports);
|
|
61
|
-
// Chapter events
|
|
62
|
-
__exportStar(require("./events/event-types/books/chapter-created-event"), exports);
|
|
63
|
-
__exportStar(require("./events/event-types/books/chapter-updated-event"), exports);
|
|
64
|
-
__exportStar(require("./events/event-types/books/chapter-deleted-event"), exports);
|
|
65
|
-
// Author events
|
|
66
|
-
__exportStar(require("./events/event-types/auth/author-updated-event"), exports);
|
|
67
|
-
__exportStar(require("./events/event-types/auth/author-deleted-event"), exports);
|
|
68
|
-
__exportStar(require("./events/event-types/auth/author-verified-event"), exports);
|
|
69
|
-
__exportStar(require("./events/event-types/auth/author-signed-up-event"), exports);
|
|
70
|
-
__exportStar(require("./events/event-types/auth/author-signed-in-event"), exports);
|
|
71
|
-
__exportStar(require("./events/event-types/auth/author-signed-out-event"), exports);
|
|
72
|
-
// Reader events
|
|
73
|
-
__exportStar(require("./events/event-types/auth/reader-updated-event"), exports);
|
|
74
|
-
__exportStar(require("./events/event-types/auth/reader-deleted-event"), exports);
|
|
75
|
-
__exportStar(require("./events/event-types/auth/reader-signed-up-event"), exports);
|
|
76
|
-
__exportStar(require("./events/event-types/auth/reader-signed-in-event"), exports);
|
|
77
|
-
__exportStar(require("./events/event-types/auth/reader-signed-out-event"), exports);
|
|
78
|
-
__exportStar(require("./events/event-types/auth/reader-verified-event"), exports);
|
|
79
|
-
// Admin events
|
|
80
|
-
__exportStar(require("./events/event-types/auth/admin-signed-up-event"), exports);
|
|
81
|
-
__exportStar(require("./events/event-types/auth/admin-deleted-event"), exports);
|
|
82
|
-
__exportStar(require("./events/event-types/auth/admin-updated-event"), exports);
|
|
83
|
-
// Media events
|
|
84
|
-
__exportStar(require("./events/event-types/media/avatar-uploaded-event"), exports);
|
|
85
|
-
__exportStar(require("./events/event-types/orders/order-created-event"), exports);
|
|
86
|
-
__exportStar(require("./events/subjects"), exports);
|
|
87
|
-
__exportStar(require("./events/streams"), exports);
|
|
88
|
-
__exportStar(require("./nats-wrapper"), exports);
|
|
89
|
-
__exportStar(require("./redis-wrapper"), exports);
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.allowRoles = void 0;
|
|
4
|
-
const not_authorized_error_1 = require("../errors/not-authorized-error");
|
|
5
|
-
const forbidden_error_1 = require("../errors/forbidden-error");
|
|
6
|
-
const allowRoles = (roles) => {
|
|
7
|
-
return (req, res, next) => {
|
|
8
|
-
const currentUser = req.currentUser;
|
|
9
|
-
if (!currentUser) {
|
|
10
|
-
throw new not_authorized_error_1.NotAuthorizedError();
|
|
11
|
-
}
|
|
12
|
-
if (!roles.includes(currentUser.role)) {
|
|
13
|
-
throw new forbidden_error_1.ForbiddenError();
|
|
14
|
-
}
|
|
15
|
-
return next();
|
|
16
|
-
};
|
|
17
|
-
};
|
|
18
|
-
exports.allowRoles = allowRoles;
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { Request, Response, NextFunction } from 'express';
|
|
2
|
-
import { UserRoles } from '../enum/roles';
|
|
3
|
-
import { RedisWrapper } from '../redis-wrapper';
|
|
4
|
-
import NodeCache from 'node-cache';
|
|
5
|
-
export interface UserJwtPayload {
|
|
6
|
-
id: string;
|
|
7
|
-
email: string;
|
|
8
|
-
firstName: string;
|
|
9
|
-
lastName: string;
|
|
10
|
-
role: UserRoles;
|
|
11
|
-
}
|
|
12
|
-
export interface JwtPayload {
|
|
13
|
-
email: string;
|
|
14
|
-
firstName: string;
|
|
15
|
-
lastName: string;
|
|
16
|
-
role: UserRoles;
|
|
17
|
-
sub: string;
|
|
18
|
-
aud: string;
|
|
19
|
-
iss: string;
|
|
20
|
-
iat: number;
|
|
21
|
-
exp: number;
|
|
22
|
-
jti: string;
|
|
23
|
-
}
|
|
24
|
-
declare global {
|
|
25
|
-
namespace Express {
|
|
26
|
-
interface Request {
|
|
27
|
-
currentUser?: UserJwtPayload;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
export declare class CurrentUserMiddleware {
|
|
32
|
-
private readonly redisClient;
|
|
33
|
-
private readonly localCache;
|
|
34
|
-
constructor(params?: {
|
|
35
|
-
redisClient?: RedisWrapper;
|
|
36
|
-
localCache?: NodeCache;
|
|
37
|
-
});
|
|
38
|
-
getMiddleware(): (req: Request, res: Response, next: NextFunction) => Promise<void>;
|
|
39
|
-
}
|
|
40
|
-
export declare const currentUser: (req: Request, res: Response, next: NextFunction) => void;
|
|
@@ -1,88 +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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.currentUser = exports.CurrentUserMiddleware = void 0;
|
|
16
|
-
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
|
17
|
-
class CurrentUserMiddleware {
|
|
18
|
-
constructor(params) {
|
|
19
|
-
this.localCache = (params === null || params === void 0 ? void 0 : params.localCache) || null;
|
|
20
|
-
this.redisClient = (params === null || params === void 0 ? void 0 : params.redisClient) || null;
|
|
21
|
-
}
|
|
22
|
-
getMiddleware() {
|
|
23
|
-
return (req, res, next) => __awaiter(this, void 0, void 0, function* () {
|
|
24
|
-
var _a, _b, _c, _d;
|
|
25
|
-
try {
|
|
26
|
-
const token = (_a = req.headers['authorization']) === null || _a === void 0 ? void 0 : _a.split(' ')[1];
|
|
27
|
-
if (!token) {
|
|
28
|
-
return next();
|
|
29
|
-
}
|
|
30
|
-
const payload = jsonwebtoken_1.default.verify(token, process.env.JWT_KEY);
|
|
31
|
-
const userData = {
|
|
32
|
-
id: payload.sub,
|
|
33
|
-
email: payload.email,
|
|
34
|
-
firstName: payload.firstName,
|
|
35
|
-
lastName: payload.lastName,
|
|
36
|
-
role: payload.role,
|
|
37
|
-
};
|
|
38
|
-
// If JWT has jti claim — it’s important for revocation
|
|
39
|
-
const jti = payload.jti;
|
|
40
|
-
if (!jti) {
|
|
41
|
-
return next();
|
|
42
|
-
}
|
|
43
|
-
// Check local cache first (fast)
|
|
44
|
-
if ((_b = this.localCache) === null || _b === void 0 ? void 0 : _b.get(jti)) {
|
|
45
|
-
return next();
|
|
46
|
-
}
|
|
47
|
-
// Then check Redis
|
|
48
|
-
const redisResult = yield ((_c = this.redisClient) === null || _c === void 0 ? void 0 : _c.get(`revoked:${jti}`));
|
|
49
|
-
if (redisResult) {
|
|
50
|
-
// store in local cache to reduce redis lookups
|
|
51
|
-
(_d = this.localCache) === null || _d === void 0 ? void 0 : _d.set(jti, true, 60 * 5); // cache for 5 min
|
|
52
|
-
return next();
|
|
53
|
-
}
|
|
54
|
-
// All good — attach user
|
|
55
|
-
req.currentUser = userData;
|
|
56
|
-
next();
|
|
57
|
-
}
|
|
58
|
-
catch (err) {
|
|
59
|
-
console.error('Auth error:', err);
|
|
60
|
-
return next();
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
exports.CurrentUserMiddleware = CurrentUserMiddleware;
|
|
66
|
-
const currentUser = (req, res, next) => {
|
|
67
|
-
var _a;
|
|
68
|
-
const token = (_a = req.headers['authorization']) === null || _a === void 0 ? void 0 : _a.split(' ')[1];
|
|
69
|
-
if (!token) {
|
|
70
|
-
return next();
|
|
71
|
-
}
|
|
72
|
-
try {
|
|
73
|
-
const payload = jsonwebtoken_1.default.verify(token, process.env.JWT_KEY);
|
|
74
|
-
const userData = {
|
|
75
|
-
id: payload.sub,
|
|
76
|
-
email: payload.email,
|
|
77
|
-
firstName: payload.firstName,
|
|
78
|
-
lastName: payload.lastName,
|
|
79
|
-
role: payload.role,
|
|
80
|
-
};
|
|
81
|
-
req.currentUser = userData;
|
|
82
|
-
}
|
|
83
|
-
catch (err) {
|
|
84
|
-
console.log(err);
|
|
85
|
-
}
|
|
86
|
-
next();
|
|
87
|
-
};
|
|
88
|
-
exports.currentUser = currentUser;
|
|
@@ -1,14 +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
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
6
|
-
const errorHandler = (err, req, res, next) => {
|
|
7
|
-
if (err instanceof custom_error_1.CustomError) {
|
|
8
|
-
return res.status(err.statusCode).send({ errors: err.serializeErrors() });
|
|
9
|
-
}
|
|
10
|
-
res.status(400).send({
|
|
11
|
-
errors: [{ message: 'Something went wrong' }],
|
|
12
|
-
});
|
|
13
|
-
};
|
|
14
|
-
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>, field?: 'body' | 'query' | 'params', 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, field = 'body', 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[field]);
|
|
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 = (0, class_transformer_1.instanceToPlain)(dto, { exposeUnsetFields: false });
|
|
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,92 +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, _c;
|
|
43
|
-
try {
|
|
44
|
-
const streamInfo = yield ((_a = this.jetStreamManager) === null || _a === void 0 ? void 0 : _a.streams.info(this.stream));
|
|
45
|
-
// Check if subjects need to be updated
|
|
46
|
-
const existingSubjects = (streamInfo === null || streamInfo === void 0 ? void 0 : streamInfo.config.subjects) || [];
|
|
47
|
-
const missingSubjects = this.subjects.filter(s => !existingSubjects.includes(s));
|
|
48
|
-
if (missingSubjects.length > 0) {
|
|
49
|
-
// Merge existing subjects with new ones and update the stream
|
|
50
|
-
const allSubjects = [...new Set([...existingSubjects, ...this.subjects])];
|
|
51
|
-
yield ((_b = this.jetStreamManager) === null || _b === void 0 ? void 0 : _b.streams.update(this.stream, {
|
|
52
|
-
subjects: allSubjects,
|
|
53
|
-
}));
|
|
54
|
-
console.log(`✅ Updated stream "${this.stream}" with new subjects:`, missingSubjects);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
catch (_d) {
|
|
58
|
-
// Stream doesn't exist, create it
|
|
59
|
-
yield ((_c = this.jetStreamManager) === null || _c === void 0 ? void 0 : _c.streams.add({
|
|
60
|
-
name: this.stream,
|
|
61
|
-
subjects: this.subjects,
|
|
62
|
-
}));
|
|
63
|
-
console.log(`✅ Created stream "${this.stream}" with subjects:`, this.subjects);
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
connect(server) {
|
|
68
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
69
|
-
let connectionAttempts = 0;
|
|
70
|
-
while (connectionAttempts < 6) {
|
|
71
|
-
try {
|
|
72
|
-
const connection = yield (0, nats_1.connect)({
|
|
73
|
-
servers: [server],
|
|
74
|
-
});
|
|
75
|
-
this._natsConnection = connection;
|
|
76
|
-
this._jetStreamClient = connection.jetstream();
|
|
77
|
-
this._jetStreamManager = yield connection.jetstreamManager();
|
|
78
|
-
yield this.ensureStreamExists();
|
|
79
|
-
console.log('✅ Connected to NATS');
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
catch (e) {
|
|
83
|
-
console.error('❌ NATS connection failed, retrying in 3s...', e.message);
|
|
84
|
-
yield new Promise(res => setTimeout(res, 3000));
|
|
85
|
-
connectionAttempts++;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
throw new Error('NATS connection failed');
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
exports.NatsWrapper = NatsWrapper;
|
package/build/redis-wrapper.d.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { Redis } from 'ioredis';
|
|
2
|
-
declare class RedisWrapper {
|
|
3
|
-
private _client;
|
|
4
|
-
private host;
|
|
5
|
-
private port;
|
|
6
|
-
private username;
|
|
7
|
-
private password;
|
|
8
|
-
constructor(params?: {
|
|
9
|
-
host?: string;
|
|
10
|
-
port?: number;
|
|
11
|
-
username?: string;
|
|
12
|
-
password?: string;
|
|
13
|
-
});
|
|
14
|
-
connect(): Promise<void>;
|
|
15
|
-
disconnect(): Promise<void>;
|
|
16
|
-
set(key: string, value: string, expireInSeconds: number): Promise<void>;
|
|
17
|
-
get(key: string): Promise<string | null>;
|
|
18
|
-
get client(): Redis;
|
|
19
|
-
}
|
|
20
|
-
export { RedisWrapper };
|
package/build/redis-wrapper.js
DELETED
|
@@ -1,77 +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.RedisWrapper = void 0;
|
|
13
|
-
const ioredis_1 = require("ioredis");
|
|
14
|
-
class RedisWrapper {
|
|
15
|
-
constructor(params) {
|
|
16
|
-
this._client = null;
|
|
17
|
-
this.host = (params === null || params === void 0 ? void 0 : params.host) || 'localhost';
|
|
18
|
-
this.port = (params === null || params === void 0 ? void 0 : params.port) || 6379;
|
|
19
|
-
this.username = (params === null || params === void 0 ? void 0 : params.username) || '';
|
|
20
|
-
this.password = (params === null || params === void 0 ? void 0 : params.password) || '';
|
|
21
|
-
}
|
|
22
|
-
connect() {
|
|
23
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
24
|
-
try {
|
|
25
|
-
this._client = new ioredis_1.Redis({
|
|
26
|
-
host: this.host,
|
|
27
|
-
port: this.port,
|
|
28
|
-
username: this.username,
|
|
29
|
-
password: this.password,
|
|
30
|
-
lazyConnect: true,
|
|
31
|
-
});
|
|
32
|
-
yield this._client.connect();
|
|
33
|
-
console.log('✅ Connected to Redis');
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
catch (e) {
|
|
37
|
-
console.error('❌ Error connecting to Redis:', e.message);
|
|
38
|
-
}
|
|
39
|
-
console.log('❌ Failed to connect to Redis');
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
disconnect() {
|
|
43
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
-
try {
|
|
45
|
-
if (this._client) {
|
|
46
|
-
yield this._client.quit();
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
catch (e) {
|
|
50
|
-
console.error('❌ Error disconnecting from Redis:', e.message);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
set(key, value, expireInSeconds) {
|
|
55
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
56
|
-
if (!this._client) {
|
|
57
|
-
throw new Error('Redis not connected');
|
|
58
|
-
}
|
|
59
|
-
yield this._client.set(key, value, 'EX', expireInSeconds);
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
get(key) {
|
|
63
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
-
if (!this._client) {
|
|
65
|
-
throw new Error('Redis not connected');
|
|
66
|
-
}
|
|
67
|
-
return yield this._client.get(key);
|
|
68
|
-
});
|
|
69
|
-
}
|
|
70
|
-
get client() {
|
|
71
|
-
if (!this._client) {
|
|
72
|
-
throw new Error('Cannot access Redis client before connecting');
|
|
73
|
-
}
|
|
74
|
-
return this._client;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
exports.RedisWrapper = RedisWrapper;
|
package/build/test/setup.d.ts
DELETED
package/build/test/setup.js
DELETED
|
@@ -1,45 +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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.createTestToken = void 0;
|
|
16
|
-
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
|
17
|
-
const roles_1 = require("../enum/roles");
|
|
18
|
-
// Set up environment variables for tests
|
|
19
|
-
process.env.JWT_KEY = 'test-jwt-key';
|
|
20
|
-
// Helper to create signed JWT tokens for testing
|
|
21
|
-
const createTestToken = (userId = '507f1f77bcf86cd799439011', role = roles_1.UserRoles.reader, options) => {
|
|
22
|
-
const payload = {
|
|
23
|
-
email: (options === null || options === void 0 ? void 0 : options.email) || 'test@test.com',
|
|
24
|
-
firstName: (options === null || options === void 0 ? void 0 : options.firstName) || 'Test',
|
|
25
|
-
lastName: (options === null || options === void 0 ? void 0 : options.lastName) || 'User',
|
|
26
|
-
role,
|
|
27
|
-
};
|
|
28
|
-
const signOptions = {
|
|
29
|
-
subject: userId,
|
|
30
|
-
audience: 'eratu',
|
|
31
|
-
issuer: 'eratu-auth',
|
|
32
|
-
expiresIn: ((options === null || options === void 0 ? void 0 : options.expiresIn) || '1h'),
|
|
33
|
-
};
|
|
34
|
-
if (options === null || options === void 0 ? void 0 : options.jti) {
|
|
35
|
-
signOptions.jwtid = options.jti;
|
|
36
|
-
}
|
|
37
|
-
return jsonwebtoken_1.default.sign(payload, process.env.JWT_KEY, signOptions);
|
|
38
|
-
};
|
|
39
|
-
exports.createTestToken = createTestToken;
|
|
40
|
-
// Global test timeout
|
|
41
|
-
jest.setTimeout(30000);
|
|
42
|
-
// Clean up after all tests
|
|
43
|
-
afterAll(() => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
|
-
// Any global cleanup can be added here
|
|
45
|
-
}));
|