@lenne.tech/nest-server 11.4.2 → 11.4.3
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.
|
@@ -10,6 +10,7 @@ exports.MapAndValidatePipe = void 0;
|
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
11
|
const class_transformer_1 = require("class-transformer");
|
|
12
12
|
const class_validator_1 = require("class-validator");
|
|
13
|
+
const util_1 = require("util");
|
|
13
14
|
const input_helper_1 = require("../helpers/input.helper");
|
|
14
15
|
const DEBUG_VALIDATION = process.env.DEBUG_VALIDATION === 'true';
|
|
15
16
|
let MapAndValidatePipe = class MapAndValidatePipe {
|
|
@@ -23,7 +24,7 @@ let MapAndValidatePipe = class MapAndValidatePipe {
|
|
|
23
24
|
type: metadata.type,
|
|
24
25
|
});
|
|
25
26
|
console.debug('Input value type:', typeof value);
|
|
26
|
-
console.debug('Input value:',
|
|
27
|
+
console.debug('Input value:', (0, util_1.inspect)(value, { colors: true, depth: 3 }));
|
|
27
28
|
}
|
|
28
29
|
if (!value || typeof value !== 'object' || !metatype || (0, input_helper_1.isBasicType)(metatype)) {
|
|
29
30
|
if (DEBUG_VALIDATION) {
|
|
@@ -45,7 +46,7 @@ let MapAndValidatePipe = class MapAndValidatePipe {
|
|
|
45
46
|
}
|
|
46
47
|
value = (0, class_transformer_1.plainToInstance)(metatype, value);
|
|
47
48
|
if (DEBUG_VALIDATION) {
|
|
48
|
-
console.debug('Transformed value:',
|
|
49
|
+
console.debug('Transformed value:', (0, util_1.inspect)(value, { colors: true, depth: 3 }));
|
|
49
50
|
console.debug('Transformed value instance of:', value?.constructor?.name);
|
|
50
51
|
}
|
|
51
52
|
}
|
|
@@ -77,6 +78,7 @@ let MapAndValidatePipe = class MapAndValidatePipe {
|
|
|
77
78
|
});
|
|
78
79
|
}
|
|
79
80
|
const result = {};
|
|
81
|
+
const errorSummary = [];
|
|
80
82
|
const processErrors = (errorList, parentKey = '') => {
|
|
81
83
|
errorList.forEach((e) => {
|
|
82
84
|
const key = parentKey ? `${parentKey}.${e.property}` : e.property;
|
|
@@ -85,17 +87,35 @@ let MapAndValidatePipe = class MapAndValidatePipe {
|
|
|
85
87
|
}
|
|
86
88
|
else {
|
|
87
89
|
result[key] = e.constraints;
|
|
90
|
+
if (e.constraints) {
|
|
91
|
+
const constraintTypes = Object.keys(e.constraints).join(', ');
|
|
92
|
+
errorSummary.push(`${key} (${constraintTypes})`);
|
|
93
|
+
}
|
|
88
94
|
}
|
|
89
95
|
});
|
|
90
96
|
};
|
|
91
97
|
processErrors(errors);
|
|
92
98
|
if (DEBUG_VALIDATION) {
|
|
93
99
|
console.debug('\nProcessed validation result:');
|
|
94
|
-
console.debug(
|
|
100
|
+
console.debug((0, util_1.inspect)(result, { colors: true, depth: 5 }));
|
|
95
101
|
console.debug('Result is empty:', Object.keys(result).length === 0);
|
|
102
|
+
console.debug('Error summary:', errorSummary);
|
|
96
103
|
console.debug('=== End Debug ===\n');
|
|
97
104
|
}
|
|
98
|
-
|
|
105
|
+
let errorMessage = 'Validation failed';
|
|
106
|
+
if (errorSummary.length > 0) {
|
|
107
|
+
const fieldCount = errorSummary.length;
|
|
108
|
+
const fieldWord = fieldCount === 1 ? 'field' : 'fields';
|
|
109
|
+
errorMessage = `Validation failed for ${fieldCount} ${fieldWord}: ${errorSummary.join('; ')}`;
|
|
110
|
+
}
|
|
111
|
+
else if (errors.length > 0) {
|
|
112
|
+
const topLevelProperties = errors.map((e) => e.property).join(', ');
|
|
113
|
+
errorMessage = `Validation failed for properties: ${topLevelProperties} (nested validation errors)`;
|
|
114
|
+
}
|
|
115
|
+
throw new common_1.BadRequestException({
|
|
116
|
+
message: errorMessage,
|
|
117
|
+
...result,
|
|
118
|
+
});
|
|
99
119
|
}
|
|
100
120
|
if (DEBUG_VALIDATION) {
|
|
101
121
|
console.debug('Validation successful - no errors');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"map-and-validate.pipe.js","sourceRoot":"","sources":["../../../../src/core/common/pipes/map-and-validate.pipe.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAkG;AAClG,yDAAoD;AACpD,qDAA4D;
|
|
1
|
+
{"version":3,"file":"map-and-validate.pipe.js","sourceRoot":"","sources":["../../../../src/core/common/pipes/map-and-validate.pipe.ts"],"names":[],"mappings":"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"}
|