@decaf-ts/decorator-validation 1.7.3 → 1.7.5

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 (134) hide show
  1. package/LICENSE.md +21 -157
  2. package/dist/decorator-validation.cjs +461 -265
  3. package/dist/decorator-validation.esm.cjs +459 -265
  4. package/lib/constants/errors.cjs +19 -0
  5. package/lib/constants/errors.d.ts +11 -0
  6. package/lib/constants/index.cjs +2 -1
  7. package/lib/constants/index.d.ts +1 -0
  8. package/lib/esm/constants/errors.d.ts +11 -0
  9. package/lib/esm/constants/errors.js +16 -0
  10. package/lib/esm/constants/index.d.ts +1 -0
  11. package/lib/esm/constants/index.js +3 -2
  12. package/lib/esm/index.d.ts +1 -1
  13. package/lib/esm/index.js +6 -6
  14. package/lib/esm/mcp/ModelContextProtocol.d.ts +31 -0
  15. package/lib/esm/mcp/ModelContextProtocol.js +66 -0
  16. package/lib/esm/mcp/mcp1.d.ts +0 -0
  17. package/lib/esm/mcp/mcp1.js +405 -0
  18. package/lib/esm/mcp/tools/createModel.tool.d.ts +0 -0
  19. package/lib/esm/mcp/tools/createModel.tool.js +67 -0
  20. package/lib/esm/mcp/tools/validateModel.tool.d.ts +0 -0
  21. package/lib/esm/mcp/tools/validateModel.tool.js +2 -0
  22. package/lib/esm/mcp/types.d.ts +3 -0
  23. package/lib/esm/mcp/types.js +2 -0
  24. package/lib/esm/model/Builder.d.ts +0 -0
  25. package/lib/esm/model/Builder.js +130 -0
  26. package/lib/esm/model/Model.d.ts +1 -0
  27. package/lib/esm/model/Model.js +19 -9
  28. package/lib/esm/model/construction.js +2 -2
  29. package/lib/esm/model/decorators.d.ts +10 -0
  30. package/lib/esm/model/decorators.js +16 -4
  31. package/lib/esm/model/index.js +9 -9
  32. package/lib/esm/model/utils.js +2 -2
  33. package/lib/esm/model/validation.js +16 -13
  34. package/lib/esm/utils/Decoration.js +2 -2
  35. package/lib/esm/utils/PathProxy.d.ts +43 -0
  36. package/lib/esm/utils/PathProxy.js +89 -0
  37. package/lib/esm/utils/constants.d.ts +1 -0
  38. package/lib/esm/utils/constants.js +2 -1
  39. package/lib/esm/utils/dates.js +3 -3
  40. package/lib/esm/utils/decorators.js +2 -2
  41. package/lib/esm/utils/index.d.ts +1 -0
  42. package/lib/esm/utils/index.js +11 -10
  43. package/lib/esm/utils/serialization.js +4 -4
  44. package/lib/esm/validation/Validation.d.ts +3 -0
  45. package/lib/esm/validation/Validation.js +14 -3
  46. package/lib/esm/validation/Validators/DateValidator.js +4 -4
  47. package/lib/esm/validation/Validators/DiffValidator.d.ts +4 -2
  48. package/lib/esm/validation/Validators/DiffValidator.js +8 -8
  49. package/lib/esm/validation/Validators/EmailValidator.js +4 -4
  50. package/lib/esm/validation/Validators/EqualsValidator.d.ts +4 -2
  51. package/lib/esm/validation/Validators/EqualsValidator.js +8 -8
  52. package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.d.ts +4 -2
  53. package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +9 -8
  54. package/lib/esm/validation/Validators/GreaterThanValidator.d.ts +4 -2
  55. package/lib/esm/validation/Validators/GreaterThanValidator.js +9 -8
  56. package/lib/esm/validation/Validators/LessThanOrEqualValidator.d.ts +4 -2
  57. package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +9 -8
  58. package/lib/esm/validation/Validators/LessThanValidator.d.ts +4 -2
  59. package/lib/esm/validation/Validators/LessThanValidator.js +9 -8
  60. package/lib/esm/validation/Validators/ListValidator.js +4 -4
  61. package/lib/esm/validation/Validators/MaxLengthValidator.js +4 -4
  62. package/lib/esm/validation/Validators/MaxValidator.js +4 -4
  63. package/lib/esm/validation/Validators/MinLengthValidator.js +4 -4
  64. package/lib/esm/validation/Validators/MinValidator.js +4 -4
  65. package/lib/esm/validation/Validators/PasswordValidator.js +4 -4
  66. package/lib/esm/validation/Validators/PatternValidator.js +4 -4
  67. package/lib/esm/validation/Validators/RequiredValidator.js +4 -4
  68. package/lib/esm/validation/Validators/StepValidator.js +4 -4
  69. package/lib/esm/validation/Validators/TypeValidator.js +6 -6
  70. package/lib/esm/validation/Validators/URLValidator.js +4 -4
  71. package/lib/esm/validation/Validators/Validator.d.ts +3 -2
  72. package/lib/esm/validation/Validators/Validator.js +3 -3
  73. package/lib/esm/validation/Validators/ValidatorRegistry.js +2 -2
  74. package/lib/esm/validation/Validators/constants.d.ts +0 -13
  75. package/lib/esm/validation/Validators/constants.js +2 -15
  76. package/lib/esm/validation/Validators/decorators.js +3 -3
  77. package/lib/esm/validation/Validators/index.js +25 -25
  78. package/lib/esm/validation/Validators/utils.d.ts +0 -14
  79. package/lib/esm/validation/Validators/utils.js +69 -56
  80. package/lib/esm/validation/decorators.d.ts +26 -3
  81. package/lib/esm/validation/decorators.js +107 -58
  82. package/lib/esm/validation/index.js +5 -5
  83. package/lib/esm/validation/types.d.ts +11 -5
  84. package/lib/esm/validation/types.js +2 -2
  85. package/lib/index.cjs +1 -1
  86. package/lib/index.d.ts +1 -1
  87. package/lib/mcp/ModelContextProtocol.cjs +70 -0
  88. package/lib/mcp/ModelContextProtocol.d.ts +31 -0
  89. package/lib/mcp/mcp1.cjs +405 -0
  90. package/lib/mcp/mcp1.d.ts +0 -0
  91. package/lib/mcp/tools/createModel.tool.cjs +67 -0
  92. package/lib/mcp/tools/createModel.tool.d.ts +0 -0
  93. package/lib/mcp/tools/validateModel.tool.cjs +2 -0
  94. package/lib/mcp/tools/validateModel.tool.d.ts +0 -0
  95. package/lib/mcp/types.cjs +3 -0
  96. package/lib/mcp/types.d.ts +3 -0
  97. package/lib/model/Builder.cjs +130 -0
  98. package/lib/model/Builder.d.ts +0 -0
  99. package/lib/model/Model.cjs +12 -2
  100. package/lib/model/Model.d.ts +1 -0
  101. package/lib/model/decorators.cjs +14 -1
  102. package/lib/model/decorators.d.ts +10 -0
  103. package/lib/model/validation.cjs +8 -5
  104. package/lib/utils/PathProxy.cjs +93 -0
  105. package/lib/utils/PathProxy.d.ts +43 -0
  106. package/lib/utils/constants.cjs +2 -1
  107. package/lib/utils/constants.d.ts +1 -0
  108. package/lib/utils/index.cjs +2 -1
  109. package/lib/utils/index.d.ts +1 -0
  110. package/lib/validation/Validation.cjs +12 -1
  111. package/lib/validation/Validation.d.ts +3 -0
  112. package/lib/validation/Validators/DiffValidator.cjs +5 -5
  113. package/lib/validation/Validators/DiffValidator.d.ts +4 -2
  114. package/lib/validation/Validators/EqualsValidator.cjs +5 -5
  115. package/lib/validation/Validators/EqualsValidator.d.ts +4 -2
  116. package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +5 -4
  117. package/lib/validation/Validators/GreaterThanOrEqualValidator.d.ts +4 -2
  118. package/lib/validation/Validators/GreaterThanValidator.cjs +5 -4
  119. package/lib/validation/Validators/GreaterThanValidator.d.ts +4 -2
  120. package/lib/validation/Validators/LessThanOrEqualValidator.cjs +5 -4
  121. package/lib/validation/Validators/LessThanOrEqualValidator.d.ts +4 -2
  122. package/lib/validation/Validators/LessThanValidator.cjs +5 -4
  123. package/lib/validation/Validators/LessThanValidator.d.ts +4 -2
  124. package/lib/validation/Validators/Validator.cjs +1 -1
  125. package/lib/validation/Validators/Validator.d.ts +3 -2
  126. package/lib/validation/Validators/constants.cjs +2 -15
  127. package/lib/validation/Validators/constants.d.ts +0 -13
  128. package/lib/validation/Validators/utils.cjs +79 -67
  129. package/lib/validation/Validators/utils.d.ts +0 -14
  130. package/lib/validation/decorators.cjs +102 -52
  131. package/lib/validation/decorators.d.ts +26 -3
  132. package/lib/validation/types.cjs +1 -1
  133. package/lib/validation/types.d.ts +11 -5
  134. package/package.json +16 -5
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validationMetadata = validationMetadata;
3
4
  exports.required = required;
4
5
  exports.min = min;
5
6
  exports.max = max;
@@ -27,6 +28,23 @@ const dates_1 = require("./../utils/dates.cjs");
27
28
  const decorators_1 = require("./../utils/decorators.cjs");
28
29
  const Validation_1 = require("./Validation.cjs");
29
30
  const Decoration_1 = require("./../utils/Decoration.cjs");
31
+ const reflection_1 = require("@decaf-ts/reflection");
32
+ /**
33
+ * @description Combined property decorator factory for metadata and attribute marking
34
+ * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it
35
+ *
36
+ * @template V
37
+ * @param {PropertyDecorator} decorator - The metadata key
38
+ * @param {string} key - The metadata key
39
+ * @param {V} value - The metadata value to associate with the property
40
+ * @return {Function} - Combined decorator function
41
+ * @function validationMetadata
42
+ * @category Property Decorators
43
+ */
44
+ function validationMetadata(decorator, key, value) {
45
+ Validation_1.Validation.registerDecorator(key, decorator);
46
+ return (0, reflection_1.apply)((0, decorators_1.propMetadata)(key, value));
47
+ }
30
48
  /**
31
49
  * @description Property decorator that marks a field as required
32
50
  * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.
@@ -52,10 +70,12 @@ const Decoration_1 = require("./../utils/Decoration.cjs");
52
70
  */
53
71
  function required(message = constants_1.DEFAULT_ERROR_MESSAGES.REQUIRED) {
54
72
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.REQUIRED);
55
- return Decoration_1.Decoration.for(key)
56
- .define((0, decorators_1.propMetadata)(key, {
73
+ const meta = {
57
74
  message: message,
58
- }))
75
+ description: `defines the attribute as required`,
76
+ };
77
+ return Decoration_1.Decoration.for(key)
78
+ .define(validationMetadata(required, key, meta))
59
79
  .apply();
60
80
  }
61
81
  /**
@@ -84,12 +104,14 @@ function required(message = constants_1.DEFAULT_ERROR_MESSAGES.REQUIRED) {
84
104
  */
85
105
  function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
86
106
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.MIN);
87
- return Decoration_1.Decoration.for(key)
88
- .define((0, decorators_1.propMetadata)(key, {
107
+ const meta = {
89
108
  [constants_1.ValidationKeys.MIN]: value,
90
109
  message: message,
91
110
  types: [Number.name, Date.name],
92
- }))
111
+ description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,
112
+ };
113
+ return Decoration_1.Decoration.for(key)
114
+ .define(validationMetadata(min, key, meta))
93
115
  .apply();
94
116
  }
95
117
  /**
@@ -104,12 +126,14 @@ function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
104
126
  */
105
127
  function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
106
128
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.MAX);
107
- return Decoration_1.Decoration.for(key)
108
- .define((0, decorators_1.propMetadata)(key, {
129
+ const meta = {
109
130
  [constants_1.ValidationKeys.MAX]: value,
110
131
  message: message,
111
132
  types: [Number.name, Date.name],
112
- }))
133
+ description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,
134
+ };
135
+ return Decoration_1.Decoration.for(key)
136
+ .define(validationMetadata(max, key, meta))
113
137
  .apply();
114
138
  }
115
139
  /**
@@ -124,12 +148,14 @@ function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
124
148
  */
125
149
  function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
126
150
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.STEP);
127
- return Decoration_1.Decoration.for(key)
128
- .define((0, decorators_1.propMetadata)(key, {
151
+ const meta = {
129
152
  [constants_1.ValidationKeys.STEP]: value,
130
153
  message: message,
131
154
  types: [Number.name],
132
- }))
155
+ description: `defines the step of the attribute as ${value}`,
156
+ };
157
+ return Decoration_1.Decoration.for(key)
158
+ .define(validationMetadata(step, key, meta))
133
159
  .apply();
134
160
  }
135
161
  /**
@@ -144,12 +170,14 @@ function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
144
170
  */
145
171
  function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
146
172
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.MIN_LENGTH);
147
- return Decoration_1.Decoration.for(key)
148
- .define((0, decorators_1.propMetadata)(key, {
173
+ const meta = {
149
174
  [constants_1.ValidationKeys.MIN_LENGTH]: value,
150
175
  message: message,
151
176
  types: [String.name, Array.name, Set.name],
152
- }))
177
+ description: `defines the min length of the attribute as ${value} (applies to strings or lists)`,
178
+ };
179
+ return Decoration_1.Decoration.for(key)
180
+ .define(validationMetadata(minlength, key, meta))
153
181
  .apply();
154
182
  }
155
183
  /**
@@ -164,12 +192,14 @@ function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGT
164
192
  */
165
193
  function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
166
194
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.MAX_LENGTH);
167
- return Decoration_1.Decoration.for(key)
168
- .define((0, decorators_1.propMetadata)(key, {
195
+ const meta = {
169
196
  [constants_1.ValidationKeys.MAX_LENGTH]: value,
170
197
  message: message,
171
198
  types: [String.name, Array.name, Set.name],
172
- }))
199
+ description: `defines the max length of the attribute as ${value} (applies to strings or lists)`,
200
+ };
201
+ return Decoration_1.Decoration.for(key)
202
+ .define(validationMetadata(maxlength, key, meta))
173
203
  .apply();
174
204
  }
175
205
  /**
@@ -184,12 +214,14 @@ function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGT
184
214
  */
185
215
  function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
186
216
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN);
187
- return Decoration_1.Decoration.for(key)
188
- .define((0, decorators_1.propMetadata)(key, {
217
+ const meta = {
189
218
  [constants_1.ValidationKeys.PATTERN]: typeof value === "string" ? value : value.toString(),
190
219
  message: message,
191
220
  types: [String.name],
192
- }))
221
+ description: `assigns the ${value === "string" ? value : value.toString()} pattern to the attribute`,
222
+ };
223
+ return Decoration_1.Decoration.for(key)
224
+ .define(validationMetadata(pattern, key, meta))
193
225
  .apply();
194
226
  }
195
227
  /**
@@ -203,12 +235,14 @@ function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
203
235
  */
204
236
  function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
205
237
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL);
206
- return Decoration_1.Decoration.for(key)
207
- .define((0, decorators_1.propMetadata)(key, {
208
- [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.EMAIL,
238
+ const meta = {
239
+ [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.EMAIL.toString(),
209
240
  message: message,
210
241
  types: [String.name],
211
- }))
242
+ description: "marks the attribute as an email",
243
+ };
244
+ return Decoration_1.Decoration.for(key)
245
+ .define(validationMetadata(email, key, meta))
212
246
  .apply();
213
247
  }
214
248
  /**
@@ -222,12 +256,14 @@ function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
222
256
  */
223
257
  function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
224
258
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.URL);
225
- return Decoration_1.Decoration.for(key)
226
- .define((0, decorators_1.propMetadata)(key, {
227
- [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.URL,
259
+ const meta = {
260
+ [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.URL.toString(),
228
261
  message: message,
229
262
  types: [String.name],
230
- }))
263
+ description: "marks the attribute as an url",
264
+ };
265
+ return Decoration_1.Decoration.for(key)
266
+ .define(validationMetadata(url, key, meta))
231
267
  .apply();
232
268
  }
233
269
  /**
@@ -242,11 +278,13 @@ function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
242
278
  */
243
279
  function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
244
280
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.TYPE);
245
- return Decoration_1.Decoration.for(key)
246
- .define((0, decorators_1.propMetadata)(key, {
281
+ const meta = {
247
282
  customTypes: types,
248
283
  message: message,
249
- }))
284
+ description: "defines the accepted types for the attribute",
285
+ };
286
+ return Decoration_1.Decoration.for(key)
287
+ .define(validationMetadata(type, key, meta))
250
288
  .apply();
251
289
  }
252
290
  /**
@@ -264,12 +302,14 @@ function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
264
302
  */
265
303
  function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGES.DATE) {
266
304
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.DATE);
305
+ const meta = {
306
+ [constants_1.ValidationKeys.FORMAT]: format,
307
+ message: message,
308
+ types: [Date.name],
309
+ description: `defines the attribute as a date with the format ${format}`,
310
+ };
267
311
  const dateDec = (target, propertyKey) => {
268
- (0, decorators_1.propMetadata)(key, {
269
- [constants_1.ValidationKeys.FORMAT]: format,
270
- message: message,
271
- types: [Date.name],
272
- })(target, propertyKey);
312
+ validationMetadata(date, key, meta)(target, propertyKey);
273
313
  const values = new WeakMap();
274
314
  Object.defineProperty(target, propertyKey, {
275
315
  configurable: false,
@@ -313,19 +353,21 @@ function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGE
313
353
  */
314
354
  function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = constants_1.DEFAULT_ERROR_MESSAGES.PASSWORD) {
315
355
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.PASSWORD);
316
- return Decoration_1.Decoration.for(key)
317
- .define((0, decorators_1.propMetadata)(key, {
318
- [constants_1.ValidationKeys.PATTERN]: pattern,
356
+ const meta = {
357
+ [constants_1.ValidationKeys.PATTERN]: pattern.toString(),
319
358
  message: message,
320
359
  types: [String.name],
321
- }))
360
+ description: `attribute as a password`,
361
+ };
362
+ return Decoration_1.Decoration.for(key)
363
+ .define(validationMetadata(password, key, meta))
322
364
  .apply();
323
365
  }
324
366
  /**
325
367
  * @summary List Decorator
326
368
  * @description Also sets the {@link type} to the provided collection
327
369
  *
328
- * @param {ModelConstructor} clazz
370
+ * @param {Constructor} clazz
329
371
  * @param {string} [collection] The collection being used. defaults to Array
330
372
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
331
373
  *
@@ -335,12 +377,14 @@ function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_E
335
377
  */
336
378
  function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_MESSAGES.LIST) {
337
379
  const key = Validation_1.Validation.key(constants_1.ValidationKeys.LIST);
338
- return Decoration_1.Decoration.for(key)
339
- .define((0, decorators_1.propMetadata)(key, {
380
+ const meta = {
340
381
  clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
341
382
  type: collection,
342
383
  message: message,
343
- }))
384
+ description: `defines the attribute as a ${collection} of ${clazz.name}`,
385
+ };
386
+ return Decoration_1.Decoration.for(key)
387
+ .define(validationMetadata(list, key, meta))
344
388
  .apply();
345
389
  }
346
390
  /**
@@ -373,8 +417,9 @@ function eq(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.EQUA
373
417
  const options = {
374
418
  message: message,
375
419
  [constants_1.ValidationKeys.EQUALS]: propertyToCompare,
420
+ description: `defines attribute as equal to ${propertyToCompare}`,
376
421
  };
377
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EQUALS), options);
422
+ return validationMetadata(eq, Validation_1.Validation.key(constants_1.ValidationKeys.EQUALS), options);
378
423
  }
379
424
  /**
380
425
  * @summary Declares that the decorated property must be different from another specified property.
@@ -392,8 +437,9 @@ function diff(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.DI
392
437
  const options = {
393
438
  message: message,
394
439
  [constants_1.ValidationKeys.DIFF]: propertyToCompare,
440
+ description: `defines attribute as different to ${propertyToCompare}`,
395
441
  };
396
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.DIFF), options);
442
+ return validationMetadata(diff, Validation_1.Validation.key(constants_1.ValidationKeys.DIFF), options);
397
443
  }
398
444
  /**
399
445
  * @summary Declares that the decorated property must be less than another specified property.
@@ -411,8 +457,9 @@ function lt(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.LESS
411
457
  const options = {
412
458
  message: message,
413
459
  [constants_1.ValidationKeys.LESS_THAN]: propertyToCompare,
460
+ description: `defines attribute as less than to ${propertyToCompare}`,
414
461
  };
415
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN), options);
462
+ return validationMetadata(lt, Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN), options);
416
463
  }
417
464
  /**
418
465
  * @summary Declares that the decorated property must be equal or less than another specified property.
@@ -430,8 +477,9 @@ function lte(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.LES
430
477
  const options = {
431
478
  message: message,
432
479
  [constants_1.ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,
480
+ description: `defines attribute as less or equal to ${propertyToCompare}`,
433
481
  };
434
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN_OR_EQUAL), options);
482
+ return validationMetadata(lte, Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN_OR_EQUAL), options);
435
483
  }
436
484
  /**
437
485
  * @summary Declares that the decorated property must be greater than another specified property.
@@ -449,8 +497,9 @@ function gt(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.GREA
449
497
  const options = {
450
498
  message: message,
451
499
  [constants_1.ValidationKeys.GREATER_THAN]: propertyToCompare,
500
+ description: `defines attribute as greater than ${propertyToCompare}`,
452
501
  };
453
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN), options);
502
+ return validationMetadata(gt, Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN), options);
454
503
  }
455
504
  /**
456
505
  * @summary Declares that the decorated property must be equal or greater than another specified property.
@@ -468,7 +517,8 @@ function gte(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.GRE
468
517
  const options = {
469
518
  message: message,
470
519
  [constants_1.ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,
520
+ description: `defines attribute as greater or equal to ${propertyToCompare}`,
471
521
  };
472
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN_OR_EQUAL), options);
522
+ return validationMetadata(gte, Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN_OR_EQUAL), options);
473
523
  }
474
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport {\n  DiffValidatorOptions,\n  EqualsValidatorOptions,\n  GreaterThanOrEqualValidatorOptions,\n  GreaterThanValidatorOptions,\n  LessThanOrEqualValidatorOptions,\n  LessThanValidatorOptions,\n  ValidationMetadata,\n} from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\nimport { Decoration } from \"../utils/Decoration\";\n\n/**\n * @description Property decorator that marks a field as required\n * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.\n * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.\n * This decorator is commonly used as the first validation step for important fields.\n *\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function required\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class User {\n *   @required()\n *   username: string;\n *\n *   @required(\"Email address is mandatory\")\n *   email: string;\n * }\n * ```\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  const key = Validation.key(ValidationKeys.REQUIRED);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MIN]: value,\n        message: message,\n        types: [Number.name, Date.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MAX]: value,\n        message: message,\n        types: [Number.name, Date.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.STEP]: value,\n        message: message,\n        types: [Number.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MIN_LENGTH]: value,\n        message: message,\n        types: [String.name, Array.name, Set.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MAX_LENGTH]: value,\n        message: message,\n        types: [String.name, Array.name, Set.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.PATTERN]:\n          typeof value === \"string\" ? value : value.toString(),\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @category Property Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  const key = Validation.key(ValidationKeys.TYPE);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        customTypes: types,\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n *\n * @function date\n *\n * @category Property Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  const key = Validation.key(ValidationKeys.DATE);\n  const dateDec = (target: Record<string, any>, propertyKey?: any): any => {\n    propMetadata(key, {\n      [ValidationKeys.FORMAT]: format,\n      message: message,\n      types: [Date.name],\n    })(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n  return Decoration.for(key).define(dateDec).apply();\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n *\n * @function password\n *\n * @category Property Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  const key = Validation.key(ValidationKeys.PASSWORD);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        [ValidationKeys.PATTERN]: pattern,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function list\n *\n * @category Property Decorators\n */\nexport function list(\n  clazz: ModelConstructor<any> | ModelConstructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  const key = Validation.key(ValidationKeys.LIST);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n        type: collection,\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @category Property Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: EqualsValidatorOptions = {\n    message: message,\n    [ValidationKeys.EQUALS]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.EQUALS),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be different from another specified property.\n * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare difference against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.\n *\n * @function diff\n * @category Property Decorators\n */\nexport function diff(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.DIFF\n) {\n  const options: DiffValidatorOptions = {\n    message: message,\n    [ValidationKeys.DIFF]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.DIFF),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.\n *\n * @function lt\n * @category Property Decorators\n */\nexport function lt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN\n) {\n  const options: LessThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.LESS_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.\n *\n * @function lte\n * @category Property Decorators\n */\nexport function lte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL\n) {\n  const options: LessThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.\n *\n * @function gt\n * @category Property Decorators\n */\nexport function gt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN\n) {\n  const options: GreaterThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.GREATER_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.\n *\n * @function gte\n * @category Property Decorators\n */\nexport function gte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL\n) {\n  const options: GreaterThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n"]}
524
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport {\n  DateValidatorOptions,\n  DiffValidatorOptions,\n  EqualsValidatorOptions,\n  GreaterThanOrEqualValidatorOptions,\n  GreaterThanValidatorOptions,\n  LessThanOrEqualValidatorOptions,\n  LessThanValidatorOptions,\n  ListValidatorOptions,\n  MaxLengthValidatorOptions,\n  MaxValidatorOptions,\n  MinLengthValidatorOptions,\n  MinValidatorOptions,\n  PatternValidatorOptions,\n  StepValidatorOptions,\n  ValidationMetadata,\n  ValidatorOptions,\n} from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { Constructor, ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\nimport { Decoration } from \"../utils/Decoration\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Combined property decorator factory for metadata and attribute marking\n * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it\n *\n * @template V\n * @param {PropertyDecorator} decorator - The metadata key\n * @param {string} key - The metadata key\n * @param {V} value - The metadata value to associate with the property\n * @return {Function} - Combined decorator function\n * @function validationMetadata\n * @category Property Decorators\n */\nexport function validationMetadata<V>(decorator: any, key: string, value: V) {\n  Validation.registerDecorator(key, decorator);\n  return apply(propMetadata<V>(key, value));\n}\n\n/**\n * @description Property decorator that marks a field as required\n * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.\n * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.\n * This decorator is commonly used as the first validation step for important fields.\n *\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function required\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class User {\n *   @required()\n *   username: string;\n *\n *   @required(\"Email address is mandatory\")\n *   email: string;\n * }\n * ```\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  const key = Validation.key(ValidationKeys.REQUIRED);\n  const meta: ValidatorOptions = {\n    message: message,\n    description: `defines the attribute as required`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<ValidatorOptions>(required, key, meta))\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  const meta: MinValidatorOptions = {\n    [ValidationKeys.MIN]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinValidatorOptions>(min, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  const meta: MaxValidatorOptions = {\n    [ValidationKeys.MAX]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxValidatorOptions>(max, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  const meta: StepValidatorOptions = {\n    [ValidationKeys.STEP]: value,\n    message: message,\n    types: [Number.name],\n    description: `defines the step of the attribute as ${value}`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<StepValidatorOptions>(step, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  const meta: MinLengthValidatorOptions = {\n    [ValidationKeys.MIN_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the min length of the attribute as ${value} (applies to strings or lists)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinLengthValidatorOptions>(minlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  const meta: MaxLengthValidatorOptions = {\n    [ValidationKeys.MAX_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the max length of the attribute as ${value} (applies to strings or lists)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxLengthValidatorOptions>(maxlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]:\n      typeof value === \"string\" ? value : value.toString(),\n    message: message,\n    types: [String.name],\n    description: `assigns the ${value === \"string\" ? value : value.toString()} pattern to the attribute`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(pattern, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an email\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(email, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an url\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(url, key, meta))\n    .apply();\n}\n\nexport interface TypeMetadata extends ValidatorOptions {\n  customTypes: string[] | string;\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @category Property Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  const key = Validation.key(ValidationKeys.TYPE);\n  const meta: TypeMetadata = {\n    customTypes: types,\n    message: message,\n    description: \"defines the accepted types for the attribute\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<TypeMetadata>(type, key, meta))\n    .apply();\n}\n\nexport interface DateMetadata extends DateValidatorOptions {\n  types: string[];\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n *\n * @function date\n *\n * @category Property Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  const key = Validation.key(ValidationKeys.DATE);\n  const meta: DateMetadata = {\n    [ValidationKeys.FORMAT]: format,\n    message: message,\n    types: [Date.name],\n    description: `defines the attribute as a date with the format ${format}`,\n  };\n  const dateDec = (target: Record<string, any>, propertyKey?: any): any => {\n    validationMetadata(date, key, meta)(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n  return Decoration.for(key).define(dateDec).apply();\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n *\n * @function password\n *\n * @category Property Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  const key = Validation.key(ValidationKeys.PASSWORD);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: pattern.toString(),\n    message: message,\n    types: [String.name],\n    description: `attribute as a password`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(password, key, meta))\n    .apply();\n}\n\nexport interface ListMetadata extends ListValidatorOptions {\n  type: \"Array\" | \"Set\";\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {Constructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function list\n *\n * @category Property Decorators\n */\nexport function list(\n  clazz: Constructor<any> | Constructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  const key = Validation.key(ValidationKeys.LIST);\n  const meta: ListMetadata = {\n    clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n    type: collection,\n    message: message,\n    description: `defines the attribute as a ${collection} of ${(clazz as ModelConstructor<any>).name}`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(list, key, meta))\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @category Property Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: EqualsValidatorOptions = {\n    message: message,\n    [ValidationKeys.EQUALS]: propertyToCompare,\n    description: `defines attribute as equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    eq,\n    Validation.key(ValidationKeys.EQUALS),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be different from another specified property.\n * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare difference against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.\n *\n * @function diff\n * @category Property Decorators\n */\nexport function diff(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.DIFF\n) {\n  const options: DiffValidatorOptions = {\n    message: message,\n    [ValidationKeys.DIFF]: propertyToCompare,\n    description: `defines attribute as different to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    diff,\n    Validation.key(ValidationKeys.DIFF),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.\n *\n * @function lt\n * @category Property Decorators\n */\nexport function lt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN\n) {\n  const options: LessThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN]: propertyToCompare,\n    description: `defines attribute as less than to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lt,\n    Validation.key(ValidationKeys.LESS_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.\n *\n * @function lte\n * @category Property Decorators\n */\nexport function lte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL\n) {\n  const options: LessThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as less or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lte,\n    Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.\n *\n * @function gt\n * @category Property Decorators\n */\nexport function gt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN\n) {\n  const options: GreaterThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN]: propertyToCompare,\n    description: `defines attribute as greater than ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gt,\n    Validation.key(ValidationKeys.GREATER_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.\n *\n * @function gte\n * @category Property Decorators\n */\nexport function gte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL\n) {\n  const options: GreaterThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as greater or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gte,\n    Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n"]}
@@ -1,5 +1,19 @@
1
1
  import "reflect-metadata";
2
- import { ModelConstructor } from "../model/types";
2
+ import { DateValidatorOptions, ListValidatorOptions, ValidatorOptions } from "./types";
3
+ import { Constructor, ModelConstructor } from "../model/types";
4
+ /**
5
+ * @description Combined property decorator factory for metadata and attribute marking
6
+ * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it
7
+ *
8
+ * @template V
9
+ * @param {PropertyDecorator} decorator - The metadata key
10
+ * @param {string} key - The metadata key
11
+ * @param {V} value - The metadata value to associate with the property
12
+ * @return {Function} - Combined decorator function
13
+ * @function validationMetadata
14
+ * @category Property Decorators
15
+ */
16
+ export declare function validationMetadata<V>(decorator: any, key: string, value: V): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
3
17
  /**
4
18
  * @description Property decorator that marks a field as required
5
19
  * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.
@@ -124,6 +138,9 @@ export declare function email(message?: string): (target: any, propertyKey?: any
124
138
  * @category Property Decorators
125
139
  */
126
140
  export declare function url(message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
141
+ export interface TypeMetadata extends ValidatorOptions {
142
+ customTypes: string[] | string;
143
+ }
127
144
  /**
128
145
  * @summary Enforces type verification
129
146
  * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
@@ -135,6 +152,9 @@ export declare function url(message?: string): (target: any, propertyKey?: any,
135
152
  * @category Property Decorators
136
153
  */
137
154
  export declare function type(types: string[] | string, message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
155
+ export interface DateMetadata extends DateValidatorOptions {
156
+ types: string[];
157
+ }
138
158
  /**
139
159
  * @summary Date Handler Decorator
140
160
  * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
@@ -161,11 +181,14 @@ export declare function date(format?: string, message?: string): (target: any, p
161
181
  * @category Property Decorators
162
182
  */
163
183
  export declare function password(pattern?: RegExp, message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
184
+ export interface ListMetadata extends ListValidatorOptions {
185
+ type: "Array" | "Set";
186
+ }
164
187
  /**
165
188
  * @summary List Decorator
166
189
  * @description Also sets the {@link type} to the provided collection
167
190
  *
168
- * @param {ModelConstructor} clazz
191
+ * @param {Constructor} clazz
169
192
  * @param {string} [collection] The collection being used. defaults to Array
170
193
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
171
194
  *
@@ -173,7 +196,7 @@ export declare function password(pattern?: RegExp, message?: string): (target: a
173
196
  *
174
197
  * @category Property Decorators
175
198
  */
176
- export declare function list(clazz: ModelConstructor<any> | ModelConstructor<any>[], collection?: "Array" | "Set", message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
199
+ export declare function list(clazz: Constructor<any> | Constructor<any>[], collection?: "Array" | "Set", message?: string): (target: any, propertyKey?: any, descriptor?: TypedPropertyDescriptor<any>) => any;
177
200
  /**
178
201
  * @summary Set Decorator
179
202
  * @description Wrapper for {@link list} with the 'Set' Collection