@decaf-ts/decorator-validation 1.6.0 → 1.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/README.md +8 -2
  2. package/dist/decorator-validation.cjs +1169 -366
  3. package/dist/decorator-validation.esm.cjs +1139 -334
  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/MaxLengthValidator.js +3 -3
  45. package/lib/esm/validation/Validators/MaxValidator.d.ts +52 -6
  46. package/lib/esm/validation/Validators/MaxValidator.js +53 -7
  47. package/lib/esm/validation/Validators/MinLengthValidator.js +3 -3
  48. package/lib/esm/validation/Validators/MinValidator.d.ts +52 -6
  49. package/lib/esm/validation/Validators/MinValidator.js +53 -7
  50. package/lib/esm/validation/Validators/PatternValidator.d.ts +75 -9
  51. package/lib/esm/validation/Validators/PatternValidator.js +76 -10
  52. package/lib/esm/validation/Validators/RequiredValidator.d.ts +52 -6
  53. package/lib/esm/validation/Validators/RequiredValidator.js +53 -7
  54. package/lib/esm/validation/Validators/TypeValidator.d.ts +60 -6
  55. package/lib/esm/validation/Validators/TypeValidator.js +69 -7
  56. package/lib/esm/validation/Validators/URLValidator.d.ts +41 -7
  57. package/lib/esm/validation/Validators/URLValidator.js +42 -8
  58. package/lib/esm/validation/Validators/Validator.d.ts +77 -14
  59. package/lib/esm/validation/Validators/Validator.js +68 -11
  60. package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +1 -7
  61. package/lib/esm/validation/Validators/ValidatorRegistry.js +4 -11
  62. package/lib/esm/validation/Validators/constants.d.ts +16 -15
  63. package/lib/esm/validation/Validators/constants.js +2 -1
  64. package/lib/esm/validation/decorators.d.ts +50 -40
  65. package/lib/esm/validation/decorators.js +112 -63
  66. package/lib/esm/validation/types.d.ts +154 -36
  67. package/lib/esm/validation/types.js +2 -2
  68. package/lib/index.cjs +7 -38
  69. package/lib/index.d.ts +5 -36
  70. package/lib/model/Model.cjs +103 -38
  71. package/lib/model/Model.d.ts +100 -29
  72. package/lib/model/constants.cjs +4 -4
  73. package/lib/model/constants.d.ts +3 -3
  74. package/lib/model/construction.cjs +4 -4
  75. package/lib/model/construction.d.ts +3 -3
  76. package/lib/model/decorators.cjs +6 -5
  77. package/lib/model/decorators.d.ts +4 -4
  78. package/lib/model/types.cjs +1 -1
  79. package/lib/model/types.d.ts +30 -11
  80. package/lib/model/validation.cjs +4 -4
  81. package/lib/model/validation.d.ts +2 -2
  82. package/lib/utils/Decoration.cjs +192 -0
  83. package/lib/utils/Decoration.d.ts +123 -0
  84. package/lib/utils/constants.cjs +29 -11
  85. package/lib/utils/constants.d.ts +27 -9
  86. package/lib/utils/dates.cjs +27 -17
  87. package/lib/utils/dates.d.ts +26 -16
  88. package/lib/utils/decorators.cjs +42 -1
  89. package/lib/utils/decorators.d.ts +41 -0
  90. package/lib/utils/hashing.cjs +49 -5
  91. package/lib/utils/hashing.d.ts +50 -6
  92. package/lib/utils/index.cjs +2 -1
  93. package/lib/utils/index.d.ts +1 -0
  94. package/lib/utils/registry.cjs +1 -1
  95. package/lib/utils/registry.d.ts +2 -2
  96. package/lib/utils/serialization.cjs +2 -2
  97. package/lib/utils/serialization.d.ts +1 -1
  98. package/lib/utils/strings.cjs +5 -5
  99. package/lib/utils/strings.d.ts +4 -4
  100. package/lib/utils/types.cjs +1 -1
  101. package/lib/utils/types.d.ts +123 -16
  102. package/lib/validation/Validators/DateValidator.cjs +41 -9
  103. package/lib/validation/Validators/DateValidator.d.ts +40 -8
  104. package/lib/validation/Validators/EmailValidator.cjs +40 -8
  105. package/lib/validation/Validators/EmailValidator.d.ts +39 -7
  106. package/lib/validation/Validators/ListValidator.cjs +45 -7
  107. package/lib/validation/Validators/ListValidator.d.ts +44 -6
  108. package/lib/validation/Validators/MaxLengthValidator.cjs +3 -3
  109. package/lib/validation/Validators/MaxValidator.cjs +53 -7
  110. package/lib/validation/Validators/MaxValidator.d.ts +52 -6
  111. package/lib/validation/Validators/MinLengthValidator.cjs +3 -3
  112. package/lib/validation/Validators/MinValidator.cjs +53 -7
  113. package/lib/validation/Validators/MinValidator.d.ts +52 -6
  114. package/lib/validation/Validators/PatternValidator.cjs +76 -10
  115. package/lib/validation/Validators/PatternValidator.d.ts +75 -9
  116. package/lib/validation/Validators/RequiredValidator.cjs +53 -7
  117. package/lib/validation/Validators/RequiredValidator.d.ts +52 -6
  118. package/lib/validation/Validators/TypeValidator.cjs +69 -7
  119. package/lib/validation/Validators/TypeValidator.d.ts +60 -6
  120. package/lib/validation/Validators/URLValidator.cjs +42 -8
  121. package/lib/validation/Validators/URLValidator.d.ts +41 -7
  122. package/lib/validation/Validators/Validator.cjs +68 -11
  123. package/lib/validation/Validators/Validator.d.ts +77 -14
  124. package/lib/validation/Validators/ValidatorRegistry.cjs +4 -12
  125. package/lib/validation/Validators/ValidatorRegistry.d.ts +1 -7
  126. package/lib/validation/Validators/constants.cjs +2 -1
  127. package/lib/validation/Validators/constants.d.ts +16 -15
  128. package/lib/validation/decorators.cjs +112 -63
  129. package/lib/validation/decorators.d.ts +50 -40
  130. package/lib/validation/types.cjs +2 -1
  131. package/lib/validation/types.d.ts +154 -36
  132. package/package.json +2 -2
@@ -4,38 +4,71 @@ import { sf } from "../utils/strings";
4
4
  import { parseDate } from "../utils/dates";
5
5
  import { propMetadata } from "../utils/decorators";
6
6
  import { Validation } from "./Validation";
7
+ import { Decoration } from "../utils/Decoration";
7
8
  /**
8
- * @summary Marks the property as required.
9
- * @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
9
+ * @description Property decorator that marks a field as required
10
+ * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.
11
+ * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.
12
+ * This decorator is commonly used as the first validation step for important fields.
10
13
  *
11
- * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
14
+ * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
15
+ * @return {PropertyDecorator} A decorator function that can be applied to class properties
12
16
  *
13
17
  * @function required
14
- *
15
18
  * @category Decorators
19
+ *
20
+ * @example
21
+ * ```typescript
22
+ * class User {
23
+ * @required()
24
+ * username: string;
25
+ *
26
+ * @required("Email address is mandatory")
27
+ * email: string;
28
+ * }
29
+ * ```
16
30
  */
17
31
  export function required(message = DEFAULT_ERROR_MESSAGES.REQUIRED) {
18
- return propMetadata(Validation.key(ValidationKeys.REQUIRED), {
32
+ const key = Validation.key(ValidationKeys.REQUIRED);
33
+ return Decoration.for(key)
34
+ .define(propMetadata(key, {
19
35
  message: message,
20
- });
36
+ }))
37
+ .apply();
21
38
  }
22
39
  /**
23
- * @summary Defines a minimum value for the property
24
- * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
40
+ * @description Property decorator that enforces a minimum value constraint
41
+ * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.
42
+ * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.
43
+ * This decorator works with numeric values and dates.
25
44
  *
26
- * @param {number | Date} value
27
- * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
45
+ * @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
46
+ * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
47
+ * @return {PropertyDecorator} A decorator function that can be applied to class properties
28
48
  *
29
49
  * @function min
30
- * @memberOf module:decorator-validation.Decorators.Validation
31
50
  * @category Decorators
51
+ *
52
+ * @example
53
+ * ```typescript
54
+ * class Product {
55
+ * @min(0)
56
+ * price: number;
57
+ *
58
+ * @min(new Date(2023, 0, 1), "Date must be after January 1, 2023")
59
+ * releaseDate: Date;
60
+ * }
61
+ * ```
32
62
  */
33
63
  export function min(value, message = DEFAULT_ERROR_MESSAGES.MIN) {
34
- return propMetadata(Validation.key(ValidationKeys.MIN), {
35
- min: value,
64
+ const key = Validation.key(ValidationKeys.MIN);
65
+ return Decoration.for(key)
66
+ .define(propMetadata(Validation.key(ValidationKeys.MIN), {
67
+ [ValidationKeys.MIN]: value,
36
68
  message: message,
37
69
  types: [Number.name, Date.name],
38
- });
70
+ }))
71
+ .apply();
39
72
  }
40
73
  /**
41
74
  * @summary Defines a maximum value for the property
@@ -45,15 +78,17 @@ export function min(value, message = DEFAULT_ERROR_MESSAGES.MIN) {
45
78
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
46
79
  *
47
80
  * @function max
48
- * @memberOf module:decorator-validation.Decorators.Validation
49
81
  * @category Decorators
50
82
  */
51
83
  export function max(value, message = DEFAULT_ERROR_MESSAGES.MAX) {
52
- return propMetadata(Validation.key(ValidationKeys.MAX), {
53
- max: value,
84
+ const key = Validation.key(ValidationKeys.MAX);
85
+ return Decoration.for(key)
86
+ .define(propMetadata(key, {
87
+ [ValidationKeys.MAX]: value,
54
88
  message: message,
55
89
  types: [Number.name, Date.name],
56
- });
90
+ }))
91
+ .apply();
57
92
  }
58
93
  /**
59
94
  * @summary Defines a step value for the property
@@ -63,15 +98,17 @@ export function max(value, message = DEFAULT_ERROR_MESSAGES.MAX) {
63
98
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
64
99
  *
65
100
  * @function step
66
- * @memberOf module:decorator-validation.Decorators.Validation
67
101
  * @category Decorators
68
102
  */
69
103
  export function step(value, message = DEFAULT_ERROR_MESSAGES.STEP) {
70
- return propMetadata(Validation.key(ValidationKeys.STEP), {
71
- step: value,
104
+ const key = Validation.key(ValidationKeys.STEP);
105
+ return Decoration.for(key)
106
+ .define(propMetadata(key, {
107
+ [ValidationKeys.STEP]: value,
72
108
  message: message,
73
109
  types: [Number.name],
74
- });
110
+ }))
111
+ .apply();
75
112
  }
76
113
  /**
77
114
  * @summary Defines a minimum length for the property
@@ -81,15 +118,17 @@ export function step(value, message = DEFAULT_ERROR_MESSAGES.STEP) {
81
118
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
82
119
  *
83
120
  * @function minlength
84
- * @memberOf module:decorator-validation.Decorators.Validation
85
121
  * @category Decorators
86
122
  */
87
123
  export function minlength(value, message = DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
88
- return propMetadata(Validation.key(ValidationKeys.MIN_LENGTH), {
89
- minLength: value,
124
+ const key = Validation.key(ValidationKeys.MIN_LENGTH);
125
+ return Decoration.for(key)
126
+ .define(propMetadata(key, {
127
+ [ValidationKeys.MIN_LENGTH]: value,
90
128
  message: message,
91
129
  types: [String.name, Array.name, Set.name],
92
- });
130
+ }))
131
+ .apply();
93
132
  }
94
133
  /**
95
134
  * @summary Defines a maximum length for the property
@@ -99,15 +138,17 @@ export function minlength(value, message = DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
99
138
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
100
139
  *
101
140
  * @function maxlength
102
- * @memberOf module:decorator-validation.Decorators.Validation
103
141
  * @category Decorators
104
142
  */
105
143
  export function maxlength(value, message = DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
106
- return propMetadata(Validation.key(ValidationKeys.MAX_LENGTH), {
107
- maxLength: value,
144
+ const key = Validation.key(ValidationKeys.MAX_LENGTH);
145
+ return Decoration.for(key)
146
+ .define(propMetadata(key, {
147
+ [ValidationKeys.MAX_LENGTH]: value,
108
148
  message: message,
109
149
  types: [String.name, Array.name, Set.name],
110
- });
150
+ }))
151
+ .apply();
111
152
  }
112
153
  /**
113
154
  * @summary Defines a RegExp pattern the property must respect
@@ -117,15 +158,17 @@ export function maxlength(value, message = DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
117
158
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
118
159
  *
119
160
  * @function pattern
120
- * @memberOf module:decorator-validation.Decorators.Validation
121
161
  * @category Decorators
122
162
  */
123
163
  export function pattern(value, message = DEFAULT_ERROR_MESSAGES.PATTERN) {
124
- return propMetadata(Validation.key(ValidationKeys.PATTERN), {
125
- pattern: typeof value === "string" ? value : value.toString(),
164
+ const key = Validation.key(ValidationKeys.PATTERN);
165
+ return Decoration.for(key)
166
+ .define(propMetadata(Validation.key(ValidationKeys.PATTERN), {
167
+ [ValidationKeys.PATTERN]: typeof value === "string" ? value : value.toString(),
126
168
  message: message,
127
169
  types: [String.name],
128
- });
170
+ }))
171
+ .apply();
129
172
  }
130
173
  /**
131
174
  * @summary Defines the property as an email
@@ -134,15 +177,17 @@ export function pattern(value, message = DEFAULT_ERROR_MESSAGES.PATTERN) {
134
177
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
135
178
  *
136
179
  * @function email
137
- * @memberOf module:decorator-validation.Decorators.Validation
138
180
  * @category Decorators
139
181
  */
140
182
  export function email(message = DEFAULT_ERROR_MESSAGES.EMAIL) {
141
- return propMetadata(Validation.key(ValidationKeys.EMAIL), {
142
- pattern: DEFAULT_PATTERNS.EMAIL,
183
+ const key = Validation.key(ValidationKeys.EMAIL);
184
+ return Decoration.for(key)
185
+ .define(propMetadata(Validation.key(ValidationKeys.EMAIL), {
186
+ [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL,
143
187
  message: message,
144
188
  types: [String.name],
145
- });
189
+ }))
190
+ .apply();
146
191
  }
147
192
  /**
148
193
  * @summary Defines the property as an URL
@@ -151,15 +196,17 @@ export function email(message = DEFAULT_ERROR_MESSAGES.EMAIL) {
151
196
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
152
197
  *
153
198
  * @function url
154
- * @memberOf module:decorator-validation.Decorators.Validation
155
199
  * @category Decorators
156
200
  */
157
201
  export function url(message = DEFAULT_ERROR_MESSAGES.URL) {
158
- return propMetadata(Validation.key(ValidationKeys.URL), {
159
- pattern: DEFAULT_PATTERNS.URL,
202
+ const key = Validation.key(ValidationKeys.URL);
203
+ return Decoration.for(key)
204
+ .define(propMetadata(Validation.key(ValidationKeys.URL), {
205
+ [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL,
160
206
  message: message,
161
207
  types: [String.name],
162
- });
208
+ }))
209
+ .apply();
163
210
  }
164
211
  /**
165
212
  * @summary Enforces type verification
@@ -169,14 +216,16 @@ export function url(message = DEFAULT_ERROR_MESSAGES.URL) {
169
216
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
170
217
  *
171
218
  * @function type
172
- * @memberOf module:decorator-validation.Decorators.Validation
173
219
  * @category Decorators
174
220
  */
175
221
  export function type(types, message = DEFAULT_ERROR_MESSAGES.TYPE) {
176
- return propMetadata(Validation.key(ValidationKeys.TYPE), {
222
+ const key = Validation.key(ValidationKeys.TYPE);
223
+ return Decoration.for(key)
224
+ .define(propMetadata(Validation.key(ValidationKeys.TYPE), {
177
225
  customTypes: types,
178
226
  message: message,
179
- });
227
+ }))
228
+ .apply();
180
229
  }
181
230
  /**
182
231
  * @summary Date Handler Decorator
@@ -186,17 +235,16 @@ export function type(types, message = DEFAULT_ERROR_MESSAGES.TYPE) {
186
235
  *
187
236
  * @param {string} format accepted format according to {@link formatDate}
188
237
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
189
- * @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
190
238
  *
191
239
  * @function date
192
240
  *
193
- * @memberOf module:decorator-validation.Decorators.Validation
194
241
  * @category Decorators
195
242
  */
196
243
  export function date(format = "dd/MM/yyyy", message = DEFAULT_ERROR_MESSAGES.DATE) {
197
- return (target, propertyKey) => {
198
- propMetadata(Validation.key(ValidationKeys.DATE), {
199
- format: format,
244
+ const key = Validation.key(ValidationKeys.DATE);
245
+ const dateDec = (target, propertyKey) => {
246
+ propMetadata(key, {
247
+ [ValidationKeys.FORMAT]: format,
200
248
  message: message,
201
249
  types: [Date.name],
202
250
  })(target, propertyKey);
@@ -228,26 +276,28 @@ export function date(format = "dd/MM/yyyy", message = DEFAULT_ERROR_MESSAGES.DAT
228
276
  },
229
277
  });
230
278
  };
279
+ return Decoration.for(key).define(dateDec).apply();
231
280
  }
232
281
  /**
233
282
  * @summary Password Handler Decorator
234
283
  * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
235
284
  *
236
- * @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
285
+ * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}
237
286
  * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
238
- * @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
239
287
  *
240
288
  * @function password
241
289
  *
242
- * @memberOf module:decorator-validation.Decorators.Validation
243
290
  * @category Decorators
244
291
  */
245
292
  export function password(pattern = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = DEFAULT_ERROR_MESSAGES.PASSWORD) {
246
- return propMetadata(Validation.key(ValidationKeys.PASSWORD), {
247
- pattern: pattern,
293
+ const key = Validation.key(ValidationKeys.PASSWORD);
294
+ return Decoration.for(key)
295
+ .define(propMetadata(key, {
296
+ [ValidationKeys.PATTERN]: pattern,
248
297
  message: message,
249
298
  types: [String.name],
250
- });
299
+ }))
300
+ .apply();
251
301
  }
252
302
  /**
253
303
  * @summary List Decorator
@@ -256,19 +306,20 @@ export function password(pattern = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,
256
306
  * @param {ModelConstructor} clazz
257
307
  * @param {string} [collection] The collection being used. defaults to Array
258
308
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
259
- * @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
260
309
  *
261
310
  * @function list
262
311
  *
263
- * @memberOf module:decorator-validation.Decorators.Validation
264
312
  * @category Decorators
265
313
  */
266
314
  export function list(clazz, collection = "Array", message = DEFAULT_ERROR_MESSAGES.LIST) {
267
- return propMetadata(Validation.key(ValidationKeys.LIST), {
315
+ const key = Validation.key(ValidationKeys.LIST);
316
+ return Decoration.for(key)
317
+ .define(propMetadata(key, {
268
318
  clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
269
319
  type: collection,
270
320
  message: message,
271
- });
321
+ }))
322
+ .apply();
272
323
  }
273
324
  /**
274
325
  * @summary Set Decorator
@@ -276,14 +327,12 @@ export function list(clazz, collection = "Array", message = DEFAULT_ERROR_MESSAG
276
327
  *
277
328
  * @param {ModelConstructor} clazz
278
329
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
279
- * @param {Constructor<Validator>} [validator]
280
330
  *
281
331
  * @function set
282
332
  *
283
- * @memberOf module:decorator-validation.Decorators.Validation
284
333
  * @category Decorators
285
334
  */
286
335
  export function set(clazz, message = DEFAULT_ERROR_MESSAGES.LIST) {
287
336
  return list(clazz, "Set", message);
288
337
  }
289
- //# 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    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    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    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      minLength: 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      maxLength: 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      pattern: 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      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    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      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    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"]}
338
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/validation/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAE1B,OAAO,EACL,sBAAsB,EACtB,gBAAgB,EAChB,cAAc,GACf,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAEtC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,QAAQ,CAAC,UAAkB,sBAAsB,CAAC,QAAQ;IACxE,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IACpD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,GAAG,EAAE;QACpC,OAAO,EAAE,OAAO;KACjB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,UAAU,GAAG,CACjB,KAA6B,EAC7B,UAAkB,sBAAsB,CAAC,GAAG;IAE5C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IAC/C,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;QACnE,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK;QAC3B,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;KAChC,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,GAAG,CACjB,KAA6B,EAC7B,UAAkB,sBAAsB,CAAC,GAAG;IAE5C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IAC/C,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,GAAG,EAAE;QACpC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK;QAC3B,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;KAChC,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,IAAI,CAClB,KAAa,EACb,UAAkB,sBAAsB,CAAC,IAAI;IAE7C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAChD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,GAAG,EAAE;QACpC,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK;QAC5B,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,SAAS,CACvB,KAAa,EACb,UAAkB,sBAAsB,CAAC,UAAU;IAEnD,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACtD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,GAAG,EAAE;QACpC,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,KAAK;QAClC,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC;KAC3C,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,SAAS,CACvB,KAAa,EACb,UAAkB,sBAAsB,CAAC,UAAU;IAEnD,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACtD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,GAAG,EAAE;QACpC,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,KAAK;QAClC,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC;KAC3C,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,OAAO,CACrB,KAAsB,EACtB,UAAkB,sBAAsB,CAAC,OAAO;IAEhD,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACnD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;QACvE,CAAC,cAAc,CAAC,OAAO,CAAC,EACtB,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;QACtD,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,KAAK,CAAC,UAAkB,sBAAsB,CAAC,KAAK;IAClE,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;IACjD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;QACrE,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,gBAAgB,CAAC,KAAK;QAChD,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,GAAG,CAAC,UAAkB,sBAAsB,CAAC,GAAG;IAC9D,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;IAC/C,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;QACnE,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,gBAAgB,CAAC,GAAG;QAC9C,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,IAAI,CAClB,KAAwB,EACxB,UAAkB,sBAAsB,CAAC,IAAI;IAE7C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAChD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAqB,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;QACpE,WAAW,EAAE,KAAK;QAClB,OAAO,EAAE,OAAO;KACjB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,IAAI,CAClB,SAAiB,YAAY,EAC7B,UAAkB,sBAAsB,CAAC,IAAI;IAE7C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAChD,MAAM,OAAO,GAAG,CAAC,MAA2B,EAAE,WAAiB,EAAO,EAAE;QACtE,YAAY,CAAC,GAAG,EAAE;YAChB,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,MAAM;YAC/B,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC;SACnB,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAExB,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QAE7B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;YACzC,YAAY,EAAE,KAAK;YACnB,GAAG,CAAY,QAAuB;gBACpC,MAAM,UAAU,GAAG,MAAM,CAAC,wBAAwB,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;gBACtE,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,YAAY;oBACxC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE;wBACvC,UAAU,EAAE,IAAI;wBAChB,YAAY,EAAE,KAAK;wBACnB,GAAG,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;wBAC3B,GAAG,EAAE,CAAC,QAAgC,EAAE,EAAE;4BACxC,IAAI,GAAqB,CAAC;4BAC1B,IAAI,CAAC;gCACH,GAAG,GAAG,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;gCAClC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;4BACxB,CAAC;4BAAC,OAAO,CAAM,EAAE,CAAC;gCAChB,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,2BAA2B,EAAE,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC;4BACjE,CAAC;wBACH,CAAC;qBACF,CAAC,CAAC;gBACL,IAAI,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC;YAC/B,CAAC;YACD,GAAG;gBACD,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACtB,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC;IACF,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC;AACrD,CAAC;AAED;;;;;;;;;;GAUG;AACH,MAAM,UAAU,QAAQ,CACtB,UAAkB,gBAAgB,CAAC,QAAQ,CAAC,iBAAiB,EAC7D,UAAkB,sBAAsB,CAAC,QAAQ;IAEjD,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IACpD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAC,GAAG,EAAE;QAChB,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,OAAO;QACjC,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,IAAI,CAClB,KAAsD,EACtD,aAA8B,OAAO,EACrC,UAAkB,sBAAsB,CAAC,IAAI;IAE7C,MAAM,GAAG,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;IAChD,OAAO,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;SACvB,MAAM,CACL,YAAY,CAAC,GAAG,EAAE;QAChB,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QACrE,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,OAAO;KACjB,CAAC,CACH;SACA,KAAK,EAAE,CAAC;AACb,CAAC;AAED;;;;;;;;;;GAUG;AACH,MAAM,UAAU,GAAG,CACjB,KAA4B,EAC5B,UAAkB,sBAAsB,CAAC,IAAI;IAE7C,OAAO,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;AACrC,CAAC","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"]}