@eratu/common 1.0.10 → 1.0.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -0,0 +1,10 @@
|
|
|
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 = {}));
|
package/build/index.d.ts
CHANGED
|
@@ -7,6 +7,8 @@ export * from "./errors/request-validation-error";
|
|
|
7
7
|
export * from "./middlewares/current-user";
|
|
8
8
|
export * from "./middlewares/error-handler";
|
|
9
9
|
export * from "./middlewares/require-auth";
|
|
10
|
+
export * from "./middlewares/validation";
|
|
11
|
+
export * from "./enum/roles";
|
|
10
12
|
export * from "./events/listeners/base-listener";
|
|
11
13
|
export * from "./events/publishers/base-publisher";
|
|
12
14
|
export * from "./events/event-types/books/book-created-event";
|
package/build/index.js
CHANGED
|
@@ -23,6 +23,9 @@ __exportStar(require("./errors/request-validation-error"), exports);
|
|
|
23
23
|
__exportStar(require("./middlewares/current-user"), exports);
|
|
24
24
|
__exportStar(require("./middlewares/error-handler"), exports);
|
|
25
25
|
__exportStar(require("./middlewares/require-auth"), exports);
|
|
26
|
+
__exportStar(require("./middlewares/validation"), exports);
|
|
27
|
+
// Enums
|
|
28
|
+
__exportStar(require("./enum/roles"), exports);
|
|
26
29
|
__exportStar(require("./events/listeners/base-listener"), exports);
|
|
27
30
|
__exportStar(require("./events/publishers/base-publisher"), exports);
|
|
28
31
|
__exportStar(require("./events/event-types/books/book-created-event"), exports);
|
|
@@ -0,0 +1,3 @@
|
|
|
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>;
|
|
@@ -0,0 +1,57 @@
|
|
|
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
|
+
success: false,
|
|
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
|
+
success: false,
|
|
53
|
+
message: 'Internal server error during validation',
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@eratu/common",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.11",
|
|
4
4
|
"description": "A package for shared code across microservices",
|
|
5
5
|
"main": "./build/index.js",
|
|
6
6
|
"types": "./build/index.d.ts",
|
|
@@ -23,6 +23,8 @@
|
|
|
23
23
|
"dependencies": {
|
|
24
24
|
"@types/express": "^5.0.3",
|
|
25
25
|
"@types/jsonwebtoken": "^9.0.10",
|
|
26
|
+
"class-transformer": "^0.5.1",
|
|
27
|
+
"class-validator": "^0.14.2",
|
|
26
28
|
"cookie-session": "^2.1.0",
|
|
27
29
|
"express": "^4.21.2",
|
|
28
30
|
"express-validator": "^7.2.1",
|