@lenne.tech/nest-server 11.4.0 → 11.4.2
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/dist/core/common/pipes/map-and-validate.pipe.js +59 -0
- package/dist/core/common/pipes/map-and-validate.pipe.js.map +1 -1
- package/dist/core/modules/migrate/templates/migration-project.template.ts +53 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +3 -2
- package/src/core/common/pipes/map-and-validate.pipe.ts +67 -0
- package/src/core/modules/migrate/MIGRATION_FROM_NODEPIT.md +150 -71
- package/src/core/modules/migrate/README.md +9 -8
- package/src/core/modules/migrate/templates/migration-project.template.ts +53 -0
- package/dist/core/modules/migrate/templates/migration-with-helper.template.d.ts +0 -2
- package/dist/core/modules/migrate/templates/migration-with-helper.template.js +0 -10
- package/dist/core/modules/migrate/templates/migration-with-helper.template.js.map +0 -1
- package/dist/core/modules/migrate/templates/migration.template.d.ts +0 -2
- package/dist/core/modules/migrate/templates/migration.template.js +0 -15
- package/dist/core/modules/migrate/templates/migration.template.js.map +0 -1
- package/src/core/modules/migrate/templates/migration-with-helper.template.ts +0 -72
- package/src/core/modules/migrate/templates/migration.template.ts +0 -59
|
@@ -11,22 +11,71 @@ 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
13
|
const input_helper_1 = require("../helpers/input.helper");
|
|
14
|
+
const DEBUG_VALIDATION = process.env.DEBUG_VALIDATION === 'true';
|
|
14
15
|
let MapAndValidatePipe = class MapAndValidatePipe {
|
|
15
16
|
async transform(value, metadata) {
|
|
16
17
|
const { metatype } = metadata;
|
|
18
|
+
if (DEBUG_VALIDATION) {
|
|
19
|
+
console.debug('\n=== MapAndValidatePipe Debug ===');
|
|
20
|
+
console.debug('Metadata:', {
|
|
21
|
+
data: metadata.data,
|
|
22
|
+
metatype: metatype?.name,
|
|
23
|
+
type: metadata.type,
|
|
24
|
+
});
|
|
25
|
+
console.debug('Input value type:', typeof value);
|
|
26
|
+
console.debug('Input value:', JSON.stringify(value, null, 2));
|
|
27
|
+
}
|
|
17
28
|
if (!value || typeof value !== 'object' || !metatype || (0, input_helper_1.isBasicType)(metatype)) {
|
|
29
|
+
if (DEBUG_VALIDATION) {
|
|
30
|
+
console.debug('Skipping validation - basic type or no metatype');
|
|
31
|
+
console.debug('=== End Debug ===\n');
|
|
32
|
+
}
|
|
18
33
|
return value;
|
|
19
34
|
}
|
|
20
35
|
if (!(value instanceof metatype)) {
|
|
21
36
|
if (metatype?.map) {
|
|
37
|
+
if (DEBUG_VALIDATION) {
|
|
38
|
+
console.debug('Using custom map function');
|
|
39
|
+
}
|
|
22
40
|
value = metatype?.map(value);
|
|
23
41
|
}
|
|
24
42
|
else {
|
|
43
|
+
if (DEBUG_VALIDATION) {
|
|
44
|
+
console.debug('Using plainToInstance to transform to:', metatype.name);
|
|
45
|
+
}
|
|
25
46
|
value = (0, class_transformer_1.plainToInstance)(metatype, value);
|
|
47
|
+
if (DEBUG_VALIDATION) {
|
|
48
|
+
console.debug('Transformed value:', JSON.stringify(value, null, 2));
|
|
49
|
+
console.debug('Transformed value instance of:', value?.constructor?.name);
|
|
50
|
+
}
|
|
26
51
|
}
|
|
27
52
|
}
|
|
53
|
+
if (DEBUG_VALIDATION) {
|
|
54
|
+
console.debug('Starting validation...');
|
|
55
|
+
}
|
|
28
56
|
const errors = await (0, class_validator_1.validate)(value, { forbidUnknownValues: false });
|
|
29
57
|
if (errors.length > 0) {
|
|
58
|
+
if (DEBUG_VALIDATION) {
|
|
59
|
+
console.debug('Validation errors found:', errors.length);
|
|
60
|
+
console.debug('Raw validation errors:');
|
|
61
|
+
errors.forEach((err, index) => {
|
|
62
|
+
console.debug(`\nError ${index + 1}:`);
|
|
63
|
+
console.debug(' Property:', err.property);
|
|
64
|
+
console.debug(' Value:', err.value);
|
|
65
|
+
console.debug(' Constraints:', err.constraints);
|
|
66
|
+
console.debug(' Children:', err.children?.length || 0);
|
|
67
|
+
if (err.children && err.children.length > 0) {
|
|
68
|
+
console.debug(' Children details:');
|
|
69
|
+
err.children.forEach((child, childIndex) => {
|
|
70
|
+
console.debug(` Child ${childIndex + 1}:`);
|
|
71
|
+
console.debug(' Property:', child.property);
|
|
72
|
+
console.debug(' Value:', child.value);
|
|
73
|
+
console.debug(' Constraints:', child.constraints);
|
|
74
|
+
console.debug(' Has children:', (child.children?.length || 0) > 0);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
30
79
|
const result = {};
|
|
31
80
|
const processErrors = (errorList, parentKey = '') => {
|
|
32
81
|
errorList.forEach((e) => {
|
|
@@ -40,8 +89,18 @@ let MapAndValidatePipe = class MapAndValidatePipe {
|
|
|
40
89
|
});
|
|
41
90
|
};
|
|
42
91
|
processErrors(errors);
|
|
92
|
+
if (DEBUG_VALIDATION) {
|
|
93
|
+
console.debug('\nProcessed validation result:');
|
|
94
|
+
console.debug(JSON.stringify(result, null, 2));
|
|
95
|
+
console.debug('Result is empty:', Object.keys(result).length === 0);
|
|
96
|
+
console.debug('=== End Debug ===\n');
|
|
97
|
+
}
|
|
43
98
|
throw new common_1.BadRequestException(result);
|
|
44
99
|
}
|
|
100
|
+
if (DEBUG_VALIDATION) {
|
|
101
|
+
console.debug('Validation successful - no errors');
|
|
102
|
+
console.debug('=== End Debug ===\n');
|
|
103
|
+
}
|
|
45
104
|
return value;
|
|
46
105
|
}
|
|
47
106
|
};
|
|
@@ -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;AAE5D,0DAAsD;
|
|
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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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getDb, uploadFileToGridFS } from '@lenne.tech/nest-server';
|
|
2
|
+
import { Db, ObjectId } from 'mongodb';
|
|
3
|
+
import config from '../src/config.env';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Migration template for nest-server projects
|
|
7
|
+
*
|
|
8
|
+
* This template is ready-to-use for @lenne.tech/nest-server projects.
|
|
9
|
+
* It imports the necessary helpers and config automatically.
|
|
10
|
+
*
|
|
11
|
+
* Available helpers:
|
|
12
|
+
* - getDb(uri): Get MongoDB connection
|
|
13
|
+
* - uploadFileToGridFS(uri, filePath, options): Upload file to GridFS
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
const MONGO_URL = config.mongoose.uri;
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Run migration
|
|
20
|
+
*
|
|
21
|
+
* Code your update script here!
|
|
22
|
+
*/
|
|
23
|
+
export const up = async () => {
|
|
24
|
+
const db: Db = await getDb(MONGO_URL);
|
|
25
|
+
|
|
26
|
+
// Example: Add a new field to all documents in a collection
|
|
27
|
+
// await db.collection('users').updateMany(
|
|
28
|
+
// { email: { $exists: false } },
|
|
29
|
+
// { $set: { email: '' } }
|
|
30
|
+
// );
|
|
31
|
+
|
|
32
|
+
// Example: Upload a file to GridFS
|
|
33
|
+
// const fileId: ObjectId = await uploadFileToGridFS(
|
|
34
|
+
// MONGO_URL,
|
|
35
|
+
// '../assets/image.png',
|
|
36
|
+
// { bucketName: 'images', filename: 'logo.png' }
|
|
37
|
+
// );
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Rollback migration
|
|
42
|
+
*
|
|
43
|
+
* Code your downgrade script here!
|
|
44
|
+
*/
|
|
45
|
+
export const down = async () => {
|
|
46
|
+
const db: Db = await getDb(MONGO_URL);
|
|
47
|
+
|
|
48
|
+
// Example: Remove the field added in the up() function
|
|
49
|
+
// await db.collection('users').updateMany(
|
|
50
|
+
// {},
|
|
51
|
+
// { $unset: { email: '' } }
|
|
52
|
+
// );
|
|
53
|
+
};
|