@decaf-ts/decorator-validation 1.6.5 → 1.7.0

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