@decaf-ts/decorator-validation 1.7.13 → 1.7.15

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 (33) hide show
  1. package/dist/decorator-validation.cjs +69 -46
  2. package/dist/decorator-validation.esm.cjs +69 -46
  3. package/lib/esm/index.d.ts +1 -1
  4. package/lib/esm/index.js +1 -1
  5. package/lib/esm/model/Model.js +6 -4
  6. package/lib/esm/model/validation.js +5 -4
  7. package/lib/esm/validation/Validators/DiffValidator.js +2 -2
  8. package/lib/esm/validation/Validators/EqualsValidator.js +2 -2
  9. package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +2 -2
  10. package/lib/esm/validation/Validators/GreaterThanValidator.js +2 -2
  11. package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +2 -2
  12. package/lib/esm/validation/Validators/LessThanValidator.js +2 -2
  13. package/lib/esm/validation/Validators/TypeValidator.js +3 -3
  14. package/lib/esm/validation/decorators.d.ts +25 -13
  15. package/lib/esm/validation/decorators.js +51 -31
  16. package/lib/esm/validation/types.d.ts +11 -8
  17. package/lib/esm/validation/types.js +1 -1
  18. package/lib/index.cjs +1 -1
  19. package/lib/index.d.ts +1 -1
  20. package/lib/model/Model.cjs +6 -4
  21. package/lib/model/validation.cjs +5 -4
  22. package/lib/validation/Validators/DiffValidator.cjs +2 -2
  23. package/lib/validation/Validators/EqualsValidator.cjs +2 -2
  24. package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +2 -2
  25. package/lib/validation/Validators/GreaterThanValidator.cjs +2 -2
  26. package/lib/validation/Validators/LessThanOrEqualValidator.cjs +2 -2
  27. package/lib/validation/Validators/LessThanValidator.cjs +2 -2
  28. package/lib/validation/Validators/TypeValidator.cjs +3 -3
  29. package/lib/validation/decorators.cjs +51 -31
  30. package/lib/validation/decorators.d.ts +25 -13
  31. package/lib/validation/types.cjs +1 -1
  32. package/lib/validation/types.d.ts +11 -8
  33. package/package.json +1 -1
@@ -441,41 +441,49 @@ export function set(clazz, message = DEFAULT_ERROR_MESSAGES.LIST) {
441
441
  * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.
442
442
  *
443
443
  * @param {string} propertyToCompare - The name of the property to compare equality against.
444
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.
444
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
445
+ * @param {string} [options.label] - The label text displayed in the error message.
446
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to be returned if validation fails.
445
447
  *
446
448
  * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.
447
449
  *
448
450
  * @function eq
449
451
  * @category Property Decorators
450
452
  */
451
- export function eq(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.EQUALS) {
452
- const options = {
453
- message: message,
453
+ export function eq(propertyToCompare, options
454
+ // message: string = DEFAULT_ERROR_MESSAGES.EQUALS
455
+ ) {
456
+ const equalsOptions = {
457
+ label: options?.label || propertyToCompare,
458
+ message: options?.message || DEFAULT_ERROR_MESSAGES.EQUALS,
454
459
  [ValidationKeys.EQUALS]: propertyToCompare,
455
460
  description: `defines attribute as equal to ${propertyToCompare}`,
456
461
  };
457
- return validationMetadata(eq, Validation.key(ValidationKeys.EQUALS), { ...options, async: false });
462
+ return validationMetadata(eq, Validation.key(ValidationKeys.EQUALS), { ...equalsOptions, async: false });
458
463
  }
459
464
  /**
460
465
  * @summary Declares that the decorated property must be different from another specified property.
461
466
  * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.
462
467
  *
463
468
  * @param {string} propertyToCompare - The name of the property to compare difference against.
464
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.
469
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
470
+ * @param {string} [options.label] - The label text displayed in the error message.
471
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to be returned if validation fails.
465
472
  *
466
473
  * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.
467
474
  *
468
475
  * @function diff
469
476
  * @category Property Decorators
470
477
  */
471
- export function diff(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.DIFF) {
472
- const options = {
473
- message: message,
478
+ export function diff(propertyToCompare, options) {
479
+ const diffOptions = {
480
+ label: options?.label || propertyToCompare,
481
+ message: options?.message || DEFAULT_ERROR_MESSAGES.DIFF,
474
482
  [ValidationKeys.DIFF]: propertyToCompare,
475
483
  description: `defines attribute as different to ${propertyToCompare}`,
476
484
  };
477
485
  return validationMetadata(diff, Validation.key(ValidationKeys.DIFF), {
478
- ...options,
486
+ ...diffOptions,
479
487
  async: false,
480
488
  });
481
489
  }
@@ -484,79 +492,91 @@ export function diff(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.DIFF) {
484
492
  * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.
485
493
  *
486
494
  * @param {string} propertyToCompare - The name of the property to compare against.
487
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.
495
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
496
+ * @param {string} [options.label] - The label text displayed in the error message.
497
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to be returned if validation fails.
488
498
  *
489
499
  * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.
490
500
  *
491
501
  * @function lt
492
502
  * @category Property Decorators
493
503
  */
494
- export function lt(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.LESS_THAN) {
495
- const options = {
496
- message: message,
504
+ export function lt(propertyToCompare, options) {
505
+ const ltOptions = {
506
+ label: options?.label || propertyToCompare,
507
+ message: options?.message || DEFAULT_ERROR_MESSAGES.LESS_THAN,
497
508
  [ValidationKeys.LESS_THAN]: propertyToCompare,
498
509
  description: `defines attribute as less than to ${propertyToCompare}`,
499
510
  };
500
- return validationMetadata(lt, Validation.key(ValidationKeys.LESS_THAN), { ...options, async: false });
511
+ return validationMetadata(lt, Validation.key(ValidationKeys.LESS_THAN), { ...ltOptions, async: false });
501
512
  }
502
513
  /**
503
514
  * @summary Declares that the decorated property must be equal or less than another specified property.
504
515
  * @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.
505
516
  *
506
517
  * @param {string} propertyToCompare - The name of the property to compare against.
507
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.
518
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
519
+ * @param {string} [options.label] - The label text displayed in the error message.
520
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to be returned if validation fails.
508
521
  *
509
522
  * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.
510
523
  *
511
524
  * @function lte
512
525
  * @category Property Decorators
513
526
  */
514
- export function lte(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL) {
515
- const options = {
516
- message: message,
527
+ export function lte(propertyToCompare, options) {
528
+ const lteOptions = {
529
+ label: options?.label || propertyToCompare,
530
+ message: options?.message || DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL,
517
531
  [ValidationKeys.LESS_THAN_OR_EQUAL]: propertyToCompare,
518
532
  description: `defines attribute as less or equal to ${propertyToCompare}`,
519
533
  };
520
- return validationMetadata(lte, Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL), { ...options, async: false });
534
+ return validationMetadata(lte, Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL), { ...lteOptions, async: false });
521
535
  }
522
536
  /**
523
537
  * @summary Declares that the decorated property must be greater than another specified property.
524
538
  * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.
525
539
  *
526
540
  * @param {string} propertyToCompare - The name of the property to compare against.
527
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.
541
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
542
+ * @param {string} [options.label] - The label text displayed in the error message.
543
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to be returned if validation fails.
528
544
  *
529
545
  * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.
530
546
  *
531
547
  * @function gt
532
548
  * @category Property Decorators
533
549
  */
534
- export function gt(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.GREATER_THAN) {
535
- const options = {
536
- message: message,
550
+ export function gt(propertyToCompare, options) {
551
+ const gtOptions = {
552
+ label: options?.label || propertyToCompare,
553
+ message: options?.message || DEFAULT_ERROR_MESSAGES.GREATER_THAN,
537
554
  [ValidationKeys.GREATER_THAN]: propertyToCompare,
538
555
  description: `defines attribute as greater than ${propertyToCompare}`,
539
556
  };
540
- return validationMetadata(gt, Validation.key(ValidationKeys.GREATER_THAN), { ...options, async: false });
557
+ return validationMetadata(gt, Validation.key(ValidationKeys.GREATER_THAN), { ...gtOptions, async: false });
541
558
  }
542
559
  /**
543
560
  * @summary Declares that the decorated property must be equal or greater than another specified property.
544
561
  * @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.
545
562
  *
546
563
  * @param {string} propertyToCompare - The name of the property to compare against.
547
- * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.
564
+ * @param {ComparisonValidatorOptions} options - Options for the validator.
565
+ * @param {string} [options.label] - The label text displayed in the error message.
566
+ * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to be returned if validation fails.
548
567
  *
549
568
  * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.
550
569
  *
551
570
  * @function gte
552
571
  * @category Property Decorators
553
572
  */
554
- export function gte(propertyToCompare, message = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL) {
555
- const options = {
556
- message: message,
573
+ export function gte(propertyToCompare, options) {
574
+ const gteOptions = {
575
+ label: options?.label || propertyToCompare,
576
+ message: options?.message || DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL,
557
577
  [ValidationKeys.GREATER_THAN_OR_EQUAL]: propertyToCompare,
558
578
  description: `defines attribute as greater or equal to ${propertyToCompare}`,
559
579
  };
560
- return validationMetadata(gte, Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL), { ...options, async: false });
580
+ return validationMetadata(gte, Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL), { ...gteOptions, async: false });
561
581
  }
562
- //# 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({\n      decorator: validationMetadata<ValidatorOptions>,\n      args: [required, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  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({\n      decorator: validationMetadata<MinValidatorOptions>,\n      args: [min, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  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({\n      decorator: validationMetadata<MaxValidatorOptions>,\n      args: [max, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  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({\n      decorator: validationMetadata<StepValidatorOptions>,\n      args: [step, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  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({\n      decorator: validationMetadata<MinLengthValidatorOptions>,\n      args: [minlength, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  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({\n      decorator: validationMetadata<MaxLengthValidatorOptions>,\n      args: [maxlength, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [pattern, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [email, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [url, key, meta],\n    })\n    .apply();\n}\n\nexport interface TypeMetadata extends ValidatorOptions {\n  customTypes: (string | (() => string))[] | 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))[] | 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({\n      decorator: validationMetadata<TypeMetadata>,\n      args: [type, key, meta],\n    })\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  function dateDec(target: Record<string, any>, propertyKey?: any): any {\n    const values = new WeakMap();\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        return values.get(this);\n      },\n    });\n    return validationMetadata(date, key, meta)(target, propertyKey);\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({\n      decorator: validationMetadata,\n      args: [password, key, meta],\n    })\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:\n    | Constructor<any>\n    | (() => Constructor<any>)\n    | (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)\n      ? clazz.map((c) => (c.name ? c.name : c))\n      : [clazz.name ? clazz.name : clazz]) as (\n      | string\n      | (() => Constructor<any>)\n    )[],\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({\n      decorator: validationMetadata,\n      args: [list, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @category Property Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: EqualsValidatorOptions = {\n    message: message,\n    [ValidationKeys.EQUALS]: propertyToCompare,\n    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"]}
582
+ //# 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  ComparisonValidatorOptions,\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({\n      decorator: validationMetadata<ValidatorOptions>,\n      args: [required, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Property Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  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({\n      decorator: validationMetadata<MinValidatorOptions>,\n      args: [min, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Property Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  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({\n      decorator: validationMetadata<MaxValidatorOptions>,\n      args: [max, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Property Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  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({\n      decorator: validationMetadata<StepValidatorOptions>,\n      args: [step, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Property Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  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({\n      decorator: validationMetadata<MinLengthValidatorOptions>,\n      args: [minlength, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Property Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  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({\n      decorator: validationMetadata<MaxLengthValidatorOptions>,\n      args: [maxlength, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Property Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [pattern, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Property Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [email, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Property Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  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({\n      decorator: validationMetadata<PatternValidatorOptions>,\n      args: [url, key, meta],\n    })\n    .apply();\n}\n\nexport interface TypeMetadata extends ValidatorOptions {\n  customTypes: (string | (() => string))[] | 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))[] | 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({\n      decorator: validationMetadata<TypeMetadata>,\n      args: [type, key, meta],\n    })\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  function dateDec(target: Record<string, any>, propertyKey?: any): any {\n    const values = new WeakMap();\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        return values.get(this);\n      },\n    });\n    return validationMetadata(date, key, meta)(target, propertyKey);\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({\n      decorator: validationMetadata,\n      args: [password, key, meta],\n    })\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:\n    | Constructor<any>\n    | (() => Constructor<any>)\n    | (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)\n      ? clazz.map((c) => (c.name ? c.name : c))\n      : [clazz.name ? clazz.name : clazz]) as (\n      | string\n      | (() => Constructor<any>)\n    )[],\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({\n      decorator: validationMetadata,\n      args: [list, key, meta],\n    })\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Property Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n  // message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const equalsOptions: EqualsValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.EQUALS,\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    { ...equalsOptions, 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 {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n) {\n  const diffOptions: DiffValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.DIFF,\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      ...diffOptions,\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 {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n) {\n  const ltOptions: LessThanValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.LESS_THAN,\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    { ...ltOptions, 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 {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n) {\n  const lteOptions: LessThanOrEqualValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL,\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    { ...lteOptions, 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 {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n) {\n  const gtOptions: GreaterThanValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.GREATER_THAN,\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    { ...gtOptions, 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 {ComparisonValidatorOptions} options - Options for the validator.\n * @param {string} [options.label] - The label text displayed in the error message.\n * @param {string} [options.message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to be returned 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  options: Omit<ComparisonValidatorOptions, \"async\" | \"description\">\n) {\n  const gteOptions: GreaterThanOrEqualValidatorOptions = {\n    label: options?.label || propertyToCompare,\n    message: options?.message || DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL,\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    { ...gteOptions, async: false } as ValidationMetadata\n  );\n}\n"]}
@@ -161,12 +161,12 @@ export interface URLValidatorOptions extends ValidatorOptions {
161
161
  * @description Type validation options interface
162
162
  * @summary Defines options for type validation, specifying allowed types
163
163
  * @interface TypeValidatorOptions
164
- * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types
164
+ * @property {(string|string[]|{ name: string })} type - Specifies the allowed data types
165
165
  * @memberOf module:decorator-validation
166
166
  * @category Validation
167
167
  */
168
168
  export interface TypeValidatorOptions extends ValidatorOptions {
169
- types: string | string[] | {
169
+ type: string | string[] | {
170
170
  name: string;
171
171
  };
172
172
  customTypes?: (string | (() => string))[];
@@ -276,21 +276,24 @@ export interface UniqueValidatorOptions extends ValidatorOptions {
276
276
  export interface DateValidatorOptions extends ValidatorOptions {
277
277
  [ValidationKeys.FORMAT]?: string;
278
278
  }
279
- export interface EqualsValidatorOptions extends ValidatorOptions {
279
+ export interface ComparisonValidatorOptions extends ValidatorOptions {
280
+ label?: string;
281
+ }
282
+ export interface EqualsValidatorOptions extends ComparisonValidatorOptions {
280
283
  [ValidationKeys.EQUALS]: string;
281
284
  }
282
- export interface DiffValidatorOptions extends ValidatorOptions {
285
+ export interface DiffValidatorOptions extends ComparisonValidatorOptions {
283
286
  [ValidationKeys.DIFF]: string;
284
287
  }
285
- export interface LessThanValidatorOptions extends ValidatorOptions {
288
+ export interface LessThanValidatorOptions extends ComparisonValidatorOptions {
286
289
  [ValidationKeys.LESS_THAN]: string;
287
290
  }
288
- export interface LessThanOrEqualValidatorOptions extends ValidatorOptions {
291
+ export interface LessThanOrEqualValidatorOptions extends ComparisonValidatorOptions {
289
292
  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;
290
293
  }
291
- export interface GreaterThanValidatorOptions extends ValidatorOptions {
294
+ export interface GreaterThanValidatorOptions extends ComparisonValidatorOptions {
292
295
  [ValidationKeys.GREATER_THAN]: string;
293
296
  }
294
- export interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {
297
+ export interface GreaterThanOrEqualValidatorOptions extends ComparisonValidatorOptions {
295
298
  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;
296
299
  }
@@ -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 * @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  customTypes?: (string | (() => 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 | (() => Constructor<any>))[];\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"]}
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 })} type - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  type: string | string[] | { name: string };\n  customTypes?: (string | (() => 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 | (() => Constructor<any>))[];\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 ComparisonValidatorOptions extends ValidatorOptions {\n  label?: string;\n}\n\nexport interface EqualsValidatorOptions extends ComparisonValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ComparisonValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ComparisonValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions\n  extends ComparisonValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions\n  extends ComparisonValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions\n  extends ComparisonValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
package/lib/index.cjs CHANGED
@@ -33,5 +33,5 @@ __exportStar(require("./model/index.cjs"), exports);
33
33
  * @const VERSION
34
34
  * @memberOf module:decorator-validation
35
35
  */
36
- exports.VERSION = "1.7.13";
36
+ exports.VERSION = "1.7.15";
37
37
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7Ozs7O0dBTUc7QUFDSCx3REFBNEI7QUFDNUIsb0RBQXdCO0FBQ3hCLG9EQUF3QjtBQUN4Qix5REFBNkI7QUFDN0Isb0RBQXdCO0FBRXhCOzs7OztHQUtHO0FBQ1UsUUFBQSxPQUFPLEdBQUcsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIGRlY29yYXRvci12YWxpZGF0aW9uXG4gKiBAZGVzY3JpcHRpb24gVHlwZVNjcmlwdCBkZWNvcmF0b3ItYmFzZWQgdmFsaWRhdGlvbiBsaWJyYXJ5XG4gKiBAc3VtbWFyeSBUaGlzIG1vZHVsZSBwcm92aWRlcyBhIGNvbXByZWhlbnNpdmUgdmFsaWRhdGlvbiBmcmFtZXdvcmsgdXNpbmcgVHlwZVNjcmlwdCBkZWNvcmF0b3JzLlxuICogSXQgZXhwb3NlcyB1dGlsaXR5IGZ1bmN0aW9ucywgdmFsaWRhdGlvbiBkZWNvcmF0b3JzLCBhbmQgbW9kZWwtcmVsYXRlZCBmdW5jdGlvbmFsaXR5IGZvclxuICogaW1wbGVtZW50aW5nIHR5cGUtc2FmZSwgZGVjbGFyYXRpdmUgdmFsaWRhdGlvbiBpbiBUeXBlU2NyaXB0IGFwcGxpY2F0aW9ucy5cbiAqL1xuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZhbGlkYXRpb25cIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgcmVmbGVjdGlvbiBwYWNrYWdlXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIHNlbWFudGljIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBwYWNrYWdlXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
package/lib/index.d.ts CHANGED
@@ -16,4 +16,4 @@ export * from "./model";
16
16
  * @const VERSION
17
17
  * @memberOf module:decorator-validation
18
18
  */
19
- export declare const VERSION = "1.7.13";
19
+ export declare const VERSION = "1.7.15";