@decaf-ts/decorator-validation 1.6.1 → 1.6.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.
Files changed (124) hide show
  1. package/README.md +8 -2
  2. package/dist/decorator-validation.cjs +1154 -352
  3. package/dist/decorator-validation.esm.cjs +1124 -320
  4. package/lib/esm/index.d.ts +5 -36
  5. package/lib/esm/index.js +6 -37
  6. package/lib/esm/model/Model.d.ts +100 -29
  7. package/lib/esm/model/Model.js +103 -36
  8. package/lib/esm/model/constants.d.ts +3 -3
  9. package/lib/esm/model/constants.js +4 -4
  10. package/lib/esm/model/construction.d.ts +3 -3
  11. package/lib/esm/model/construction.js +4 -4
  12. package/lib/esm/model/decorators.d.ts +4 -4
  13. package/lib/esm/model/decorators.js +6 -5
  14. package/lib/esm/model/types.d.ts +30 -11
  15. package/lib/esm/model/types.js +1 -1
  16. package/lib/esm/model/validation.d.ts +2 -2
  17. package/lib/esm/model/validation.js +5 -5
  18. package/lib/esm/utils/Decoration.d.ts +123 -0
  19. package/lib/esm/utils/Decoration.js +188 -0
  20. package/lib/esm/utils/constants.d.ts +27 -9
  21. package/lib/esm/utils/constants.js +28 -10
  22. package/lib/esm/utils/dates.d.ts +26 -16
  23. package/lib/esm/utils/dates.js +27 -17
  24. package/lib/esm/utils/decorators.d.ts +41 -0
  25. package/lib/esm/utils/decorators.js +42 -1
  26. package/lib/esm/utils/hashing.d.ts +50 -6
  27. package/lib/esm/utils/hashing.js +49 -5
  28. package/lib/esm/utils/index.d.ts +1 -0
  29. package/lib/esm/utils/index.js +2 -1
  30. package/lib/esm/utils/registry.d.ts +2 -2
  31. package/lib/esm/utils/registry.js +1 -1
  32. package/lib/esm/utils/serialization.d.ts +1 -1
  33. package/lib/esm/utils/serialization.js +2 -2
  34. package/lib/esm/utils/strings.d.ts +4 -4
  35. package/lib/esm/utils/strings.js +5 -5
  36. package/lib/esm/utils/types.d.ts +123 -16
  37. package/lib/esm/utils/types.js +1 -1
  38. package/lib/esm/validation/Validators/DateValidator.d.ts +40 -8
  39. package/lib/esm/validation/Validators/DateValidator.js +41 -9
  40. package/lib/esm/validation/Validators/EmailValidator.d.ts +39 -7
  41. package/lib/esm/validation/Validators/EmailValidator.js +40 -8
  42. package/lib/esm/validation/Validators/ListValidator.d.ts +44 -6
  43. package/lib/esm/validation/Validators/ListValidator.js +45 -7
  44. package/lib/esm/validation/Validators/MaxValidator.d.ts +52 -6
  45. package/lib/esm/validation/Validators/MaxValidator.js +53 -7
  46. package/lib/esm/validation/Validators/MinValidator.d.ts +52 -6
  47. package/lib/esm/validation/Validators/MinValidator.js +53 -7
  48. package/lib/esm/validation/Validators/PatternValidator.d.ts +75 -9
  49. package/lib/esm/validation/Validators/PatternValidator.js +76 -10
  50. package/lib/esm/validation/Validators/RequiredValidator.d.ts +52 -6
  51. package/lib/esm/validation/Validators/RequiredValidator.js +53 -7
  52. package/lib/esm/validation/Validators/TypeValidator.d.ts +60 -6
  53. package/lib/esm/validation/Validators/TypeValidator.js +69 -7
  54. package/lib/esm/validation/Validators/URLValidator.d.ts +41 -7
  55. package/lib/esm/validation/Validators/URLValidator.js +42 -8
  56. package/lib/esm/validation/Validators/Validator.d.ts +77 -14
  57. package/lib/esm/validation/Validators/Validator.js +68 -11
  58. package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +1 -7
  59. package/lib/esm/validation/Validators/ValidatorRegistry.js +4 -11
  60. package/lib/esm/validation/decorators.d.ts +50 -40
  61. package/lib/esm/validation/decorators.js +102 -53
  62. package/lib/esm/validation/types.d.ts +146 -28
  63. package/lib/esm/validation/types.js +1 -1
  64. package/lib/index.cjs +7 -38
  65. package/lib/index.d.ts +5 -36
  66. package/lib/model/Model.cjs +103 -38
  67. package/lib/model/Model.d.ts +100 -29
  68. package/lib/model/constants.cjs +4 -4
  69. package/lib/model/constants.d.ts +3 -3
  70. package/lib/model/construction.cjs +4 -4
  71. package/lib/model/construction.d.ts +3 -3
  72. package/lib/model/decorators.cjs +6 -5
  73. package/lib/model/decorators.d.ts +4 -4
  74. package/lib/model/types.cjs +1 -1
  75. package/lib/model/types.d.ts +30 -11
  76. package/lib/model/validation.cjs +4 -4
  77. package/lib/model/validation.d.ts +2 -2
  78. package/lib/utils/Decoration.cjs +192 -0
  79. package/lib/utils/Decoration.d.ts +123 -0
  80. package/lib/utils/constants.cjs +29 -11
  81. package/lib/utils/constants.d.ts +27 -9
  82. package/lib/utils/dates.cjs +27 -17
  83. package/lib/utils/dates.d.ts +26 -16
  84. package/lib/utils/decorators.cjs +42 -1
  85. package/lib/utils/decorators.d.ts +41 -0
  86. package/lib/utils/hashing.cjs +49 -5
  87. package/lib/utils/hashing.d.ts +50 -6
  88. package/lib/utils/index.cjs +2 -1
  89. package/lib/utils/index.d.ts +1 -0
  90. package/lib/utils/registry.cjs +1 -1
  91. package/lib/utils/registry.d.ts +2 -2
  92. package/lib/utils/serialization.cjs +2 -2
  93. package/lib/utils/serialization.d.ts +1 -1
  94. package/lib/utils/strings.cjs +5 -5
  95. package/lib/utils/strings.d.ts +4 -4
  96. package/lib/utils/types.cjs +1 -1
  97. package/lib/utils/types.d.ts +123 -16
  98. package/lib/validation/Validators/DateValidator.cjs +41 -9
  99. package/lib/validation/Validators/DateValidator.d.ts +40 -8
  100. package/lib/validation/Validators/EmailValidator.cjs +40 -8
  101. package/lib/validation/Validators/EmailValidator.d.ts +39 -7
  102. package/lib/validation/Validators/ListValidator.cjs +45 -7
  103. package/lib/validation/Validators/ListValidator.d.ts +44 -6
  104. package/lib/validation/Validators/MaxValidator.cjs +53 -7
  105. package/lib/validation/Validators/MaxValidator.d.ts +52 -6
  106. package/lib/validation/Validators/MinValidator.cjs +53 -7
  107. package/lib/validation/Validators/MinValidator.d.ts +52 -6
  108. package/lib/validation/Validators/PatternValidator.cjs +76 -10
  109. package/lib/validation/Validators/PatternValidator.d.ts +75 -9
  110. package/lib/validation/Validators/RequiredValidator.cjs +53 -7
  111. package/lib/validation/Validators/RequiredValidator.d.ts +52 -6
  112. package/lib/validation/Validators/TypeValidator.cjs +69 -7
  113. package/lib/validation/Validators/TypeValidator.d.ts +60 -6
  114. package/lib/validation/Validators/URLValidator.cjs +42 -8
  115. package/lib/validation/Validators/URLValidator.d.ts +41 -7
  116. package/lib/validation/Validators/Validator.cjs +68 -11
  117. package/lib/validation/Validators/Validator.d.ts +77 -14
  118. package/lib/validation/Validators/ValidatorRegistry.cjs +4 -12
  119. package/lib/validation/Validators/ValidatorRegistry.d.ts +1 -7
  120. package/lib/validation/decorators.cjs +102 -53
  121. package/lib/validation/decorators.d.ts +50 -40
  122. package/lib/validation/types.cjs +1 -1
  123. package/lib/validation/types.d.ts +146 -28
  124. package/package.json +2 -2
@@ -20,38 +20,71 @@ const strings_1 = require("../utils/strings.cjs");
20
20
  const dates_1 = require("../utils/dates.cjs");
21
21
  const decorators_1 = require("../utils/decorators.cjs");
22
22
  const Validation_1 = require("./Validation.cjs");
23
+ const Decoration_1 = require("../utils/Decoration.cjs");
23
24
  /**
24
- * @summary Marks the property as required.
25
- * @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
25
+ * @description Property decorator that marks a field as required
26
+ * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.
27
+ * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.
28
+ * This decorator is commonly used as the first validation step for important fields.
26
29
  *
27
- * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
30
+ * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
31
+ * @return {PropertyDecorator} A decorator function that can be applied to class properties
28
32
  *
29
33
  * @function required
30
- *
31
34
  * @category Decorators
35
+ *
36
+ * @example
37
+ * ```typescript
38
+ * class User {
39
+ * @required()
40
+ * username: string;
41
+ *
42
+ * @required("Email address is mandatory")
43
+ * email: string;
44
+ * }
45
+ * ```
32
46
  */
33
47
  function required(message = constants_1.DEFAULT_ERROR_MESSAGES.REQUIRED) {
34
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.REQUIRED), {
48
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.REQUIRED);
49
+ return Decoration_1.Decoration.for(key)
50
+ .define((0, decorators_1.propMetadata)(key, {
35
51
  message: message,
36
- });
52
+ }))
53
+ .apply();
37
54
  }
38
55
  /**
39
- * @summary Defines a minimum value for the property
40
- * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
56
+ * @description Property decorator that enforces a minimum value constraint
57
+ * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.
58
+ * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.
59
+ * This decorator works with numeric values and dates.
41
60
  *
42
- * @param {number | Date} value
43
- * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
61
+ * @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
62
+ * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
63
+ * @return {PropertyDecorator} A decorator function that can be applied to class properties
44
64
  *
45
65
  * @function min
46
- * @memberOf module:decorator-validation.Decorators.Validation
47
66
  * @category Decorators
67
+ *
68
+ * @example
69
+ * ```typescript
70
+ * class Product {
71
+ * @min(0)
72
+ * price: number;
73
+ *
74
+ * @min(new Date(2023, 0, 1), "Date must be after January 1, 2023")
75
+ * releaseDate: Date;
76
+ * }
77
+ * ```
48
78
  */
49
79
  function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
50
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN), {
80
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.MIN);
81
+ return Decoration_1.Decoration.for(key)
82
+ .define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN), {
51
83
  [constants_1.ValidationKeys.MIN]: value,
52
84
  message: message,
53
85
  types: [Number.name, Date.name],
54
- });
86
+ }))
87
+ .apply();
55
88
  }
56
89
  /**
57
90
  * @summary Defines a maximum value for the property
@@ -61,15 +94,17 @@ function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
61
94
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
62
95
  *
63
96
  * @function max
64
- * @memberOf module:decorator-validation.Decorators.Validation
65
97
  * @category Decorators
66
98
  */
67
99
  function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
68
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MAX), {
100
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.MAX);
101
+ return Decoration_1.Decoration.for(key)
102
+ .define((0, decorators_1.propMetadata)(key, {
69
103
  [constants_1.ValidationKeys.MAX]: value,
70
104
  message: message,
71
105
  types: [Number.name, Date.name],
72
- });
106
+ }))
107
+ .apply();
73
108
  }
74
109
  /**
75
110
  * @summary Defines a step value for the property
@@ -79,15 +114,17 @@ function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
79
114
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
80
115
  *
81
116
  * @function step
82
- * @memberOf module:decorator-validation.Decorators.Validation
83
117
  * @category Decorators
84
118
  */
85
119
  function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
86
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.STEP), {
120
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.STEP);
121
+ return Decoration_1.Decoration.for(key)
122
+ .define((0, decorators_1.propMetadata)(key, {
87
123
  [constants_1.ValidationKeys.STEP]: value,
88
124
  message: message,
89
125
  types: [Number.name],
90
- });
126
+ }))
127
+ .apply();
91
128
  }
92
129
  /**
93
130
  * @summary Defines a minimum length for the property
@@ -97,15 +134,17 @@ function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
97
134
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
98
135
  *
99
136
  * @function minlength
100
- * @memberOf module:decorator-validation.Decorators.Validation
101
137
  * @category Decorators
102
138
  */
103
139
  function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
104
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN_LENGTH), {
140
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.MIN_LENGTH);
141
+ return Decoration_1.Decoration.for(key)
142
+ .define((0, decorators_1.propMetadata)(key, {
105
143
  [constants_1.ValidationKeys.MIN_LENGTH]: value,
106
144
  message: message,
107
145
  types: [String.name, Array.name, Set.name],
108
- });
146
+ }))
147
+ .apply();
109
148
  }
110
149
  /**
111
150
  * @summary Defines a maximum length for the property
@@ -115,15 +154,17 @@ function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGT
115
154
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
116
155
  *
117
156
  * @function maxlength
118
- * @memberOf module:decorator-validation.Decorators.Validation
119
157
  * @category Decorators
120
158
  */
121
159
  function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
122
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MAX_LENGTH), {
160
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.MAX_LENGTH);
161
+ return Decoration_1.Decoration.for(key)
162
+ .define((0, decorators_1.propMetadata)(key, {
123
163
  [constants_1.ValidationKeys.MAX_LENGTH]: value,
124
164
  message: message,
125
165
  types: [String.name, Array.name, Set.name],
126
- });
166
+ }))
167
+ .apply();
127
168
  }
128
169
  /**
129
170
  * @summary Defines a RegExp pattern the property must respect
@@ -133,15 +174,17 @@ function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGT
133
174
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
134
175
  *
135
176
  * @function pattern
136
- * @memberOf module:decorator-validation.Decorators.Validation
137
177
  * @category Decorators
138
178
  */
139
179
  function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
140
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN), {
180
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN);
181
+ return Decoration_1.Decoration.for(key)
182
+ .define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN), {
141
183
  [constants_1.ValidationKeys.PATTERN]: typeof value === "string" ? value : value.toString(),
142
184
  message: message,
143
185
  types: [String.name],
144
- });
186
+ }))
187
+ .apply();
145
188
  }
146
189
  /**
147
190
  * @summary Defines the property as an email
@@ -150,15 +193,17 @@ function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
150
193
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
151
194
  *
152
195
  * @function email
153
- * @memberOf module:decorator-validation.Decorators.Validation
154
196
  * @category Decorators
155
197
  */
156
198
  function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
157
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL), {
199
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL);
200
+ return Decoration_1.Decoration.for(key)
201
+ .define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL), {
158
202
  [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.EMAIL,
159
203
  message: message,
160
204
  types: [String.name],
161
- });
205
+ }))
206
+ .apply();
162
207
  }
163
208
  /**
164
209
  * @summary Defines the property as an URL
@@ -167,15 +212,17 @@ function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
167
212
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
168
213
  *
169
214
  * @function url
170
- * @memberOf module:decorator-validation.Decorators.Validation
171
215
  * @category Decorators
172
216
  */
173
217
  function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
174
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.URL), {
218
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.URL);
219
+ return Decoration_1.Decoration.for(key)
220
+ .define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.URL), {
175
221
  [constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.URL,
176
222
  message: message,
177
223
  types: [String.name],
178
- });
224
+ }))
225
+ .apply();
179
226
  }
180
227
  /**
181
228
  * @summary Enforces type verification
@@ -185,14 +232,16 @@ function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
185
232
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
186
233
  *
187
234
  * @function type
188
- * @memberOf module:decorator-validation.Decorators.Validation
189
235
  * @category Decorators
190
236
  */
191
237
  function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
192
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.TYPE), {
238
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.TYPE);
239
+ return Decoration_1.Decoration.for(key)
240
+ .define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.TYPE), {
193
241
  customTypes: types,
194
242
  message: message,
195
- });
243
+ }))
244
+ .apply();
196
245
  }
197
246
  /**
198
247
  * @summary Date Handler Decorator
@@ -202,16 +251,15 @@ function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
202
251
  *
203
252
  * @param {string} format accepted format according to {@link formatDate}
204
253
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
205
- * @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
206
254
  *
207
255
  * @function date
208
256
  *
209
- * @memberOf module:decorator-validation.Decorators.Validation
210
257
  * @category Decorators
211
258
  */
212
259
  function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGES.DATE) {
213
- return (target, propertyKey) => {
214
- (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.DATE), {
260
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.DATE);
261
+ const dateDec = (target, propertyKey) => {
262
+ (0, decorators_1.propMetadata)(key, {
215
263
  [constants_1.ValidationKeys.FORMAT]: format,
216
264
  message: message,
217
265
  types: [Date.name],
@@ -244,26 +292,28 @@ function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGE
244
292
  },
245
293
  });
246
294
  };
295
+ return Decoration_1.Decoration.for(key).define(dateDec).apply();
247
296
  }
248
297
  /**
249
298
  * @summary Password Handler Decorator
250
299
  * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
251
300
  *
252
- * @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
301
+ * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}
253
302
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
254
- * @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
255
303
  *
256
304
  * @function password
257
305
  *
258
- * @memberOf module:decorator-validation.Decorators.Validation
259
306
  * @category Decorators
260
307
  */
261
308
  function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = constants_1.DEFAULT_ERROR_MESSAGES.PASSWORD) {
262
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PASSWORD), {
309
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.PASSWORD);
310
+ return Decoration_1.Decoration.for(key)
311
+ .define((0, decorators_1.propMetadata)(key, {
263
312
  [constants_1.ValidationKeys.PATTERN]: pattern,
264
313
  message: message,
265
314
  types: [String.name],
266
- });
315
+ }))
316
+ .apply();
267
317
  }
268
318
  /**
269
319
  * @summary List Decorator
@@ -272,19 +322,20 @@ function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_E
272
322
  * @param {ModelConstructor} clazz
273
323
  * @param {string} [collection] The collection being used. defaults to Array
274
324
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
275
- * @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
276
325
  *
277
326
  * @function list
278
327
  *
279
- * @memberOf module:decorator-validation.Decorators.Validation
280
328
  * @category Decorators
281
329
  */
282
330
  function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_MESSAGES.LIST) {
283
- return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LIST), {
331
+ const key = Validation_1.Validation.key(constants_1.ValidationKeys.LIST);
332
+ return Decoration_1.Decoration.for(key)
333
+ .define((0, decorators_1.propMetadata)(key, {
284
334
  clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
285
335
  type: collection,
286
336
  message: message,
287
- });
337
+ }))
338
+ .apply();
288
339
  }
289
340
  /**
290
341
  * @summary Set Decorator
@@ -292,14 +343,12 @@ function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_M
292
343
  *
293
344
  * @param {ModelConstructor} clazz
294
345
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
295
- * @param {Constructor<Validator>} [validator]
296
346
  *
297
347
  * @function set
298
348
  *
299
- * @memberOf module:decorator-validation.Decorators.Validation
300
349
  * @category Decorators
301
350
  */
302
351
  function set(clazz, message = constants_1.DEFAULT_ERROR_MESSAGES.LIST) {
303
352
  return list(clazz, "Set", message);
304
353
  }
305
- //# 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 { ValidationMetadata } 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\";\n\n/**\n * @summary Marks the property as required.\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n *\n * @function required\n *\n * @category Decorators\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.REQUIRED),\n    {\n      message: message,\n    }\n  );\n}\n\n/**\n * @summary Defines a minimum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n *\n * @function min\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.MIN), {\n    [ValidationKeys.MIN]: value,\n    message: message,\n    types: [Number.name, Date.name],\n  });\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.MAX), {\n    [ValidationKeys.MAX]: value,\n    message: message,\n    types: [Number.name, Date.name],\n  });\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.STEP), {\n    [ValidationKeys.STEP]: value,\n    message: message,\n    types: [Number.name],\n  });\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.MIN_LENGTH),\n    {\n      [ValidationKeys.MIN_LENGTH]: value,\n      message: message,\n      types: [String.name, Array.name, Set.name],\n    }\n  );\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.MAX_LENGTH),\n    {\n      [ValidationKeys.MAX_LENGTH]: value,\n      message: message,\n      types: [String.name, Array.name, Set.name],\n    }\n  );\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.PATTERN),\n    {\n      [ValidationKeys.PATTERN]:\n        typeof value === \"string\" ? value : value.toString(),\n      message: message,\n      types: [String.name],\n    }\n  );\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.EMAIL),\n    {\n      [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL,\n      message: message,\n      types: [String.name],\n    }\n  );\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.URL), {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL,\n    message: message,\n    types: [String.name],\n  });\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 * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.TYPE), {\n    customTypes: types,\n    message: message,\n  });\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 * @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}\n *\n * @function date\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  return (target: Record<string, any>, propertyKey?: any): any => {\n    propMetadata(Validation.key(ValidationKeys.DATE), {\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}\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 PasswordPatterns#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n * @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}\n *\n * @function password\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  return propMetadata(Validation.key(ValidationKeys.PASSWORD), {\n    [ValidationKeys.PATTERN]: pattern,\n    message: message,\n    types: [String.name],\n  });\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 * @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}\n *\n * @function list\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category 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  return propMetadata(Validation.key(ValidationKeys.LIST), {\n    clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n    type: collection,\n    message: message,\n  });\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 * @param {Constructor<Validator>} [validator]\n *\n * @function set\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category 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"]}
354
+ //# 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 { ValidationMetadata } 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 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 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>(Validation.key(ValidationKeys.MIN), {\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 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 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 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 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 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>(Validation.key(ValidationKeys.PATTERN), {\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 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>(Validation.key(ValidationKeys.EMAIL), {\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 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>(Validation.key(ValidationKeys.URL), {\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 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>(Validation.key(ValidationKeys.TYPE), {\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 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 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 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 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"]}