@decaf-ts/decorator-validation 1.7.6 → 1.7.8

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 (79) hide show
  1. package/dist/decorator-validation.cjs +632 -259
  2. package/dist/decorator-validation.esm.cjs +625 -260
  3. package/lib/constants/validation.cjs +3 -2
  4. package/lib/constants/validation.d.ts +1 -0
  5. package/lib/esm/constants/validation.d.ts +1 -0
  6. package/lib/esm/constants/validation.js +2 -1
  7. package/lib/esm/index.d.ts +1 -1
  8. package/lib/esm/index.js +1 -1
  9. package/lib/esm/mcp/ModelContextProtocol.d.ts +14 -22
  10. package/lib/esm/mcp/ModelContextProtocol.js +55 -51
  11. package/lib/esm/model/Model.d.ts +11 -8
  12. package/lib/esm/model/Model.js +12 -6
  13. package/lib/esm/model/decorators.js +1 -1
  14. package/lib/esm/model/types.d.ts +37 -9
  15. package/lib/esm/model/types.js +1 -1
  16. package/lib/esm/model/utils.d.ts +14 -1
  17. package/lib/esm/model/utils.js +15 -1
  18. package/lib/esm/model/validation.d.ts +107 -5
  19. package/lib/esm/model/validation.js +329 -124
  20. package/lib/esm/types/index.d.ts +1 -0
  21. package/lib/esm/types/index.js +2 -0
  22. package/lib/esm/types/validation.d.ts +25 -0
  23. package/lib/esm/types/validation.js +2 -0
  24. package/lib/esm/utils/Decoration.js +4 -6
  25. package/lib/esm/validation/Validators/AsyncValidator.d.ts +72 -0
  26. package/lib/esm/validation/Validators/AsyncValidator.js +61 -0
  27. package/lib/esm/validation/Validators/BaseValidator.d.ts +118 -0
  28. package/lib/esm/validation/Validators/BaseValidator.js +117 -0
  29. package/lib/esm/validation/Validators/ListValidator.js +2 -2
  30. package/lib/esm/validation/Validators/MinLengthValidator.d.ts +1 -1
  31. package/lib/esm/validation/Validators/MinLengthValidator.js +2 -2
  32. package/lib/esm/validation/Validators/TypeValidator.js +1 -1
  33. package/lib/esm/validation/Validators/Validator.d.ts +28 -68
  34. package/lib/esm/validation/Validators/Validator.js +30 -86
  35. package/lib/esm/validation/Validators/constants.d.ts +12 -11
  36. package/lib/esm/validation/Validators/constants.js +14 -12
  37. package/lib/esm/validation/Validators/index.d.ts +1 -0
  38. package/lib/esm/validation/Validators/index.js +2 -1
  39. package/lib/esm/validation/decorators.d.ts +2 -1
  40. package/lib/esm/validation/decorators.js +31 -8
  41. package/lib/esm/validation/types.d.ts +19 -0
  42. package/lib/esm/validation/types.js +1 -1
  43. package/lib/index.cjs +1 -1
  44. package/lib/index.d.ts +1 -1
  45. package/lib/mcp/ModelContextProtocol.cjs +55 -51
  46. package/lib/mcp/ModelContextProtocol.d.ts +14 -22
  47. package/lib/model/Model.cjs +11 -5
  48. package/lib/model/Model.d.ts +11 -8
  49. package/lib/model/decorators.cjs +1 -1
  50. package/lib/model/types.cjs +1 -1
  51. package/lib/model/types.d.ts +37 -9
  52. package/lib/model/utils.cjs +16 -1
  53. package/lib/model/utils.d.ts +14 -1
  54. package/lib/model/validation.cjs +334 -125
  55. package/lib/model/validation.d.ts +107 -5
  56. package/lib/types/index.cjs +18 -0
  57. package/lib/types/index.d.ts +1 -0
  58. package/lib/types/validation.cjs +3 -0
  59. package/lib/types/validation.d.ts +25 -0
  60. package/lib/utils/Decoration.cjs +4 -6
  61. package/lib/validation/Validators/AsyncValidator.cjs +65 -0
  62. package/lib/validation/Validators/AsyncValidator.d.ts +72 -0
  63. package/lib/validation/Validators/BaseValidator.cjs +121 -0
  64. package/lib/validation/Validators/BaseValidator.d.ts +118 -0
  65. package/lib/validation/Validators/ListValidator.cjs +2 -2
  66. package/lib/validation/Validators/MinLengthValidator.cjs +2 -2
  67. package/lib/validation/Validators/MinLengthValidator.d.ts +1 -1
  68. package/lib/validation/Validators/TypeValidator.cjs +1 -1
  69. package/lib/validation/Validators/Validator.cjs +30 -86
  70. package/lib/validation/Validators/Validator.d.ts +28 -68
  71. package/lib/validation/Validators/constants.cjs +14 -12
  72. package/lib/validation/Validators/constants.d.ts +12 -11
  73. package/lib/validation/Validators/index.cjs +2 -1
  74. package/lib/validation/Validators/index.d.ts +1 -0
  75. package/lib/validation/decorators.cjs +32 -8
  76. package/lib/validation/decorators.d.ts +2 -1
  77. package/lib/validation/types.cjs +1 -1
  78. package/lib/validation/types.d.ts +19 -0
  79. package/package.json +1 -1
@@ -6,6 +6,7 @@ import { propMetadata } from "./../utils/decorators.js";
6
6
  import { Validation } from "./Validation.js";
7
7
  import { Decoration } from "./../utils/Decoration.js";
8
8
  import { apply } from "@decaf-ts/reflection";
9
+ import { ASYNC_META_KEY } from "./../constants/index.js";
9
10
  /**
10
11
  * @description Combined property decorator factory for metadata and attribute marking
11
12
  * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it
@@ -22,6 +23,12 @@ export function validationMetadata(decorator, key, value) {
22
23
  Validation.registerDecorator(key, decorator);
23
24
  return apply(propMetadata(key, value));
24
25
  }
26
+ export function async() {
27
+ return (model) => {
28
+ if (!Object.prototype.hasOwnProperty.call(model, ASYNC_META_KEY))
29
+ model[ASYNC_META_KEY] = true;
30
+ };
31
+ }
25
32
  /**
26
33
  * @description Property decorator that marks a field as required
27
34
  * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.
@@ -50,6 +57,7 @@ export function required(message = DEFAULT_ERROR_MESSAGES.REQUIRED) {
50
57
  const meta = {
51
58
  message: message,
52
59
  description: `defines the attribute as required`,
60
+ async: false,
53
61
  };
54
62
  return Decoration.for(key)
55
63
  .define(validationMetadata(required, key, meta))
@@ -86,6 +94,7 @@ export function min(value, message = DEFAULT_ERROR_MESSAGES.MIN) {
86
94
  message: message,
87
95
  types: [Number.name, Date.name],
88
96
  description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,
97
+ async: false,
89
98
  };
90
99
  return Decoration.for(key)
91
100
  .define(validationMetadata(min, key, meta))
@@ -108,6 +117,7 @@ export function max(value, message = DEFAULT_ERROR_MESSAGES.MAX) {
108
117
  message: message,
109
118
  types: [Number.name, Date.name],
110
119
  description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,
120
+ async: false,
111
121
  };
112
122
  return Decoration.for(key)
113
123
  .define(validationMetadata(max, key, meta))
@@ -130,6 +140,7 @@ export function step(value, message = DEFAULT_ERROR_MESSAGES.STEP) {
130
140
  message: message,
131
141
  types: [Number.name],
132
142
  description: `defines the step of the attribute as ${value}`,
143
+ async: false,
133
144
  };
134
145
  return Decoration.for(key)
135
146
  .define(validationMetadata(step, key, meta))
@@ -152,6 +163,7 @@ export function minlength(value, message = DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
152
163
  message: message,
153
164
  types: [String.name, Array.name, Set.name],
154
165
  description: `defines the min length of the attribute as ${value} (applies to strings or lists)`,
166
+ async: false,
155
167
  };
156
168
  return Decoration.for(key)
157
169
  .define(validationMetadata(minlength, key, meta))
@@ -174,6 +186,7 @@ export function maxlength(value, message = DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
174
186
  message: message,
175
187
  types: [String.name, Array.name, Set.name],
176
188
  description: `defines the max length of the attribute as ${value} (applies to strings or lists)`,
189
+ async: false,
177
190
  };
178
191
  return Decoration.for(key)
179
192
  .define(validationMetadata(maxlength, key, meta))
@@ -196,6 +209,7 @@ export function pattern(value, message = DEFAULT_ERROR_MESSAGES.PATTERN) {
196
209
  message: message,
197
210
  types: [String.name],
198
211
  description: `assigns the ${value === "string" ? value : value.toString()} pattern to the attribute`,
212
+ async: false,
199
213
  };
200
214
  return Decoration.for(key)
201
215
  .define(validationMetadata(pattern, key, meta))
@@ -217,6 +231,7 @@ export function email(message = DEFAULT_ERROR_MESSAGES.EMAIL) {
217
231
  message: message,
218
232
  types: [String.name],
219
233
  description: "marks the attribute as an email",
234
+ async: false,
220
235
  };
221
236
  return Decoration.for(key)
222
237
  .define(validationMetadata(email, key, meta))
@@ -238,6 +253,7 @@ export function url(message = DEFAULT_ERROR_MESSAGES.URL) {
238
253
  message: message,
239
254
  types: [String.name],
240
255
  description: "marks the attribute as an url",
256
+ async: false,
241
257
  };
242
258
  return Decoration.for(key)
243
259
  .define(validationMetadata(url, key, meta))
@@ -259,6 +275,7 @@ export function type(types, message = DEFAULT_ERROR_MESSAGES.TYPE) {
259
275
  customTypes: types,
260
276
  message: message,
261
277
  description: "defines the accepted types for the attribute",
278
+ async: false,
262
279
  };
263
280
  return Decoration.for(key)
264
281
  .define(validationMetadata(type, key, meta))
@@ -284,6 +301,7 @@ export function date(format = "dd/MM/yyyy", message = DEFAULT_ERROR_MESSAGES.DAT
284
301
  message: message,
285
302
  types: [Date.name],
286
303
  description: `defines the attribute as a date with the format ${format}`,
304
+ async: false,
287
305
  };
288
306
  const dateDec = (target, propertyKey) => {
289
307
  validationMetadata(date, key, meta)(target, propertyKey);
@@ -335,6 +353,7 @@ export function password(pattern = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,
335
353
  message: message,
336
354
  types: [String.name],
337
355
  description: `attribute as a password`,
356
+ async: false,
338
357
  };
339
358
  return Decoration.for(key)
340
359
  .define(validationMetadata(password, key, meta))
@@ -344,7 +363,7 @@ export function password(pattern = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,
344
363
  * @summary List Decorator
345
364
  * @description Also sets the {@link type} to the provided collection
346
365
  *
347
- * @param {Constructor} clazz
366
+ * @param {ModelConstructor} clazz
348
367
  * @param {string} [collection] The collection being used. defaults to Array
349
368
  * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
350
369
  *
@@ -358,6 +377,7 @@ export function list(clazz, collection = "Array", message = DEFAULT_ERROR_MESSAG
358
377
  clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
359
378
  type: collection,
360
379
  message: message,
380
+ async: false,
361
381
  description: `defines the attribute as a ${collection} of ${clazz.name}`,
362
382
  };
363
383
  return Decoration.for(key)
@@ -396,7 +416,7 @@ export function eq(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.EQUALS) {
396
416
  [ValidationKeys.EQUALS]: propertyToCompare,
397
417
  description: `defines attribute as equal to ${propertyToCompare}`,
398
418
  };
399
- return validationMetadata(eq, Validation.key(ValidationKeys.EQUALS), options);
419
+ return validationMetadata(eq, Validation.key(ValidationKeys.EQUALS), { ...options, async: false });
400
420
  }
401
421
  /**
402
422
  * @summary Declares that the decorated property must be different from another specified property.
@@ -416,7 +436,10 @@ export function diff(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.DIFF) {
416
436
  [ValidationKeys.DIFF]: propertyToCompare,
417
437
  description: `defines attribute as different to ${propertyToCompare}`,
418
438
  };
419
- return validationMetadata(diff, Validation.key(ValidationKeys.DIFF), options);
439
+ return validationMetadata(diff, Validation.key(ValidationKeys.DIFF), {
440
+ ...options,
441
+ async: false,
442
+ });
420
443
  }
421
444
  /**
422
445
  * @summary Declares that the decorated property must be less than another specified property.
@@ -436,7 +459,7 @@ export function lt(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.LESS_THAN
436
459
  [ValidationKeys.LESS_THAN]: propertyToCompare,
437
460
  description: `defines attribute as less than to ${propertyToCompare}`,
438
461
  };
439
- return validationMetadata(lt, Validation.key(ValidationKeys.LESS_THAN), options);
462
+ return validationMetadata(lt, Validation.key(ValidationKeys.LESS_THAN), { ...options, async: false });
440
463
  }
441
464
  /**
442
465
  * @summary Declares that the decorated property must be equal or less than another specified property.
@@ -456,7 +479,7 @@ export function lte(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.LESS_THA
456
479
  [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,
457
480
  description: `defines attribute as less or equal to ${propertyToCompare}`,
458
481
  };
459
- return validationMetadata(lte, Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL), options);
482
+ return validationMetadata(lte, Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL), { ...options, async: false });
460
483
  }
461
484
  /**
462
485
  * @summary Declares that the decorated property must be greater than another specified property.
@@ -476,7 +499,7 @@ export function gt(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.GREATER_T
476
499
  [ValidationKeys.GREATER_THAN]: propertyToCompare,
477
500
  description: `defines attribute as greater than ${propertyToCompare}`,
478
501
  };
479
- return validationMetadata(gt, Validation.key(ValidationKeys.GREATER_THAN), options);
502
+ return validationMetadata(gt, Validation.key(ValidationKeys.GREATER_THAN), { ...options, async: false });
480
503
  }
481
504
  /**
482
505
  * @summary Declares that the decorated property must be equal or greater than another specified property.
@@ -496,6 +519,6 @@ export function gte(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.GREATER_
496
519
  [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,
497
520
  description: `defines attribute as greater or equal to ${propertyToCompare}`,
498
521
  };
499
- return validationMetadata(gte, Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL), options);
522
+ return validationMetadata(gte, Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL), { ...options, async: false });
500
523
  }
501
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport {\n  DateValidatorOptions,\n  DiffValidatorOptions,\n  EqualsValidatorOptions,\n  GreaterThanOrEqualValidatorOptions,\n  GreaterThanValidatorOptions,\n  LessThanOrEqualValidatorOptions,\n  LessThanValidatorOptions,\n  ListValidatorOptions,\n  MaxLengthValidatorOptions,\n  MaxValidatorOptions,\n  MinLengthValidatorOptions,\n  MinValidatorOptions,\n  PatternValidatorOptions,\n  StepValidatorOptions,\n  ValidationMetadata,\n  ValidatorOptions,\n} from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { Constructor, ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\nimport { Decoration } from \"../utils/Decoration\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Combined property decorator factory for metadata and attribute marking\n * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it\n *\n * @template V\n * @param {PropertyDecorator} decorator - The metadata key\n * @param {string} key - The metadata key\n * @param {V} value - The metadata value to associate with the property\n * @return {Function} - Combined decorator function\n * @function validationMetadata\n * @category Property Decorators\n */\nexport function validationMetadata<V>(decorator: any, key: string, value: V) {\n  Validation.registerDecorator(key, decorator);\n  return apply(propMetadata<V>(key, value));\n}\n\n/**\n * @description Property decorator that marks a field as required\n * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.\n * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.\n * This decorator is commonly used as the first validation step for important fields.\n *\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function required\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class User {\n *   @required()\n *   username: string;\n *\n *   @required(\"Email address is mandatory\")\n *   email: string;\n * }\n * ```\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  const key = Validation.key(ValidationKeys.REQUIRED);\n  const meta: ValidatorOptions = {\n    message: message,\n    description: `defines the attribute as required`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<ValidatorOptions>(required, key, meta))\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  const meta: MinValidatorOptions = {\n    [ValidationKeys.MIN]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinValidatorOptions>(min, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  const meta: MaxValidatorOptions = {\n    [ValidationKeys.MAX]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxValidatorOptions>(max, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  const meta: StepValidatorOptions = {\n    [ValidationKeys.STEP]: value,\n    message: message,\n    types: [Number.name],\n    description: `defines the step of the attribute as ${value}`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<StepValidatorOptions>(step, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  const meta: MinLengthValidatorOptions = {\n    [ValidationKeys.MIN_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the min length of the attribute as ${value} (applies to strings or lists)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinLengthValidatorOptions>(minlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  const meta: MaxLengthValidatorOptions = {\n    [ValidationKeys.MAX_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the max length of the attribute as ${value} (applies to strings or lists)`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxLengthValidatorOptions>(maxlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]:\n      typeof value === \"string\" ? value : value.toString(),\n    message: message,\n    types: [String.name],\n    description: `assigns the ${value === \"string\" ? value : value.toString()} pattern to the attribute`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(pattern, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an email\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(email, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an url\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(url, key, meta))\n    .apply();\n}\n\nexport interface TypeMetadata extends ValidatorOptions {\n  customTypes: string[] | string;\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @category Property Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  const key = Validation.key(ValidationKeys.TYPE);\n  const meta: TypeMetadata = {\n    customTypes: types,\n    message: message,\n    description: \"defines the accepted types for the attribute\",\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<TypeMetadata>(type, key, meta))\n    .apply();\n}\n\nexport interface DateMetadata extends DateValidatorOptions {\n  types: string[];\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n *\n * @function date\n *\n * @category Property Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  const key = Validation.key(ValidationKeys.DATE);\n  const meta: DateMetadata = {\n    [ValidationKeys.FORMAT]: format,\n    message: message,\n    types: [Date.name],\n    description: `defines the attribute as a date with the format ${format}`,\n  };\n  const dateDec = (target: Record<string, any>, propertyKey?: any): any => {\n    validationMetadata(date, key, meta)(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n  return Decoration.for(key).define(dateDec).apply();\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n *\n * @function password\n *\n * @category Property Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  const key = Validation.key(ValidationKeys.PASSWORD);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: pattern.toString(),\n    message: message,\n    types: [String.name],\n    description: `attribute as a password`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(password, key, meta))\n    .apply();\n}\n\nexport interface ListMetadata extends ListValidatorOptions {\n  type: \"Array\" | \"Set\";\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {Constructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function list\n *\n * @category Property Decorators\n */\nexport function list(\n  clazz: Constructor<any> | Constructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  const key = Validation.key(ValidationKeys.LIST);\n  const meta: ListMetadata = {\n    clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n    type: collection,\n    message: message,\n    description: `defines the attribute as a ${collection} of ${(clazz as ModelConstructor<any>).name}`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(list, key, meta))\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @category Property Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: EqualsValidatorOptions = {\n    message: message,\n    [ValidationKeys.EQUALS]: propertyToCompare,\n    description: `defines attribute as equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    eq,\n    Validation.key(ValidationKeys.EQUALS),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be different from another specified property.\n * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare difference against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.\n *\n * @function diff\n * @category Property Decorators\n */\nexport function diff(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.DIFF\n) {\n  const options: DiffValidatorOptions = {\n    message: message,\n    [ValidationKeys.DIFF]: propertyToCompare,\n    description: `defines attribute as different to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    diff,\n    Validation.key(ValidationKeys.DIFF),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.\n *\n * @function lt\n * @category Property Decorators\n */\nexport function lt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN\n) {\n  const options: LessThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN]: propertyToCompare,\n    description: `defines attribute as less than to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lt,\n    Validation.key(ValidationKeys.LESS_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.\n *\n * @function lte\n * @category Property Decorators\n */\nexport function lte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL\n) {\n  const options: LessThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as less or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lte,\n    Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.\n *\n * @function gt\n * @category Property Decorators\n */\nexport function gt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN\n) {\n  const options: GreaterThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN]: propertyToCompare,\n    description: `defines attribute as greater than ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gt,\n    Validation.key(ValidationKeys.GREATER_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.\n *\n * @function gte\n * @category Property Decorators\n */\nexport function gte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL\n) {\n  const options: GreaterThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as greater or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gte,\n    Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n"]}
524
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport {\n  DateValidatorOptions,\n  DiffValidatorOptions,\n  EqualsValidatorOptions,\n  GreaterThanOrEqualValidatorOptions,\n  GreaterThanValidatorOptions,\n  LessThanOrEqualValidatorOptions,\n  LessThanValidatorOptions,\n  ListValidatorOptions,\n  MaxLengthValidatorOptions,\n  MaxValidatorOptions,\n  MinLengthValidatorOptions,\n  MinValidatorOptions,\n  PatternValidatorOptions,\n  StepValidatorOptions,\n  ValidationMetadata,\n  ValidatorOptions,\n} from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { Constructor, ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\nimport { Decoration } from \"../utils/Decoration\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { ASYNC_META_KEY } from \"../constants\";\n\n/**\n * @description Combined property decorator factory for metadata and attribute marking\n * @summary Creates a decorator that both marks a property as a model attribute and assigns metadata to it\n *\n * @template V\n * @param {PropertyDecorator} decorator - The metadata key\n * @param {string} key - The metadata key\n * @param {V} value - The metadata value to associate with the property\n * @return {Function} - Combined decorator function\n * @function validationMetadata\n * @category Property Decorators\n */\nexport function validationMetadata<V>(decorator: any, key: string, value: V) {\n  Validation.registerDecorator(key, decorator);\n  return apply(propMetadata<V>(key, value));\n}\n\nexport function async() {\n  return (model: object): void => {\n    if (!Object.prototype.hasOwnProperty.call(model, ASYNC_META_KEY))\n      (model as any)[ASYNC_META_KEY] = true;\n  };\n}\n\n/**\n * @description Property decorator that marks a field as required\n * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.\n * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.\n * This decorator is commonly used as the first validation step for important fields.\n *\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function required\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class User {\n *   @required()\n *   username: string;\n *\n *   @required(\"Email address is mandatory\")\n *   email: string;\n * }\n * ```\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  const key = Validation.key(ValidationKeys.REQUIRED);\n  const meta: ValidatorOptions = {\n    message: message,\n    description: `defines the attribute as required`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<ValidatorOptions>(required, key, meta))\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  const meta: MinValidatorOptions = {\n    [ValidationKeys.MIN]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinValidatorOptions>(min, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  const meta: MaxValidatorOptions = {\n    [ValidationKeys.MAX]: value,\n    message: message,\n    types: [Number.name, Date.name],\n    description: `defines the max value of the attribute as ${value} (applies to numbers or Dates)`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxValidatorOptions>(max, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  const meta: StepValidatorOptions = {\n    [ValidationKeys.STEP]: value,\n    message: message,\n    types: [Number.name],\n    description: `defines the step of the attribute as ${value}`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<StepValidatorOptions>(step, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  const meta: MinLengthValidatorOptions = {\n    [ValidationKeys.MIN_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the min length of the attribute as ${value} (applies to strings or lists)`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MinLengthValidatorOptions>(minlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  const meta: MaxLengthValidatorOptions = {\n    [ValidationKeys.MAX_LENGTH]: value,\n    message: message,\n    types: [String.name, Array.name, Set.name],\n    description: `defines the max length of the attribute as ${value} (applies to strings or lists)`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<MaxLengthValidatorOptions>(maxlength, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]:\n      typeof value === \"string\" ? value : value.toString(),\n    message: message,\n    types: [String.name],\n    description: `assigns the ${value === \"string\" ? value : value.toString()} pattern to the attribute`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(pattern, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an email\",\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(email, key, meta))\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL.toString(),\n    message: message,\n    types: [String.name],\n    description: \"marks the attribute as an url\",\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<PatternValidatorOptions>(url, key, meta))\n    .apply();\n}\n\nexport interface TypeMetadata extends ValidatorOptions {\n  customTypes: string[] | string;\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @category Property Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  const key = Validation.key(ValidationKeys.TYPE);\n  const meta: TypeMetadata = {\n    customTypes: types,\n    message: message,\n    description: \"defines the accepted types for the attribute\",\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata<TypeMetadata>(type, key, meta))\n    .apply();\n}\n\nexport interface DateMetadata extends DateValidatorOptions {\n  types: string[];\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n *\n * @function date\n *\n * @category Property Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  const key = Validation.key(ValidationKeys.DATE);\n  const meta: DateMetadata = {\n    [ValidationKeys.FORMAT]: format,\n    message: message,\n    types: [Date.name],\n    description: `defines the attribute as a date with the format ${format}`,\n    async: false,\n  };\n  const dateDec = (target: Record<string, any>, propertyKey?: any): any => {\n    validationMetadata(date, key, meta)(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n  return Decoration.for(key).define(dateDec).apply();\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n *\n * @function password\n *\n * @category Property Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  const key = Validation.key(ValidationKeys.PASSWORD);\n  const meta: PatternValidatorOptions = {\n    [ValidationKeys.PATTERN]: pattern.toString(),\n    message: message,\n    types: [String.name],\n    description: `attribute as a password`,\n    async: false,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(password, key, meta))\n    .apply();\n}\n\nexport interface ListMetadata extends ListValidatorOptions {\n  type: \"Array\" | \"Set\";\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function list\n *\n * @category Property Decorators\n */\nexport function list(\n  clazz: Constructor<any> | Constructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  const key = Validation.key(ValidationKeys.LIST);\n  const meta: ListMetadata = {\n    clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n    type: collection,\n    message: message,\n    async: false,\n    description: `defines the attribute as a ${collection} of ${(clazz as ModelConstructor<any>).name}`,\n  };\n  return Decoration.for(key)\n    .define(validationMetadata(list, key, meta))\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @category Property Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: EqualsValidatorOptions = {\n    message: message,\n    [ValidationKeys.EQUALS]: propertyToCompare,\n    description: `defines attribute as equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    eq,\n    Validation.key(ValidationKeys.EQUALS),\n    { ...options, async: false } as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be different from another specified property.\n * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare difference against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.\n *\n * @function diff\n * @category Property Decorators\n */\nexport function diff(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.DIFF\n) {\n  const options: DiffValidatorOptions = {\n    message: message,\n    [ValidationKeys.DIFF]: propertyToCompare,\n    description: `defines attribute as different to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    diff,\n    Validation.key(ValidationKeys.DIFF),\n    {\n      ...options,\n      async: false,\n    } as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.\n *\n * @function lt\n * @category Property Decorators\n */\nexport function lt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN\n) {\n  const options: LessThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN]: propertyToCompare,\n    description: `defines attribute as less than to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lt,\n    Validation.key(ValidationKeys.LESS_THAN),\n    { ...options, async: false } as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.\n *\n * @function lte\n * @category Property Decorators\n */\nexport function lte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL\n) {\n  const options: LessThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as less or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    lte,\n    Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL),\n    { ...options, async: false } as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.\n *\n * @function gt\n * @category Property Decorators\n */\nexport function gt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN\n) {\n  const options: GreaterThanValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN]: propertyToCompare,\n    description: `defines attribute as greater than ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gt,\n    Validation.key(ValidationKeys.GREATER_THAN),\n    { ...options, async: false } as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.\n *\n * @function gte\n * @category Property Decorators\n */\nexport function gte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL\n) {\n  const options: GreaterThanOrEqualValidatorOptions = {\n    message: message,\n    [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,\n    description: `defines attribute as greater or equal to ${propertyToCompare}`,\n  };\n\n  return validationMetadata<ValidationMetadata>(\n    gte,\n    Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL),\n    { ...options, async: false } as ValidationMetadata\n  );\n}\n"]}
@@ -10,6 +10,8 @@ import { IRegistry } from "../utils";
10
10
  * @property {any[]} [args] - Optional arguments for the validator
11
11
  * @property {string} message - Error message to display when validation fails
12
12
  * @property {string[]} [types] - Array of type names that the property can have
13
+ * @property {boolean} async - Indicates whether the validator associated with the decorator performs asynchronous validation logic.
14
+ * Use `true` when the validator returns a Promise, and `false` when the validation is synchronous.
13
15
  *
14
16
  * @typedef {Object} ValidationMetadata
15
17
  * @memberOf module:decorator-validation
@@ -20,6 +22,7 @@ export type ValidationMetadata = {
20
22
  args?: any[];
21
23
  message: string;
22
24
  types?: string[];
25
+ async: boolean;
23
26
  };
24
27
  /**
25
28
  * @description Type definition for property-level validation decorator configuration
@@ -36,6 +39,7 @@ export type ValidationMetadata = {
36
39
  export type ValidationPropertyDecoratorDefinition = {
37
40
  prop: string | symbol;
38
41
  decorators: ValidationDecoratorDefinition[];
42
+ async?: boolean;
39
43
  };
40
44
  /**
41
45
  * @description Type definition for individual validation decorator metadata
@@ -50,6 +54,7 @@ export type ValidationPropertyDecoratorDefinition = {
50
54
  */
51
55
  export type ValidationDecoratorDefinition = DecoratorMetadata & {
52
56
  props: ValidationElementDefinition;
57
+ async?: boolean;
53
58
  };
54
59
  /**
55
60
  * @summary Type for a validator element metadata
@@ -131,11 +136,14 @@ export interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {
131
136
  * @summary Defines the common properties available to all validators
132
137
  * @interface ValidatorOptions
133
138
  * @property {string} [message] - Custom error message to display when validation fails
139
+ * @property {boolean} async - Indicates whether the validator associated with the decorator performs asynchronous validation logic.
140
+ * Use `true` when the validator returns a Promise, and `false` when the validation is synchronous.
134
141
  * @category Validation
135
142
  */
136
143
  export interface ValidatorOptions {
137
144
  message?: string;
138
145
  description?: string;
146
+ async?: boolean;
139
147
  }
140
148
  /**
141
149
  * @description URL validation options interface
@@ -245,6 +253,17 @@ export interface MaxLengthValidatorOptions extends ValidatorOptions {
245
253
  export interface ListValidatorOptions extends ValidatorOptions {
246
254
  clazz: string[];
247
255
  }
256
+ /**
257
+ * @description Unique validation options interface
258
+ * @summary Defines options for unique validation
259
+ * @interface UniqueValidatorOptions
260
+ * @property {string[]} unique - Array of allowed class names or types
261
+ * @memberOf module:decorator-validation
262
+ * @category Validation
263
+ */
264
+ export interface UniqueValidatorOptions extends ValidatorOptions {
265
+ [ValidationKeys.UNIQUE]: string[];
266
+ }
248
267
  /**
249
268
  * @description Date validation options interface
250
269
  * @summary Defines options for date validation
@@ -1,2 +1,2 @@
1
1
  import { ValidationKeys } from "./Validators/index.js";
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/validation/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAa,8BAAqB","sourcesContent":["import { DecoratorMetadata } from \"@decaf-ts/reflection\";\nimport { Constructor } from \"../model\";\nimport { ValidationKeys, Validator } from \"./Validators\";\nimport { IRegistry } from \"../utils\";\n\n/**\n * @description Type definition for metadata used by validation decorators\n * @summary Defines the structure of metadata attached to properties by validation decorators.\n * This metadata is used during validation to determine validation rules and error messages.\n *\n * @property {any[]} [args] - Optional arguments for the validator\n * @property {string} message - Error message to display when validation fails\n * @property {string[]} [types] - Array of type names that the property can have\n *\n * @typedef {Object} ValidationMetadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationMetadata = {\n  [indexer: string]: any;\n  args?: any[];\n  message: string;\n  types?: string[];\n};\n\n/**\n * @description Type definition for property-level validation decorator configuration\n * @summary Defines the structure that associates a property with its validation decorators.\n * This type is used to track which decorators are applied to a specific property during validation.\n *\n * @property {string|symbol} prop - The property name or symbol that the decorators are applied to\n * @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property\n *\n * @typedef {Object} ValidationPropertyDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationPropertyDecoratorDefinition = {\n  prop: string | symbol;\n  decorators: ValidationDecoratorDefinition[];\n};\n\n/**\n * @description Type definition for individual validation decorator metadata\n * @summary Extends the base DecoratorMetadata type with validation-specific properties.\n * This type represents the metadata for a single validation decorator applied to a property.\n *\n * @property {ValidationElementDefinition} props - The validation element properties and configuration\n *\n * @typedef {Object} ValidationDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationDecoratorDefinition = DecoratorMetadata & {\n  props: ValidationElementDefinition;\n};\n\n/**\n * @summary Type for a validator element metadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationElementDefinition = {\n  [indexer: string]: any;\n\n  value?: string | number;\n  message: string;\n  description: string;\n  types?: string[];\n};\n\n/**\n * @summary Type for a model errors\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ModelErrors = Record<string, Record<string, string | undefined>>;\n\n/**\n * @summary Util type for {@link Validator} configuration\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorDefinition = {\n  validator: Constructor<Validator>;\n  validationKey: string;\n  save: boolean;\n};\n\n/**\n * @description Interface for a registry that manages validator instances\n * @summary Defines the contract for a registry that stores and retrieves validators.\n * The registry is responsible for maintaining a collection of validators and providing\n * access to them by key.\n *\n * @interface IValidatorRegistry\n * @template T Type of validator, must extend Validator\n * @extends IRegistry<T>\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {\n  /**\n   * @description Retrieves custom validation keys defined in the registry\n   * @summary Returns a mapping of custom validation keys to their corresponding standard keys.\n   * This allows for aliasing validation keys for specific use cases.\n   *\n   * @return {Record<string, string>} Object mapping custom keys to standard validation keys\n   */\n  getCustomKeys(): Record<string, string>;\n\n  /**\n   * @description Gets all registered validator keys\n   * @summary Returns an array of all validation keys that have registered validators.\n   *\n   * @return {string[]} Array of registered validator keys\n   */\n  getKeys(): string[];\n\n  /**\n   * @description Registers one or more validators with the registry\n   * @summary Adds validators to the registry, making them available for validation operations.\n   * Validators can be provided as instances or as validator definitions.\n   *\n   * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register\n   * @return {void}\n   */\n  register<T extends Validator>(\n    ...validator: (T | ValidatorDefinition)[]\n  ): void;\n\n  /**\n   * @description Retrieves a validator by its key\n   * @summary Looks up a validator in the registry using its validation key.\n   * Returns the validator if found, or undefined if no validator is registered for the key.\n   *\n   * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}\n   * @return {T|undefined} The registered validator or undefined if none matches the provided key\n   */\n  get<T extends Validator>(key: string): T | undefined;\n}\n\n/**\n * @description Base options type for all validators\n * @summary Defines the common properties available to all validators\n * @interface ValidatorOptions\n * @property {string} [message] - Custom error message to display when validation fails\n * @category Validation\n */\nexport interface ValidatorOptions {\n  message?: string;\n  description?: string;\n}\n\n/**\n * @description URL validation options interface\n * @summary Defines options for URL validation, including allowed URL types\n * @interface URLValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns\n * @category Validation\n */\nexport interface URLValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Type validation options interface\n * @summary Defines options for type validation, specifying allowed types\n * @interface TypeValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Step validation options interface\n * @summary Defines options for step validation, specifying the step increment\n * @interface StepValidatorOptions\n * @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface StepValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.STEP]: number | string;\n  types?: string[];\n}\n\n/**\n * @description Pattern validation options interface\n * @summary Defines options for pattern validation using regular expressions\n * @interface PatternValidatorOptions\n * @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface PatternValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.PATTERN]?: RegExp | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum value validation options interface\n * @summary Defines options for minimum value validation\n * @interface MinValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum length validation options interface\n * @summary Defines options for minimum length validation\n * @interface MinLengthValidatorOptions\n * @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description Maximum value validation options interface\n * @summary Defines options for maximum value validation\n * @interface MaxValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Maximum length validation options interface\n * @summary Defines options for maximum length validation\n * @interface MaxLengthValidatorOptions\n * @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description List validation options interface\n * @summary Defines options for list validation\n * @interface ListValidatorOptions\n * @property {string[]} clazz - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface ListValidatorOptions extends ValidatorOptions {\n  clazz: string[];\n}\n\n/**\n * @description Date validation options interface\n * @summary Defines options for date validation\n * @interface DateValidatorOptions\n * @property {string} [ValidationKeys.FORMAT] - The expected date format pattern\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface DateValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.FORMAT]?: string;\n}\n\nexport interface EqualsValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/validation/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAa,8BAAqB","sourcesContent":["import { DecoratorMetadata } from \"@decaf-ts/reflection\";\nimport { Constructor } from \"../model\";\nimport { ValidationKeys, Validator } from \"./Validators\";\nimport { IRegistry } from \"../utils\";\n\n/**\n * @description Type definition for metadata used by validation decorators\n * @summary Defines the structure of metadata attached to properties by validation decorators.\n * This metadata is used during validation to determine validation rules and error messages.\n *\n * @property {any[]} [args] - Optional arguments for the validator\n * @property {string} message - Error message to display when validation fails\n * @property {string[]} [types] - Array of type names that the property can have\n * @property {boolean} async - Indicates whether the validator associated with the decorator performs asynchronous validation logic.\n * Use `true` when the validator returns a Promise, and `false` when the validation is synchronous.\n *\n * @typedef {Object} ValidationMetadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationMetadata = {\n  [indexer: string]: any;\n  args?: any[];\n  message: string;\n  types?: string[];\n  async: boolean;\n};\n\n/**\n * @description Type definition for property-level validation decorator configuration\n * @summary Defines the structure that associates a property with its validation decorators.\n * This type is used to track which decorators are applied to a specific property during validation.\n *\n * @property {string|symbol} prop - The property name or symbol that the decorators are applied to\n * @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property\n *\n * @typedef {Object} ValidationPropertyDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationPropertyDecoratorDefinition = {\n  prop: string | symbol;\n  decorators: ValidationDecoratorDefinition[];\n  async?: boolean;\n};\n\n/**\n * @description Type definition for individual validation decorator metadata\n * @summary Extends the base DecoratorMetadata type with validation-specific properties.\n * This type represents the metadata for a single validation decorator applied to a property.\n *\n * @property {ValidationElementDefinition} props - The validation element properties and configuration\n *\n * @typedef {Object} ValidationDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationDecoratorDefinition = DecoratorMetadata & {\n  props: ValidationElementDefinition;\n  async?: boolean;\n};\n\n/**\n * @summary Type for a validator element metadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationElementDefinition = {\n  [indexer: string]: any;\n\n  value?: string | number;\n  message: string;\n  description: string;\n  types?: string[];\n};\n\n/**\n * @summary Type for a model errors\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ModelErrors = Record<string, Record<string, string | undefined>>;\n\n/**\n * @summary Util type for {@link Validator} configuration\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorDefinition = {\n  validator: Constructor<Validator>;\n  validationKey: string;\n  save: boolean;\n};\n\n/**\n * @description Interface for a registry that manages validator instances\n * @summary Defines the contract for a registry that stores and retrieves validators.\n * The registry is responsible for maintaining a collection of validators and providing\n * access to them by key.\n *\n * @interface IValidatorRegistry\n * @template T Type of validator, must extend Validator\n * @extends IRegistry<T>\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {\n  /**\n   * @description Retrieves custom validation keys defined in the registry\n   * @summary Returns a mapping of custom validation keys to their corresponding standard keys.\n   * This allows for aliasing validation keys for specific use cases.\n   *\n   * @return {Record<string, string>} Object mapping custom keys to standard validation keys\n   */\n  getCustomKeys(): Record<string, string>;\n\n  /**\n   * @description Gets all registered validator keys\n   * @summary Returns an array of all validation keys that have registered validators.\n   *\n   * @return {string[]} Array of registered validator keys\n   */\n  getKeys(): string[];\n\n  /**\n   * @description Registers one or more validators with the registry\n   * @summary Adds validators to the registry, making them available for validation operations.\n   * Validators can be provided as instances or as validator definitions.\n   *\n   * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register\n   * @return {void}\n   */\n  register<T extends Validator>(\n    ...validator: (T | ValidatorDefinition)[]\n  ): void;\n\n  /**\n   * @description Retrieves a validator by its key\n   * @summary Looks up a validator in the registry using its validation key.\n   * Returns the validator if found, or undefined if no validator is registered for the key.\n   *\n   * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}\n   * @return {T|undefined} The registered validator or undefined if none matches the provided key\n   */\n  get<T extends Validator>(key: string): T | undefined;\n}\n\n/**\n * @description Base options type for all validators\n * @summary Defines the common properties available to all validators\n * @interface ValidatorOptions\n * @property {string} [message] - Custom error message to display when validation fails\n * @property {boolean} async - Indicates whether the validator associated with the decorator performs asynchronous validation logic.\n * Use `true` when the validator returns a Promise, and `false` when the validation is synchronous.\n * @category Validation\n */\nexport interface ValidatorOptions {\n  message?: string;\n  description?: string;\n  async?: boolean;\n}\n\n/**\n * @description URL validation options interface\n * @summary Defines options for URL validation, including allowed URL types\n * @interface URLValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns\n * @category Validation\n */\nexport interface URLValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Type validation options interface\n * @summary Defines options for type validation, specifying allowed types\n * @interface TypeValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Step validation options interface\n * @summary Defines options for step validation, specifying the step increment\n * @interface StepValidatorOptions\n * @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface StepValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.STEP]: number | string;\n  types?: string[];\n}\n\n/**\n * @description Pattern validation options interface\n * @summary Defines options for pattern validation using regular expressions\n * @interface PatternValidatorOptions\n * @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface PatternValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.PATTERN]?: RegExp | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum value validation options interface\n * @summary Defines options for minimum value validation\n * @interface MinValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum length validation options interface\n * @summary Defines options for minimum length validation\n * @interface MinLengthValidatorOptions\n * @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description Maximum value validation options interface\n * @summary Defines options for maximum value validation\n * @interface MaxValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Maximum length validation options interface\n * @summary Defines options for maximum length validation\n * @interface MaxLengthValidatorOptions\n * @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description List validation options interface\n * @summary Defines options for list validation\n * @interface ListValidatorOptions\n * @property {string[]} clazz - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface ListValidatorOptions extends ValidatorOptions {\n  clazz: string[];\n}\n\n/**\n * @description Unique validation options interface\n * @summary Defines options for unique validation\n * @interface UniqueValidatorOptions\n * @property {string[]} unique - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface UniqueValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.UNIQUE]: string[];\n}\n\n/**\n * @description Date validation options interface\n * @summary Defines options for date validation\n * @interface DateValidatorOptions\n * @property {string} [ValidationKeys.FORMAT] - The expected date format pattern\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface DateValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.FORMAT]?: string;\n}\n\nexport interface EqualsValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
package/lib/index.cjs CHANGED
@@ -32,5 +32,5 @@ __exportStar(require("./model/index.cjs"), exports);
32
32
  * @const VERSION
33
33
  * @memberOf module:decorator-validation
34
34
  */
35
- exports.VERSION = "1.7.6";
35
+ exports.VERSION = "1.7.8";
36
36
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7Ozs7O0dBTUc7QUFDSCx3REFBNEI7QUFDNUIsb0RBQXdCO0FBQ3hCLHlEQUE2QjtBQUM3QixvREFBd0I7QUFFeEI7Ozs7O0dBS0c7QUFDVSxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqIEBkZXNjcmlwdGlvbiBUeXBlU2NyaXB0IGRlY29yYXRvci1iYXNlZCB2YWxpZGF0aW9uIGxpYnJhcnlcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgY29tcHJlaGVuc2l2ZSB2YWxpZGF0aW9uIGZyYW1ld29yayB1c2luZyBUeXBlU2NyaXB0IGRlY29yYXRvcnMuXG4gKiBJdCBleHBvc2VzIHV0aWxpdHkgZnVuY3Rpb25zLCB2YWxpZGF0aW9uIGRlY29yYXRvcnMsIGFuZCBtb2RlbC1yZWxhdGVkIGZ1bmN0aW9uYWxpdHkgZm9yXG4gKiBpbXBsZW1lbnRpbmcgdHlwZS1zYWZlLCBkZWNsYXJhdGl2ZSB2YWxpZGF0aW9uIGluIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zLlxuICovXG5leHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDdXJyZW50IHZlcnNpb24gb2YgdGhlIHJlZmxlY3Rpb24gcGFja2FnZVxuICogQHN1bW1hcnkgU3RvcmVzIHRoZSBzZW1hbnRpYyB2ZXJzaW9uIG51bWJlciBvZiB0aGUgcGFja2FnZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
package/lib/index.d.ts CHANGED
@@ -15,4 +15,4 @@ export * from "./model";
15
15
  * @const VERSION
16
16
  * @memberOf module:decorator-validation
17
17
  */
18
- export declare const VERSION = "1.7.6";
18
+ export declare const VERSION = "1.7.8";