@decaf-ts/decorator-validation 1.7.16 → 1.7.18

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.
@@ -9,7 +9,7 @@ const construction_1 = require("./construction.cjs");
9
9
  const constants_1 = require("./../utils/constants.cjs");
10
10
  const Model_1 = require("./Model.cjs");
11
11
  const reflection_1 = require("@decaf-ts/reflection");
12
- const utils_1 = require("./../utils/index.cjs");
12
+ const decoration_1 = require("@decaf-ts/decoration");
13
13
  function modelBaseDecorator(original) {
14
14
  // the new constructor behaviour
15
15
  const newConstructor = function (...args) {
@@ -50,6 +50,7 @@ function modelBaseDecorator(original) {
50
50
  configurable: false,
51
51
  value: original,
52
52
  });
53
+ decoration_1.Metadata.set(newConstructor, decoration_1.DecorationKeys.CONSTRUCTOR, original);
53
54
  //
54
55
  // // anchors the new constructor for future reference
55
56
  // Object.defineProperty(original, ModelKeys.ANCHOR, {
@@ -76,7 +77,7 @@ function modelBaseDecorator(original) {
76
77
  */
77
78
  function model() {
78
79
  const key = Model_1.Model.key(constants_1.ModelKeys.MODEL);
79
- return utils_1.Decoration.for(key).define(modelBaseDecorator).apply();
80
+ return decoration_1.Decoration.for(key).define(modelBaseDecorator).apply();
80
81
  }
81
82
  /**
82
83
  * @summary Defines the hashing algorithm to use on the model
@@ -125,4 +126,4 @@ function serializedBy(serializer, ...args) {
125
126
  function description(description) {
126
127
  return (0, reflection_1.metadata)(Model_1.Model.key(constants_1.ModelKeys.DESCRIPTION), description);
127
128
  }
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { bindModelPrototype, construct } from \"./construction\";\nimport { ModelKeys } from \"../utils/constants\";\nimport { Model } from \"./Model\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Decoration } from \"../utils\";\n\nexport function modelBaseDecorator(original: any) {\n  // the new constructor behaviour\n  const newConstructor: any = function (...args: any[]) {\n    const instance: ReturnType<typeof original> = construct(original, ...args);\n    bindModelPrototype(instance);\n\n    // re-apply original constructor\n    Object.defineProperty(instance, \"constructor\", {\n      writable: false,\n      enumerable: false,\n      configurable: false,\n      value: original,\n    });\n\n    // run a builder function if defined with the first argument (The ModelArg)\n    const builder = Model.getBuilder();\n    if (builder) builder(instance, args.length ? args[0] : undefined);\n\n    metadata(Model.key(ModelKeys.MODEL), original.name)(instance.constructor);\n\n    return instance;\n  };\n\n  // copy prototype so instanceof operator still works\n  newConstructor.prototype = original.prototype;\n\n  metadata(Model.key(ModelKeys.MODEL), original.name)(original);\n\n  Reflect.getMetadataKeys(original).forEach((key) => {\n    Reflect.defineMetadata(\n      key,\n      Reflect.getMetadata(key, original),\n      newConstructor\n    );\n  });\n  // Sets the proper constructor name for type verification\n  Object.defineProperty(newConstructor, \"name\", {\n    writable: false,\n    enumerable: true,\n    configurable: false,\n    value: original.prototype.constructor.name,\n  });\n  //\n  // anchors the original constructor for future reference\n  Object.defineProperty(newConstructor, ModelKeys.ANCHOR, {\n    writable: false,\n    enumerable: false,\n    configurable: false,\n    value: original,\n  });\n  //\n  // // anchors the new constructor for future reference\n  // Object.defineProperty(original, ModelKeys.ANCHOR, {\n  //   writable: false,\n  //   enumerable: true,\n  //   configurable: false,\n  //   value: newConstructor,\n  // });\n\n  Model.register(newConstructor, original.name);\n\n  // return new constructor (will override original)\n  return newConstructor;\n}\n\n/**\n * @summary Defines a class as a Model class\n * @description\n *\n * - Registers the class under the model registry so it can be easily rebuilt;\n * - Overrides the class constructor;\n * - Runs the global {@link ModelBuilderFunction} if defined;\n *\n * @function model\n *\n * @category Class Decorators\n */\nexport function model() {\n  const key = Model.key(ModelKeys.MODEL);\n  return Decoration.for(key).define(modelBaseDecorator).apply();\n}\n\n/**\n * @summary Defines the hashing algorithm to use on the model\n * @description\n *\n * - Registers the class under the model registry so it can be easily rebuilt;\n * - Overrides the class constructor;\n * - Runs the global {@link ModelBuilderFunction} if defined;\n *\n * @param {string} algorithm the algorithm to use\n *\n * @function hashedBy\n *\n * @category Class Decorators\n */\nexport function hashedBy(algorithm: string, ...args: any[]) {\n  return metadata(Model.key(ModelKeys.HASHING), {\n    algorithm: algorithm,\n    args: args,\n  });\n}\n\n/**\n * @summary Defines the serialization algorithm to use on the model\n *\n * @param {string} serializer the algorithm to use\n *\n * @function serializedBy\n *\n * @category Class Decorators\n */\nexport function serializedBy(serializer: string, ...args: any[]) {\n  return metadata(Model.key(ModelKeys.SERIALIZATION), {\n    serializer: serializer,\n    args: args,\n  });\n}\n\n/**\n * @summary Applies descriptive metadata to a class, property or method\n *\n * @param {string} description the description to apply\n *\n * @function description\n *\n * @category Decorators\n */\nexport function description(description: string) {\n  return metadata(Model.key(ModelKeys.DESCRIPTION), description);\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":";;AAMA,gDAiEC;AAcD,sBAGC;AAgBD,4BAKC;AAWD,oCAKC;AAWD,kCAEC;AA1ID,qDAA+D;AAC/D,wDAA+C;AAC/C,uCAAgC;AAChC,qDAAgD;AAChD,qDAA4E;AAE5E,SAAgB,kBAAkB,CAAC,QAAa;IAC9C,gCAAgC;IAChC,MAAM,cAAc,GAAQ,UAAU,GAAG,IAAW;QAClD,MAAM,QAAQ,GAAgC,IAAA,wBAAS,EAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,CAAC;QAC3E,IAAA,iCAAkB,EAAC,QAAQ,CAAC,CAAC;QAE7B,gCAAgC;QAChC,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,aAAa,EAAE;YAC7C,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,KAAK;YACnB,KAAK,EAAE,QAAQ;SAChB,CAAC,CAAC;QAEH,2EAA2E;QAC3E,MAAM,OAAO,GAAG,aAAK,CAAC,UAAU,EAAE,CAAC;QACnC,IAAI,OAAO;YAAE,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QAElE,IAAA,qBAAQ,EAAC,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAE1E,OAAO,QAAQ,CAAC;IAClB,CAAC,CAAC;IAEF,oDAAoD;IACpD,cAAc,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;IAE9C,IAAA,qBAAQ,EAAC,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;IAE9D,OAAO,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;QAChD,OAAO,CAAC,cAAc,CACpB,GAAG,EACH,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,QAAQ,CAAC,EAClC,cAAc,CACf,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,yDAAyD;IACzD,MAAM,CAAC,cAAc,CAAC,cAAc,EAAE,MAAM,EAAE;QAC5C,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,IAAI;QAChB,YAAY,EAAE,KAAK;QACnB,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI;KAC3C,CAAC,CAAC;IACH,EAAE;IACF,wDAAwD;IACxD,MAAM,CAAC,cAAc,CAAC,cAAc,EAAE,qBAAS,CAAC,MAAM,EAAE;QACtD,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,KAAK;QACjB,YAAY,EAAE,KAAK;QACnB,KAAK,EAAE,QAAQ;KAChB,CAAC,CAAC;IAEH,qBAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,2BAAc,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IACnE,EAAE;IACF,sDAAsD;IACtD,sDAAsD;IACtD,qBAAqB;IACrB,sBAAsB;IACtB,yBAAyB;IACzB,2BAA2B;IAC3B,MAAM;IAEN,aAAK,CAAC,QAAQ,CAAC,cAAc,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;IAE9C,kDAAkD;IAClD,OAAO,cAAc,CAAC;AACxB,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,KAAK;IACnB,MAAM,GAAG,GAAG,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,KAAK,CAAC,CAAC;IACvC,OAAO,uBAAU,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,KAAK,EAAE,CAAC;AAChE,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,SAAgB,QAAQ,CAAC,SAAiB,EAAE,GAAG,IAAW;IACxD,OAAO,IAAA,qBAAQ,EAAC,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,OAAO,CAAC,EAAE;QAC5C,SAAS,EAAE,SAAS;QACpB,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,YAAY,CAAC,UAAkB,EAAE,GAAG,IAAW;IAC7D,OAAO,IAAA,qBAAQ,EAAC,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,aAAa,CAAC,EAAE;QAClD,UAAU,EAAE,UAAU;QACtB,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;GAQG;AACH,SAAgB,WAAW,CAAC,WAAmB;IAC7C,OAAO,IAAA,qBAAQ,EAAC,aAAK,CAAC,GAAG,CAAC,qBAAS,CAAC,WAAW,CAAC,EAAE,WAAW,CAAC,CAAC;AACjE,CAAC","sourcesContent":["import { bindModelPrototype, construct } from \"./construction\";\nimport { ModelKeys } from \"../utils/constants\";\nimport { Model } from \"./Model\";\nimport { metadata } from \"@decaf-ts/reflection\";\nimport { Decoration, DecorationKeys, Metadata } from \"@decaf-ts/decoration\";\n\nexport function modelBaseDecorator(original: any) {\n  // the new constructor behaviour\n  const newConstructor: any = function (...args: any[]) {\n    const instance: ReturnType<typeof original> = construct(original, ...args);\n    bindModelPrototype(instance);\n\n    // re-apply original constructor\n    Object.defineProperty(instance, \"constructor\", {\n      writable: false,\n      enumerable: false,\n      configurable: false,\n      value: original,\n    });\n\n    // run a builder function if defined with the first argument (The ModelArg)\n    const builder = Model.getBuilder();\n    if (builder) builder(instance, args.length ? args[0] : undefined);\n\n    metadata(Model.key(ModelKeys.MODEL), original.name)(instance.constructor);\n\n    return instance;\n  };\n\n  // copy prototype so instanceof operator still works\n  newConstructor.prototype = original.prototype;\n\n  metadata(Model.key(ModelKeys.MODEL), original.name)(original);\n\n  Reflect.getMetadataKeys(original).forEach((key) => {\n    Reflect.defineMetadata(\n      key,\n      Reflect.getMetadata(key, original),\n      newConstructor\n    );\n  });\n  // Sets the proper constructor name for type verification\n  Object.defineProperty(newConstructor, \"name\", {\n    writable: false,\n    enumerable: true,\n    configurable: false,\n    value: original.prototype.constructor.name,\n  });\n  //\n  // anchors the original constructor for future reference\n  Object.defineProperty(newConstructor, ModelKeys.ANCHOR, {\n    writable: false,\n    enumerable: false,\n    configurable: false,\n    value: original,\n  });\n\n  Metadata.set(newConstructor, DecorationKeys.CONSTRUCTOR, original);\n  //\n  // // anchors the new constructor for future reference\n  // Object.defineProperty(original, ModelKeys.ANCHOR, {\n  //   writable: false,\n  //   enumerable: true,\n  //   configurable: false,\n  //   value: newConstructor,\n  // });\n\n  Model.register(newConstructor, original.name);\n\n  // return new constructor (will override original)\n  return newConstructor;\n}\n\n/**\n * @summary Defines a class as a Model class\n * @description\n *\n * - Registers the class under the model registry so it can be easily rebuilt;\n * - Overrides the class constructor;\n * - Runs the global {@link ModelBuilderFunction} if defined;\n *\n * @function model\n *\n * @category Class Decorators\n */\nexport function model() {\n  const key = Model.key(ModelKeys.MODEL);\n  return Decoration.for(key).define(modelBaseDecorator).apply();\n}\n\n/**\n * @summary Defines the hashing algorithm to use on the model\n * @description\n *\n * - Registers the class under the model registry so it can be easily rebuilt;\n * - Overrides the class constructor;\n * - Runs the global {@link ModelBuilderFunction} if defined;\n *\n * @param {string} algorithm the algorithm to use\n *\n * @function hashedBy\n *\n * @category Class Decorators\n */\nexport function hashedBy(algorithm: string, ...args: any[]) {\n  return metadata(Model.key(ModelKeys.HASHING), {\n    algorithm: algorithm,\n    args: args,\n  });\n}\n\n/**\n * @summary Defines the serialization algorithm to use on the model\n *\n * @param {string} serializer the algorithm to use\n *\n * @function serializedBy\n *\n * @category Class Decorators\n */\nexport function serializedBy(serializer: string, ...args: any[]) {\n  return metadata(Model.key(ModelKeys.SERIALIZATION), {\n    serializer: serializer,\n    args: args,\n  });\n}\n\n/**\n * @summary Applies descriptive metadata to a class, property or method\n *\n * @param {string} description the description to apply\n *\n * @function description\n *\n * @category Decorators\n */\nexport function description(description: string) {\n  return metadata(Model.key(ModelKeys.DESCRIPTION), description);\n}\n"]}
@@ -18,8 +18,8 @@ exports.DefaultFlavour = exports.ModelKeys = void 0;
18
18
  * @property {string} HASHING - Key for storing hashing configuration
19
19
  * @property {string} SERIALIZATION - Key for storing serialization configuration
20
20
  *
21
- * @readonly
22
21
  * @enum {string}
22
+ * @readonly
23
23
  * @memberOf module:decorator-validation
24
24
  * @category Model
25
25
  */
@@ -47,4 +47,4 @@ var ModelKeys;
47
47
  * @category Model
48
48
  */
49
49
  exports.DefaultFlavour = "decaf";
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUJHO0FBQ0gsSUFBWSxTQVlYO0FBWkQsV0FBWSxTQUFTO0lBQ25CLHFDQUF3QixDQUFBO0lBQ3hCLCtDQUFrQyxDQUFBO0lBQ2xDLGlDQUFvQixDQUFBO0lBQ3BCLHlDQUE0QixDQUFBO0lBQzVCLHlDQUE0QixDQUFBO0lBQzVCLDRCQUFlLENBQUE7SUFDZiwrQkFBa0IsQ0FBQTtJQUNsQiw0Q0FBK0IsQ0FBQTtJQUMvQix1Q0FBMEIsQ0FBQTtJQUMxQixnQ0FBbUIsQ0FBQTtJQUNuQiw0Q0FBK0IsQ0FBQTtBQUNqQyxDQUFDLEVBWlcsU0FBUyx5QkFBVCxTQUFTLFFBWXBCO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDVSxRQUFBLGNBQWMsR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBFbnVtIGNvbnRhaW5pbmcgbWV0YWRhdGEga2V5cyB1c2VkIGZvciByZWZsZWN0aW9uIGluIHRoZSBtb2RlbCBzeXN0ZW1cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIHZhcmlvdXMgTW9kZWwga2V5cyB1c2VkIGZvciByZWZsZWN0aW9uIGFuZCBtZXRhZGF0YSBzdG9yYWdlLlxuICogVGhlc2Uga2V5cyBhcmUgdXNlZCB0aHJvdWdob3V0IHRoZSBsaWJyYXJ5IHRvIHN0b3JlIGFuZCByZXRyaWV2ZSBtZXRhZGF0YSBhYm91dCBtb2RlbHMsXG4gKiB0aGVpciBwcm9wZXJ0aWVzLCBhbmQgdGhlaXIgYmVoYXZpb3IuXG4gKlxuICogQHByb3BlcnR5IHtzdHJpbmd9IFJFRkxFQ1QgLSBQcmVmaXggdG8gYWxsIG90aGVyIGtleXMsIHVzZWQgYXMgYSBuYW1lc3BhY2VcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBUWVBFIC0gS2V5IGZvciBzdG9yaW5nIGRlc2lnbiB0eXBlIGluZm9ybWF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUEFSQU1TIC0gS2V5IGZvciBzdG9yaW5nIG1ldGhvZCBwYXJhbWV0ZXIgdHlwZXNcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBSRVRVUk4gLSBLZXkgZm9yIHN0b3JpbmcgbWV0aG9kIHJldHVybiB0eXBlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gTU9ERUwgLSBLZXkgZm9yIGlkZW50aWZ5aW5nIG1vZGVsIG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gQU5DSE9SIC0gQW5jaG9yIGtleSB0aGF0IHNlcnZlcyBhcyBhIGdob3N0IHByb3BlcnR5IGluIHRoZSBtb2RlbFxuICogQHByb3BlcnR5IHtzdHJpbmd9IENPTlNUUlVDVElPTiAtIEtleSBmb3Igc3RvcmluZyBjb25zdHJ1Y3Rpb24gaW5mb3JtYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBBVFRSSUJVVEUgLSBLZXkgZm9yIHN0b3JpbmcgYXR0cmlidXRlIG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gSEFTSElORyAtIEtleSBmb3Igc3RvcmluZyBoYXNoaW5nIGNvbmZpZ3VyYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBTRVJJQUxJWkFUSU9OIC0gS2V5IGZvciBzdG9yaW5nIHNlcmlhbGl6YXRpb24gY29uZmlndXJhdGlvblxuICpcbiAqIEByZWFkb25seVxuICogQGVudW0ge3N0cmluZ31cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqIEBjYXRlZ29yeSBNb2RlbFxuICovXG5leHBvcnQgZW51bSBNb2RlbEtleXMge1xuICBSRUZMRUNUID0gXCJkZWNhZi5tb2RlbC5cIixcbiAgREVTQ1JJUFRJT04gPSBcImRlY2FmLmRlc2NyaXB0aW9uLlwiLFxuICBUWVBFID0gXCJkZXNpZ246dHlwZVwiLFxuICBQQVJBTVMgPSBcImRlc2lnbjpwYXJhbXR5cGVzXCIsXG4gIFJFVFVSTiA9IFwiZGVzaWduOnJldHVybnR5cGVcIixcbiAgTU9ERUwgPSBcIm1vZGVsXCIsXG4gIEFOQ0hPUiA9IFwiX19tb2RlbFwiLFxuICBDT05TVFJVQ1RJT04gPSBcImNvbnN0cnVjdGVkLWJ5XCIsXG4gIEFUVFJJQlVURSA9IFwiX19hdHRyaWJ1dGVzXCIsXG4gIEhBU0hJTkcgPSBcImhhc2hpbmdcIixcbiAgU0VSSUFMSVpBVElPTiA9IFwic2VyaWFsaXphdGlvblwiLFxufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGZsYXZvdXIgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciBzeXN0ZW1cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGRlZmF1bHQgZmxhdm91ciB1c2VkIGJ5IHRoZSBEZWNvcmF0aW9uIGNsYXNzIHdoZW4gbm8gc3BlY2lmaWMgZmxhdm91ciBpcyBwcm92aWRlZC5cbiAqIFRoaXMgY29uc3RhbnQgaXMgdXNlZCB0aHJvdWdob3V0IHRoZSBsaWJyYXJ5IGFzIHRoZSBmYWxsYmFjayBmbGF2b3VyIGZvciBkZWNvcmF0b3JzLlxuICpcbiAqIEBjb25zdCB7c3RyaW5nfVxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICogQGNhdGVnb3J5IE1vZGVsXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0Rmxhdm91ciA9IFwiZGVjYWZcIjtcbiJdfQ==
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUJHO0FBQ0gsSUFBWSxTQVlYO0FBWkQsV0FBWSxTQUFTO0lBQ25CLHFDQUF3QixDQUFBO0lBQ3hCLCtDQUFrQyxDQUFBO0lBQ2xDLGlDQUFvQixDQUFBO0lBQ3BCLHlDQUE0QixDQUFBO0lBQzVCLHlDQUE0QixDQUFBO0lBQzVCLDRCQUFlLENBQUE7SUFDZiwrQkFBa0IsQ0FBQTtJQUNsQiw0Q0FBK0IsQ0FBQTtJQUMvQix1Q0FBMEIsQ0FBQTtJQUMxQixnQ0FBbUIsQ0FBQTtJQUNuQiw0Q0FBK0IsQ0FBQTtBQUNqQyxDQUFDLEVBWlcsU0FBUyx5QkFBVCxTQUFTLFFBWXBCO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDVSxRQUFBLGNBQWMsR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXNjcmlwdGlvbiBFbnVtIGNvbnRhaW5pbmcgbWV0YWRhdGEga2V5cyB1c2VkIGZvciByZWZsZWN0aW9uIGluIHRoZSBtb2RlbCBzeXN0ZW1cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIHZhcmlvdXMgTW9kZWwga2V5cyB1c2VkIGZvciByZWZsZWN0aW9uIGFuZCBtZXRhZGF0YSBzdG9yYWdlLlxuICogVGhlc2Uga2V5cyBhcmUgdXNlZCB0aHJvdWdob3V0IHRoZSBsaWJyYXJ5IHRvIHN0b3JlIGFuZCByZXRyaWV2ZSBtZXRhZGF0YSBhYm91dCBtb2RlbHMsXG4gKiB0aGVpciBwcm9wZXJ0aWVzLCBhbmQgdGhlaXIgYmVoYXZpb3IuXG4gKlxuICogQHByb3BlcnR5IHtzdHJpbmd9IFJFRkxFQ1QgLSBQcmVmaXggdG8gYWxsIG90aGVyIGtleXMsIHVzZWQgYXMgYSBuYW1lc3BhY2VcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBUWVBFIC0gS2V5IGZvciBzdG9yaW5nIGRlc2lnbiB0eXBlIGluZm9ybWF0aW9uXG4gKiBAcHJvcGVydHkge3N0cmluZ30gUEFSQU1TIC0gS2V5IGZvciBzdG9yaW5nIG1ldGhvZCBwYXJhbWV0ZXIgdHlwZXNcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBSRVRVUk4gLSBLZXkgZm9yIHN0b3JpbmcgbWV0aG9kIHJldHVybiB0eXBlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gTU9ERUwgLSBLZXkgZm9yIGlkZW50aWZ5aW5nIG1vZGVsIG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gQU5DSE9SIC0gQW5jaG9yIGtleSB0aGF0IHNlcnZlcyBhcyBhIGdob3N0IHByb3BlcnR5IGluIHRoZSBtb2RlbFxuICogQHByb3BlcnR5IHtzdHJpbmd9IENPTlNUUlVDVElPTiAtIEtleSBmb3Igc3RvcmluZyBjb25zdHJ1Y3Rpb24gaW5mb3JtYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBBVFRSSUJVVEUgLSBLZXkgZm9yIHN0b3JpbmcgYXR0cmlidXRlIG1ldGFkYXRhXG4gKiBAcHJvcGVydHkge3N0cmluZ30gSEFTSElORyAtIEtleSBmb3Igc3RvcmluZyBoYXNoaW5nIGNvbmZpZ3VyYXRpb25cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBTRVJJQUxJWkFUSU9OIC0gS2V5IGZvciBzdG9yaW5nIHNlcmlhbGl6YXRpb24gY29uZmlndXJhdGlvblxuICpcbiAqIEBlbnVtIHtzdHJpbmd9XG4gKiBAcmVhZG9ubHlcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqIEBjYXRlZ29yeSBNb2RlbFxuICovXG5leHBvcnQgZW51bSBNb2RlbEtleXMge1xuICBSRUZMRUNUID0gXCJkZWNhZi5tb2RlbC5cIixcbiAgREVTQ1JJUFRJT04gPSBcImRlY2FmLmRlc2NyaXB0aW9uLlwiLFxuICBUWVBFID0gXCJkZXNpZ246dHlwZVwiLFxuICBQQVJBTVMgPSBcImRlc2lnbjpwYXJhbXR5cGVzXCIsXG4gIFJFVFVSTiA9IFwiZGVzaWduOnJldHVybnR5cGVcIixcbiAgTU9ERUwgPSBcIm1vZGVsXCIsXG4gIEFOQ0hPUiA9IFwiX19tb2RlbFwiLFxuICBDT05TVFJVQ1RJT04gPSBcImNvbnN0cnVjdGVkLWJ5XCIsXG4gIEFUVFJJQlVURSA9IFwiX19hdHRyaWJ1dGVzXCIsXG4gIEhBU0hJTkcgPSBcImhhc2hpbmdcIixcbiAgU0VSSUFMSVpBVElPTiA9IFwic2VyaWFsaXphdGlvblwiLFxufVxuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGZsYXZvdXIgaWRlbnRpZmllciBmb3IgdGhlIGRlY29yYXRvciBzeXN0ZW1cbiAqIEBzdW1tYXJ5IERlZmluZXMgdGhlIGRlZmF1bHQgZmxhdm91ciB1c2VkIGJ5IHRoZSBEZWNvcmF0aW9uIGNsYXNzIHdoZW4gbm8gc3BlY2lmaWMgZmxhdm91ciBpcyBwcm92aWRlZC5cbiAqIFRoaXMgY29uc3RhbnQgaXMgdXNlZCB0aHJvdWdob3V0IHRoZSBsaWJyYXJ5IGFzIHRoZSBmYWxsYmFjayBmbGF2b3VyIGZvciBkZWNvcmF0b3JzLlxuICpcbiAqIEBjb25zdCB7c3RyaW5nfVxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICogQGNhdGVnb3J5IE1vZGVsXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0Rmxhdm91ciA9IFwiZGVjYWZcIjtcbiJdfQ==
@@ -15,8 +15,8 @@
15
15
  * @property {string} HASHING - Key for storing hashing configuration
16
16
  * @property {string} SERIALIZATION - Key for storing serialization configuration
17
17
  *
18
- * @readonly
19
18
  * @enum {string}
19
+ * @readonly
20
20
  * @memberOf module:decorator-validation
21
21
  * @category Model
22
22
  */
@@ -3,18 +3,24 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DEFAULT_PATTERNS = exports.DEFAULT_ERROR_MESSAGES = exports.DAYS_OF_WEEK_NAMES = exports.MONTH_NAMES = exports.ValidationKeys = exports.ComparisonValidationKeys = void 0;
4
4
  const constants_1 = require("./../../utils/constants.cjs");
5
5
  /**
6
- * @summary Keys used for comparison-based validations.
7
- *
8
- * @property {string} EQUALS - Validates if two values are equal.
9
- * @property {string} DIFF - Validates if two values are different.
10
- * @property {string} LESS_THAN - Validates if a value is less than another.
11
- * @property {string} LESS_THAN_OR_EQUAL - Validates if a value is less than or equal to another.
12
- * @property {string} GREATER_THAN - Validates if a value is greater than another.
13
- * @property {string} GREATER_THAN_OR_EQUAL - Validates if a value is greater than or equal to another.
14
- *
15
- * @constant ComparisonValidationKeys
16
- * @memberof module:decorator-validation.Validation
6
+ * @description Object-like set of keys used for comparison-based validations.
7
+ * @summary Provides canonical names for validators that compare two values (equality and ordering checks).
8
+ * @typedef {Object} ComparisonValidationKeysDef
9
+ * @property {"equals"} EQUALS Validates if two values are equal.
10
+ * @property {"different"} DIFF Validates if two values are different.
11
+ * @property {"lessThan"} LESS_THAN Validates if a value is less than another.
12
+ * @property {"lessThanOrEqual"} LESS_THAN_OR_EQUAL Validates if a value is less than or equal to another.
13
+ * @property {"greaterThan"} GREATER_THAN Validates if a value is greater than another.
14
+ * @property {"greaterThanOrEqual"} GREATER_THAN_OR_EQUAL Validates if a value is greater than or equal to another.
15
+ * @memberOf module:decorator-validation.Validation
16
+ */
17
+ /**
18
+ * @description Keys used for comparison-based validations.
19
+ * @summary Canonical key names for comparison validators.
20
+ * @const ComparisonValidationKeys
21
+ * @memberOf module:decorator-validation.Validation
17
22
  * @category Validation
23
+ * @type {ComparisonValidationKeysDef}
18
24
  */
19
25
  exports.ComparisonValidationKeys = {
20
26
  EQUALS: "equals",
@@ -25,26 +31,34 @@ exports.ComparisonValidationKeys = {
25
31
  GREATER_THAN_OR_EQUAL: "greaterThanOrEqual",
26
32
  };
27
33
  /**
28
- * @summary The keys used for validation
29
- *
30
- * @property {string} REFLECT prefixes others
31
- * @property {string} REQUIRED sets as required
32
- * @property {string} MIN defines min value
33
- * @property {string} MAX defines max value
34
- * @property {string} STEP defines step
35
- * @property {string} MIN_LENGTH defines min length
36
- * @property {string} MAX_LENGTH defines max length
37
- * @property {string} PATTERN defines pattern
38
- * @property {string} EMAIL defines email
39
- * @property {string} URL defines url
40
- * @property {string} DATE defines date
41
- * @property {string} TYPE defines type
42
- * @property {string} PASSWORD defines password
43
- * @property {string} LIST defines list
44
- *
45
- * @constant ValidationKeys
34
+ * @description Object-like set of keys used across all validators in the system.
35
+ * @summary Defines the canonical namespaced key prefix and the individual validation flags for rules such as required, min/max, length, patterns, types, lists and more.
36
+ * @typedef {Object} ValidationKeysDef
37
+ * @property {string} REFLECT prefixes others (namespace prefix)
38
+ * @property {"required"} REQUIRED sets as required
39
+ * @property {"min"} MIN defines min value
40
+ * @property {"max"} MAX defines max value
41
+ * @property {"step"} STEP defines step
42
+ * @property {"minlength"} MIN_LENGTH defines min length
43
+ * @property {"maxlength"} MAX_LENGTH defines max length
44
+ * @property {"pattern"} PATTERN defines pattern
45
+ * @property {"email"} EMAIL defines email
46
+ * @property {"url"} URL defines url
47
+ * @property {"date"} DATE defines date
48
+ * @property {"type"} TYPE defines type
49
+ * @property {"password"} PASSWORD defines password
50
+ * @property {"list"} LIST defines list
51
+ * @property {"unique"} UNIQUE flags uniqueness
52
+ * @property {"validator"} VALIDATOR custom validator id
53
+ * @memberOf module:decorator-validation.Validation
54
+ */
55
+ /**
56
+ * @description The keys used for validation.
57
+ * @summary A namespaced collection of validation key strings used throughout the library.
58
+ * @const ValidationKeys
46
59
  * @memberOf module:decorator-validation.Validation
47
60
  * @category Validation
61
+ * @type {ValidationKeysDef}
48
62
  */
49
63
  exports.ValidationKeys = {
50
64
  REFLECT: `${constants_1.ModelKeys.REFLECT}validation.`,
@@ -67,10 +81,9 @@ exports.ValidationKeys = {
67
81
  ...exports.ComparisonValidationKeys,
68
82
  };
69
83
  /**
70
- * @summary list of month names
71
- * @description Stores month names. Can be changed for localization purposes
72
- *
73
- * @constant MONTH_NAMES
84
+ * @description list of month names
85
+ * @summary Stores month names. Can be changed for localization purposes
86
+ * @const MONTH_NAMES
74
87
  * @memberOf module:decorator-validation.Validation
75
88
  * @category Validation
76
89
  */
@@ -89,10 +102,9 @@ exports.MONTH_NAMES = [
89
102
  "December",
90
103
  ];
91
104
  /**
92
- * @summary list of names of days of the week
93
- * @description Stores names for days of the week. Can be changed for localization purposes
94
- *
95
- * @constant DAYS_OF_WEEK_NAMES
105
+ * @description list of names of days of the week
106
+ * @summary Stores names for days of the week. Can be changed for localization purposes
107
+ * @const DAYS_OF_WEEK_NAMES
96
108
  * @memberOf module:decorator-validation.Validation
97
109
  * @category Validation
98
110
  */
@@ -106,8 +118,9 @@ exports.DAYS_OF_WEEK_NAMES = [
106
118
  "Saturday",
107
119
  ];
108
120
  /**
109
- * @summary Defines the default error messages
110
- *
121
+ * @description Type definition for default error message strings keyed by validation type.
122
+ * @summary Enumerates the supported error message keys with their intended meaning; used to localize or override default messages.
123
+ * @typedef {Object} DefaultErrorMessages
111
124
  * @property {string} REQUIRED default error message
112
125
  * @property {string} MIN default error message
113
126
  * @property {string} MAX default error message
@@ -124,10 +137,15 @@ exports.DAYS_OF_WEEK_NAMES = [
124
137
  * @property {string} LIST default error message
125
138
  * @property {string} LIST_INSIDE default error message
126
139
  * @property {string} MODEL_NOT_FOUND default error message
127
- *
128
- * @constant DEFAULT_ERROR_MESSAGES
140
+ * @memberOf module:decorator-validation.Validation
141
+ */
142
+ /**
143
+ * @description Defines the default error messages
144
+ * @summary Mapping between validation keys and their default human-readable error messages.
145
+ * @const DEFAULT_ERROR_MESSAGES
129
146
  * @memberOf module:decorator-validation.Validation
130
147
  * @category Validation
148
+ * @type {DefaultErrorMessages}
131
149
  */
132
150
  exports.DEFAULT_ERROR_MESSAGES = {
133
151
  REQUIRED: "This field is required",
@@ -154,11 +172,22 @@ exports.DEFAULT_ERROR_MESSAGES = {
154
172
  UNIQUE: "Duplicate found, this field must be unique.",
155
173
  };
156
174
  /**
157
- * @summary Defines the various default regexp patterns used
158
- *
159
- * @enum DEFAULT_PATTERNS
175
+ * @description Type definition for default regular expression patterns used in validation.
176
+ * @summary Captures common regex patterns for email, URL, and password policies, including nested grouping for password-related rules.
177
+ * @typedef {Object} DefaultPatterns
178
+ * @property {RegExp} EMAIL Email address validation pattern
179
+ * @property {RegExp} URL URL validation pattern
180
+ * @property {Object} PASSWORD Password-related regex patterns
181
+ * @property {RegExp} PASSWORD.CHAR8_ONE_OF_EACH At least 8 chars with lower, upper, number, and special char
182
+ * @memberOf module:decorator-validation.Validation
183
+ */
184
+ /**
185
+ * @description Defines the various default regexp patterns used
186
+ * @summary Collection of frequently used validation patterns grouped under semantic keys.
187
+ * @const DEFAULT_PATTERNS
160
188
  * @memberOf module:decorator-validation.Validation
161
189
  * @category Validation
190
+ * @type {DefaultPatterns}
162
191
  */
163
192
  exports.DEFAULT_PATTERNS = {
164
193
  EMAIL: /[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-z0-9-]*[a-zA-Z0-9])?\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?/,
@@ -167,4 +196,4 @@ exports.DEFAULT_PATTERNS = {
167
196
  CHAR8_ONE_OF_EACH: /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&_\-.,])[A-Za-z\d@$!%*?&_\-.,]{8,}$/g,
168
197
  },
169
198
  };
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/validation/Validators/constants.ts"],"names":[],"mappings":";;;AAAA,2DAAkD;AAElD;;;;;;;;;;;;;GAaG;AACU,QAAA,wBAAwB,GAAG;IACtC,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,WAAW;IACjB,SAAS,EAAE,UAAU;IACrB,kBAAkB,EAAE,iBAAiB;IACrC,YAAY,EAAE,aAAa;IAC3B,qBAAqB,EAAE,oBAAoB;CACnC,CAAC;AAEX;;;;;;;;;;;;;;;;;;;;;GAqBG;AACU,QAAA,cAAc,GAAG;IAC5B,OAAO,EAAE,GAAG,qBAAS,CAAC,OAAO,aAAa;IAC1C,IAAI,EAAE,MAAM;IACZ,KAAK,EAAE,OAAO;IACd,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;IACZ,GAAG,EAAE,KAAK;IACV,UAAU,EAAE,WAAW;IACvB,GAAG,EAAE,KAAK;IACV,UAAU,EAAE,WAAW;IACvB,QAAQ,EAAE,UAAU;IACpB,OAAO,EAAE,SAAS;IAClB,QAAQ,EAAE,UAAU;IACpB,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,MAAM,EAAE,QAAQ;IAChB,GAAG,EAAE,KAAK;IACV,SAAS,EAAE,WAAW;IACtB,GAAG,gCAAwB;CACnB,CAAC;AAEX;;;;;;;GAOG;AACU,QAAA,WAAW,GAAG;IACzB,SAAS;IACT,UAAU;IACV,OAAO;IACP,OAAO;IACP,KAAK;IACL,MAAM;IACN,MAAM;IACN,QAAQ;IACR,WAAW;IACX,SAAS;IACT,UAAU;IACV,UAAU;CACX,CAAC;AAEF;;;;;;;GAOG;AACU,QAAA,kBAAkB,GAAG;IAChC,QAAQ;IACR,QAAQ;IACR,SAAS;IACT,WAAW;IACX,UAAU;IACV,QAAQ;IACR,UAAU;CACX,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACU,QAAA,sBAAsB,GAA2B;IAC5D,QAAQ,EAAE,wBAAwB;IAClC,GAAG,EAAE,0BAA0B;IAC/B,GAAG,EAAE,0BAA0B;IAC/B,UAAU,EAAE,2BAA2B;IACvC,UAAU,EAAE,2BAA2B;IACvC,OAAO,EAAE,sCAAsC;IAC/C,KAAK,EAAE,gCAAgC;IACvC,GAAG,EAAE,8BAA8B;IACnC,IAAI,EAAE,0CAA0C;IAChD,IAAI,EAAE,kCAAkC;IACxC,IAAI,EAAE,iCAAiC;IACvC,OAAO,EAAE,mBAAmB;IAC5B,QAAQ,EACN,4HAA4H;IAC9H,IAAI,EAAE,qBAAqB;IAC3B,eAAe,EAAE,+BAA+B;IAChD,MAAM,EAAE,uCAAuC;IAC/C,IAAI,EAAE,6CAA6C;IACnD,SAAS,EAAE,wCAAwC;IACnD,kBAAkB,EAAE,oDAAoD;IACxE,YAAY,EAAE,2CAA2C;IACzD,qBAAqB,EACnB,uDAAuD;IACzD,MAAM,EAAE,6CAA6C;CACtD,CAAC;AAEF;;;;;;GAMG;AACU,QAAA,gBAAgB,GAAG;IAC9B,KAAK,EACH,4JAA4J;IAC9J,GAAG,EAAE,yaAAya;IAC9a,QAAQ,EAAE;QACR,iBAAiB,EACf,iFAAiF;KACpF;CACF,CAAC","sourcesContent":["import { ModelKeys } from \"../../utils/constants\";\n\n/**\n * @summary Keys used for comparison-based validations.\n *\n * @property {string} EQUALS - Validates if two values are equal.\n * @property {string} DIFF - Validates if two values are different.\n * @property {string} LESS_THAN - Validates if a value is less than another.\n * @property {string} LESS_THAN_OR_EQUAL - Validates if a value is less than or equal to another.\n * @property {string} GREATER_THAN - Validates if a value is greater than another.\n * @property {string} GREATER_THAN_OR_EQUAL - Validates if a value is greater than or equal to another.\n *\n * @constant ComparisonValidationKeys\n * @memberof module:decorator-validation.Validation\n * @category Validation\n */\nexport const ComparisonValidationKeys = {\n  EQUALS: \"equals\",\n  DIFF: \"different\",\n  LESS_THAN: \"lessThan\",\n  LESS_THAN_OR_EQUAL: \"lessThanOrEqual\",\n  GREATER_THAN: \"greaterThan\",\n  GREATER_THAN_OR_EQUAL: \"greaterThanOrEqual\",\n} as const;\n\n/**\n * @summary The keys used for validation\n *\n * @property {string} REFLECT prefixes others\n * @property {string} REQUIRED sets as required\n * @property {string} MIN defines min value\n * @property {string} MAX defines max value\n * @property {string} STEP defines step\n * @property {string} MIN_LENGTH defines min length\n * @property {string} MAX_LENGTH defines max length\n * @property {string} PATTERN defines pattern\n * @property {string} EMAIL defines email\n * @property {string} URL defines url\n * @property {string} DATE defines date\n * @property {string} TYPE defines type\n * @property {string} PASSWORD defines password\n * @property {string} LIST defines list\n *\n * @constant ValidationKeys\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const ValidationKeys = {\n  REFLECT: `${ModelKeys.REFLECT}validation.`,\n  DATE: \"date\",\n  EMAIL: \"email\",\n  FORMAT: \"format\",\n  LIST: \"list\",\n  MAX: \"max\",\n  MAX_LENGTH: \"maxlength\",\n  MIN: \"min\",\n  MIN_LENGTH: \"minlength\",\n  PASSWORD: \"password\",\n  PATTERN: \"pattern\",\n  REQUIRED: \"required\",\n  STEP: \"step\",\n  TYPE: \"type\",\n  UNIQUE: \"unique\",\n  URL: \"url\",\n  VALIDATOR: \"validator\",\n  ...ComparisonValidationKeys,\n} as const;\n\n/**\n * @summary list of month names\n * @description Stores month names. Can be changed for localization purposes\n *\n * @constant MONTH_NAMES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const MONTH_NAMES = [\n  \"January\",\n  \"February\",\n  \"March\",\n  \"April\",\n  \"May\",\n  \"June\",\n  \"July\",\n  \"August\",\n  \"September\",\n  \"October\",\n  \"November\",\n  \"December\",\n];\n\n/**\n * @summary list of names of days of the week\n * @description Stores names for days of the week. Can be changed for localization purposes\n *\n * @constant DAYS_OF_WEEK_NAMES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const DAYS_OF_WEEK_NAMES = [\n  \"Sunday\",\n  \"Monday\",\n  \"Tuesday\",\n  \"Wednesday\",\n  \"Thursday\",\n  \"Friday\",\n  \"Saturday\",\n];\n\n/**\n * @summary Defines the default error messages\n *\n * @property {string} REQUIRED default error message\n * @property {string} MIN default error message\n * @property {string} MAX default error message\n * @property {string} MIN_LENGTH default error message\n * @property {string} MAX_LENGTH default error message\n * @property {string} PATTERN default error message\n * @property {string} EMAIL default error message\n * @property {string} URL default error message\n * @property {string} TYPE default error message\n * @property {string} STEP default error message\n * @property {string} DATE default error message\n * @property {string} DEFAULT default error message\n * @property {string} PASSWORD default error message\n * @property {string} LIST default error message\n * @property {string} LIST_INSIDE default error message\n * @property {string} MODEL_NOT_FOUND default error message\n *\n * @constant DEFAULT_ERROR_MESSAGES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const DEFAULT_ERROR_MESSAGES: Record<string, string> = {\n  REQUIRED: \"This field is required\",\n  MIN: \"The minimum value is {0}\",\n  MAX: \"The maximum value is {0}\",\n  MIN_LENGTH: \"The minimum length is {0}\",\n  MAX_LENGTH: \"The maximum length is {0}\",\n  PATTERN: \"The value does not match the pattern\",\n  EMAIL: \"The value is not a valid email\",\n  URL: \"The value is not a valid URL\",\n  TYPE: \"Invalid type. Expected {0}, received {1}\",\n  STEP: \"Invalid value. Not a step of {0}\",\n  DATE: \"Invalid value. not a valid Date\",\n  DEFAULT: \"There is an Error\",\n  PASSWORD:\n    \"Must be at least 8 characters and contain one of number, lower and upper case letters, and special character (@$!%*?&_-.,)\",\n  LIST: \"Invalid list of {0}\",\n  MODEL_NOT_FOUND: \"No model registered under {0}\",\n  EQUALS: \"This field must be equal to field {0}\",\n  DIFF: \"This field must be different from field {0}\",\n  LESS_THAN: \"This field must be less than field {0}\",\n  LESS_THAN_OR_EQUAL: \"This field must be less than or equal to field {0}\",\n  GREATER_THAN: \"This field must be greater than field {0}\",\n  GREATER_THAN_OR_EQUAL:\n    \"This field must be greater than or equal to field {0}\",\n  UNIQUE: \"Duplicate found, this field must be unique.\",\n};\n\n/**\n * @summary Defines the various default regexp patterns used\n *\n * @enum DEFAULT_PATTERNS\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const DEFAULT_PATTERNS = {\n  EMAIL:\n    /[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-z0-9-]*[a-zA-Z0-9])?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?/,\n  URL: /^(?:(?:(?:https?|ftp):)?\\/\\/)(?:\\S+(?::\\S*)?@)?(?:(?!(?:10|127)(?:\\.\\d{1,3}){3})(?!(?:169\\.254|192\\.168)(?:\\.\\d{1,3}){2})(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z0-9\\u00a1-\\uffff][a-z0-9\\u00a1-\\uffff_-]{0,62})?[a-z0-9\\u00a1-\\uffff]\\.)+(?:[a-z\\u00a1-\\uffff]{2,}\\.?))(?::\\d{2,5})?(?:[/?#]\\S*)?$/i,\n  PASSWORD: {\n    CHAR8_ONE_OF_EACH:\n      /^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[@$!%*?&_\\-.,])[A-Za-z\\d@$!%*?&_\\-.,]{8,}$/g,\n  },\n};\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/validation/Validators/constants.ts"],"names":[],"mappings":";;;AAAA,2DAAkD;AAElD;;;;;;;;;;;GAWG;AAEH;;;;;;;GAOG;AACU,QAAA,wBAAwB,GAAG;IACtC,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,WAAW;IACjB,SAAS,EAAE,UAAU;IACrB,kBAAkB,EAAE,iBAAiB;IACrC,YAAY,EAAE,aAAa;IAC3B,qBAAqB,EAAE,oBAAoB;CACnC,CAAC;AAEX;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;;;;;;GAOG;AACU,QAAA,cAAc,GAAG;IAC5B,OAAO,EAAE,GAAG,qBAAS,CAAC,OAAO,aAAa;IAC1C,IAAI,EAAE,MAAM;IACZ,KAAK,EAAE,OAAO;IACd,MAAM,EAAE,QAAQ;IAChB,IAAI,EAAE,MAAM;IACZ,GAAG,EAAE,KAAK;IACV,UAAU,EAAE,WAAW;IACvB,GAAG,EAAE,KAAK;IACV,UAAU,EAAE,WAAW;IACvB,QAAQ,EAAE,UAAU;IACpB,OAAO,EAAE,SAAS;IAClB,QAAQ,EAAE,UAAU;IACpB,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,MAAM,EAAE,QAAQ;IAChB,GAAG,EAAE,KAAK;IACV,SAAS,EAAE,WAAW;IACtB,GAAG,gCAAwB;CACnB,CAAC;AAEX;;;;;;GAMG;AACU,QAAA,WAAW,GAAG;IACzB,SAAS;IACT,UAAU;IACV,OAAO;IACP,OAAO;IACP,KAAK;IACL,MAAM;IACN,MAAM;IACN,QAAQ;IACR,WAAW;IACX,SAAS;IACT,UAAU;IACV,UAAU;CACX,CAAC;AAEF;;;;;;GAMG;AACU,QAAA,kBAAkB,GAAG;IAChC,QAAQ;IACR,QAAQ;IACR,SAAS;IACT,WAAW;IACX,UAAU;IACV,QAAQ;IACR,UAAU;CACX,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH;;;;;;;GAOG;AACU,QAAA,sBAAsB,GAA2B;IAC5D,QAAQ,EAAE,wBAAwB;IAClC,GAAG,EAAE,0BAA0B;IAC/B,GAAG,EAAE,0BAA0B;IAC/B,UAAU,EAAE,2BAA2B;IACvC,UAAU,EAAE,2BAA2B;IACvC,OAAO,EAAE,sCAAsC;IAC/C,KAAK,EAAE,gCAAgC;IACvC,GAAG,EAAE,8BAA8B;IACnC,IAAI,EAAE,0CAA0C;IAChD,IAAI,EAAE,kCAAkC;IACxC,IAAI,EAAE,iCAAiC;IACvC,OAAO,EAAE,mBAAmB;IAC5B,QAAQ,EACN,4HAA4H;IAC9H,IAAI,EAAE,qBAAqB;IAC3B,eAAe,EAAE,+BAA+B;IAChD,MAAM,EAAE,uCAAuC;IAC/C,IAAI,EAAE,6CAA6C;IACnD,SAAS,EAAE,wCAAwC;IACnD,kBAAkB,EAAE,oDAAoD;IACxE,YAAY,EAAE,2CAA2C;IACzD,qBAAqB,EACnB,uDAAuD;IACzD,MAAM,EAAE,6CAA6C;CACtD,CAAC;AAEF;;;;;;;;;GASG;AAEH;;;;;;;GAOG;AACU,QAAA,gBAAgB,GAAG;IAC9B,KAAK,EACH,4JAA4J;IAC9J,GAAG,EAAE,yaAAya;IAC9a,QAAQ,EAAE;QACR,iBAAiB,EACf,iFAAiF;KACpF;CACF,CAAC","sourcesContent":["import { ModelKeys } from \"../../utils/constants\";\n\n/**\n * @description Object-like set of keys used for comparison-based validations.\n * @summary Provides canonical names for validators that compare two values (equality and ordering checks).\n * @typedef {Object} ComparisonValidationKeysDef\n * @property {\"equals\"} EQUALS Validates if two values are equal.\n * @property {\"different\"} DIFF Validates if two values are different.\n * @property {\"lessThan\"} LESS_THAN Validates if a value is less than another.\n * @property {\"lessThanOrEqual\"} LESS_THAN_OR_EQUAL Validates if a value is less than or equal to another.\n * @property {\"greaterThan\"} GREATER_THAN Validates if a value is greater than another.\n * @property {\"greaterThanOrEqual\"} GREATER_THAN_OR_EQUAL Validates if a value is greater than or equal to another.\n * @memberOf module:decorator-validation.Validation\n */\n\n/**\n * @description Keys used for comparison-based validations.\n * @summary Canonical key names for comparison validators.\n * @const ComparisonValidationKeys\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n * @type {ComparisonValidationKeysDef}\n */\nexport const ComparisonValidationKeys = {\n  EQUALS: \"equals\",\n  DIFF: \"different\",\n  LESS_THAN: \"lessThan\",\n  LESS_THAN_OR_EQUAL: \"lessThanOrEqual\",\n  GREATER_THAN: \"greaterThan\",\n  GREATER_THAN_OR_EQUAL: \"greaterThanOrEqual\",\n} as const;\n\n/**\n * @description Object-like set of keys used across all validators in the system.\n * @summary Defines the canonical namespaced key prefix and the individual validation flags for rules such as required, min/max, length, patterns, types, lists and more.\n * @typedef {Object} ValidationKeysDef\n * @property {string} REFLECT prefixes others (namespace prefix)\n * @property {\"required\"} REQUIRED sets as required\n * @property {\"min\"} MIN defines min value\n * @property {\"max\"} MAX defines max value\n * @property {\"step\"} STEP defines step\n * @property {\"minlength\"} MIN_LENGTH defines min length\n * @property {\"maxlength\"} MAX_LENGTH defines max length\n * @property {\"pattern\"} PATTERN defines pattern\n * @property {\"email\"} EMAIL defines email\n * @property {\"url\"} URL defines url\n * @property {\"date\"} DATE defines date\n * @property {\"type\"} TYPE defines type\n * @property {\"password\"} PASSWORD defines password\n * @property {\"list\"} LIST defines list\n * @property {\"unique\"} UNIQUE flags uniqueness\n * @property {\"validator\"} VALIDATOR custom validator id\n * @memberOf module:decorator-validation.Validation\n */\n\n/**\n * @description The keys used for validation.\n * @summary A namespaced collection of validation key strings used throughout the library.\n * @const ValidationKeys\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n * @type {ValidationKeysDef}\n */\nexport const ValidationKeys = {\n  REFLECT: `${ModelKeys.REFLECT}validation.`,\n  DATE: \"date\",\n  EMAIL: \"email\",\n  FORMAT: \"format\",\n  LIST: \"list\",\n  MAX: \"max\",\n  MAX_LENGTH: \"maxlength\",\n  MIN: \"min\",\n  MIN_LENGTH: \"minlength\",\n  PASSWORD: \"password\",\n  PATTERN: \"pattern\",\n  REQUIRED: \"required\",\n  STEP: \"step\",\n  TYPE: \"type\",\n  UNIQUE: \"unique\",\n  URL: \"url\",\n  VALIDATOR: \"validator\",\n  ...ComparisonValidationKeys,\n} as const;\n\n/**\n * @description list of month names\n * @summary Stores month names. Can be changed for localization purposes\n * @const MONTH_NAMES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const MONTH_NAMES = [\n  \"January\",\n  \"February\",\n  \"March\",\n  \"April\",\n  \"May\",\n  \"June\",\n  \"July\",\n  \"August\",\n  \"September\",\n  \"October\",\n  \"November\",\n  \"December\",\n];\n\n/**\n * @description list of names of days of the week\n * @summary Stores names for days of the week. Can be changed for localization purposes\n * @const DAYS_OF_WEEK_NAMES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport const DAYS_OF_WEEK_NAMES = [\n  \"Sunday\",\n  \"Monday\",\n  \"Tuesday\",\n  \"Wednesday\",\n  \"Thursday\",\n  \"Friday\",\n  \"Saturday\",\n];\n\n/**\n * @description Type definition for default error message strings keyed by validation type.\n * @summary Enumerates the supported error message keys with their intended meaning; used to localize or override default messages.\n * @typedef {Object} DefaultErrorMessages\n * @property {string} REQUIRED default error message\n * @property {string} MIN default error message\n * @property {string} MAX default error message\n * @property {string} MIN_LENGTH default error message\n * @property {string} MAX_LENGTH default error message\n * @property {string} PATTERN default error message\n * @property {string} EMAIL default error message\n * @property {string} URL default error message\n * @property {string} TYPE default error message\n * @property {string} STEP default error message\n * @property {string} DATE default error message\n * @property {string} DEFAULT default error message\n * @property {string} PASSWORD default error message\n * @property {string} LIST default error message\n * @property {string} LIST_INSIDE default error message\n * @property {string} MODEL_NOT_FOUND default error message\n * @memberOf module:decorator-validation.Validation\n */\n\n/**\n * @description Defines the default error messages\n * @summary Mapping between validation keys and their default human-readable error messages.\n * @const DEFAULT_ERROR_MESSAGES\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n * @type {DefaultErrorMessages}\n */\nexport const DEFAULT_ERROR_MESSAGES: Record<string, string> = {\n  REQUIRED: \"This field is required\",\n  MIN: \"The minimum value is {0}\",\n  MAX: \"The maximum value is {0}\",\n  MIN_LENGTH: \"The minimum length is {0}\",\n  MAX_LENGTH: \"The maximum length is {0}\",\n  PATTERN: \"The value does not match the pattern\",\n  EMAIL: \"The value is not a valid email\",\n  URL: \"The value is not a valid URL\",\n  TYPE: \"Invalid type. Expected {0}, received {1}\",\n  STEP: \"Invalid value. Not a step of {0}\",\n  DATE: \"Invalid value. not a valid Date\",\n  DEFAULT: \"There is an Error\",\n  PASSWORD:\n    \"Must be at least 8 characters and contain one of number, lower and upper case letters, and special character (@$!%*?&_-.,)\",\n  LIST: \"Invalid list of {0}\",\n  MODEL_NOT_FOUND: \"No model registered under {0}\",\n  EQUALS: \"This field must be equal to field {0}\",\n  DIFF: \"This field must be different from field {0}\",\n  LESS_THAN: \"This field must be less than field {0}\",\n  LESS_THAN_OR_EQUAL: \"This field must be less than or equal to field {0}\",\n  GREATER_THAN: \"This field must be greater than field {0}\",\n  GREATER_THAN_OR_EQUAL:\n    \"This field must be greater than or equal to field {0}\",\n  UNIQUE: \"Duplicate found, this field must be unique.\",\n};\n\n/**\n * @description Type definition for default regular expression patterns used in validation.\n * @summary Captures common regex patterns for email, URL, and password policies, including nested grouping for password-related rules.\n * @typedef {Object} DefaultPatterns\n * @property {RegExp} EMAIL Email address validation pattern\n * @property {RegExp} URL URL validation pattern\n * @property {Object} PASSWORD Password-related regex patterns\n * @property {RegExp} PASSWORD.CHAR8_ONE_OF_EACH At least 8 chars with lower, upper, number, and special char\n * @memberOf module:decorator-validation.Validation\n */\n\n/**\n * @description Defines the various default regexp patterns used\n * @summary Collection of frequently used validation patterns grouped under semantic keys.\n * @const DEFAULT_PATTERNS\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n * @type {DefaultPatterns}\n */\nexport const DEFAULT_PATTERNS = {\n  EMAIL:\n    /[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-z0-9-]*[a-zA-Z0-9])?\\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?/,\n  URL: /^(?:(?:(?:https?|ftp):)?\\/\\/)(?:\\S+(?::\\S*)?@)?(?:(?!(?:10|127)(?:\\.\\d{1,3}){3})(?!(?:169\\.254|192\\.168)(?:\\.\\d{1,3}){2})(?!172\\.(?:1[6-9]|2\\d|3[0-1])(?:\\.\\d{1,3}){2})(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z0-9\\u00a1-\\uffff][a-z0-9\\u00a1-\\uffff_-]{0,62})?[a-z0-9\\u00a1-\\uffff]\\.)+(?:[a-z\\u00a1-\\uffff]{2,}\\.?))(?::\\d{2,5})?(?:[/?#]\\S*)?$/i,\n  PASSWORD: {\n    CHAR8_ONE_OF_EACH:\n      /^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[@$!%*?&_\\-.,])[A-Za-z\\d@$!%*?&_\\-.,]{8,}$/g,\n  },\n};\n"]}
@@ -1,16 +1,22 @@
1
1
  /**
2
- * @summary Keys used for comparison-based validations.
3
- *
4
- * @property {string} EQUALS - Validates if two values are equal.
5
- * @property {string} DIFF - Validates if two values are different.
6
- * @property {string} LESS_THAN - Validates if a value is less than another.
7
- * @property {string} LESS_THAN_OR_EQUAL - Validates if a value is less than or equal to another.
8
- * @property {string} GREATER_THAN - Validates if a value is greater than another.
9
- * @property {string} GREATER_THAN_OR_EQUAL - Validates if a value is greater than or equal to another.
10
- *
11
- * @constant ComparisonValidationKeys
12
- * @memberof module:decorator-validation.Validation
2
+ * @description Object-like set of keys used for comparison-based validations.
3
+ * @summary Provides canonical names for validators that compare two values (equality and ordering checks).
4
+ * @typedef {Object} ComparisonValidationKeysDef
5
+ * @property {"equals"} EQUALS Validates if two values are equal.
6
+ * @property {"different"} DIFF Validates if two values are different.
7
+ * @property {"lessThan"} LESS_THAN Validates if a value is less than another.
8
+ * @property {"lessThanOrEqual"} LESS_THAN_OR_EQUAL Validates if a value is less than or equal to another.
9
+ * @property {"greaterThan"} GREATER_THAN Validates if a value is greater than another.
10
+ * @property {"greaterThanOrEqual"} GREATER_THAN_OR_EQUAL Validates if a value is greater than or equal to another.
11
+ * @memberOf module:decorator-validation.Validation
12
+ */
13
+ /**
14
+ * @description Keys used for comparison-based validations.
15
+ * @summary Canonical key names for comparison validators.
16
+ * @const ComparisonValidationKeys
17
+ * @memberOf module:decorator-validation.Validation
13
18
  * @category Validation
19
+ * @type {ComparisonValidationKeysDef}
14
20
  */
15
21
  export declare const ComparisonValidationKeys: {
16
22
  readonly EQUALS: "equals";
@@ -21,26 +27,34 @@ export declare const ComparisonValidationKeys: {
21
27
  readonly GREATER_THAN_OR_EQUAL: "greaterThanOrEqual";
22
28
  };
23
29
  /**
24
- * @summary The keys used for validation
25
- *
26
- * @property {string} REFLECT prefixes others
27
- * @property {string} REQUIRED sets as required
28
- * @property {string} MIN defines min value
29
- * @property {string} MAX defines max value
30
- * @property {string} STEP defines step
31
- * @property {string} MIN_LENGTH defines min length
32
- * @property {string} MAX_LENGTH defines max length
33
- * @property {string} PATTERN defines pattern
34
- * @property {string} EMAIL defines email
35
- * @property {string} URL defines url
36
- * @property {string} DATE defines date
37
- * @property {string} TYPE defines type
38
- * @property {string} PASSWORD defines password
39
- * @property {string} LIST defines list
40
- *
41
- * @constant ValidationKeys
30
+ * @description Object-like set of keys used across all validators in the system.
31
+ * @summary Defines the canonical namespaced key prefix and the individual validation flags for rules such as required, min/max, length, patterns, types, lists and more.
32
+ * @typedef {Object} ValidationKeysDef
33
+ * @property {string} REFLECT prefixes others (namespace prefix)
34
+ * @property {"required"} REQUIRED sets as required
35
+ * @property {"min"} MIN defines min value
36
+ * @property {"max"} MAX defines max value
37
+ * @property {"step"} STEP defines step
38
+ * @property {"minlength"} MIN_LENGTH defines min length
39
+ * @property {"maxlength"} MAX_LENGTH defines max length
40
+ * @property {"pattern"} PATTERN defines pattern
41
+ * @property {"email"} EMAIL defines email
42
+ * @property {"url"} URL defines url
43
+ * @property {"date"} DATE defines date
44
+ * @property {"type"} TYPE defines type
45
+ * @property {"password"} PASSWORD defines password
46
+ * @property {"list"} LIST defines list
47
+ * @property {"unique"} UNIQUE flags uniqueness
48
+ * @property {"validator"} VALIDATOR custom validator id
49
+ * @memberOf module:decorator-validation.Validation
50
+ */
51
+ /**
52
+ * @description The keys used for validation.
53
+ * @summary A namespaced collection of validation key strings used throughout the library.
54
+ * @const ValidationKeys
42
55
  * @memberOf module:decorator-validation.Validation
43
56
  * @category Validation
57
+ * @type {ValidationKeysDef}
44
58
  */
45
59
  export declare const ValidationKeys: {
46
60
  readonly EQUALS: "equals";
@@ -68,26 +82,25 @@ export declare const ValidationKeys: {
68
82
  readonly VALIDATOR: "validator";
69
83
  };
70
84
  /**
71
- * @summary list of month names
72
- * @description Stores month names. Can be changed for localization purposes
73
- *
74
- * @constant MONTH_NAMES
85
+ * @description list of month names
86
+ * @summary Stores month names. Can be changed for localization purposes
87
+ * @const MONTH_NAMES
75
88
  * @memberOf module:decorator-validation.Validation
76
89
  * @category Validation
77
90
  */
78
91
  export declare const MONTH_NAMES: string[];
79
92
  /**
80
- * @summary list of names of days of the week
81
- * @description Stores names for days of the week. Can be changed for localization purposes
82
- *
83
- * @constant DAYS_OF_WEEK_NAMES
93
+ * @description list of names of days of the week
94
+ * @summary Stores names for days of the week. Can be changed for localization purposes
95
+ * @const DAYS_OF_WEEK_NAMES
84
96
  * @memberOf module:decorator-validation.Validation
85
97
  * @category Validation
86
98
  */
87
99
  export declare const DAYS_OF_WEEK_NAMES: string[];
88
100
  /**
89
- * @summary Defines the default error messages
90
- *
101
+ * @description Type definition for default error message strings keyed by validation type.
102
+ * @summary Enumerates the supported error message keys with their intended meaning; used to localize or override default messages.
103
+ * @typedef {Object} DefaultErrorMessages
91
104
  * @property {string} REQUIRED default error message
92
105
  * @property {string} MIN default error message
93
106
  * @property {string} MAX default error message
@@ -104,18 +117,34 @@ export declare const DAYS_OF_WEEK_NAMES: string[];
104
117
  * @property {string} LIST default error message
105
118
  * @property {string} LIST_INSIDE default error message
106
119
  * @property {string} MODEL_NOT_FOUND default error message
107
- *
108
- * @constant DEFAULT_ERROR_MESSAGES
120
+ * @memberOf module:decorator-validation.Validation
121
+ */
122
+ /**
123
+ * @description Defines the default error messages
124
+ * @summary Mapping between validation keys and their default human-readable error messages.
125
+ * @const DEFAULT_ERROR_MESSAGES
109
126
  * @memberOf module:decorator-validation.Validation
110
127
  * @category Validation
128
+ * @type {DefaultErrorMessages}
111
129
  */
112
130
  export declare const DEFAULT_ERROR_MESSAGES: Record<string, string>;
113
131
  /**
114
- * @summary Defines the various default regexp patterns used
115
- *
116
- * @enum DEFAULT_PATTERNS
132
+ * @description Type definition for default regular expression patterns used in validation.
133
+ * @summary Captures common regex patterns for email, URL, and password policies, including nested grouping for password-related rules.
134
+ * @typedef {Object} DefaultPatterns
135
+ * @property {RegExp} EMAIL Email address validation pattern
136
+ * @property {RegExp} URL URL validation pattern
137
+ * @property {Object} PASSWORD Password-related regex patterns
138
+ * @property {RegExp} PASSWORD.CHAR8_ONE_OF_EACH At least 8 chars with lower, upper, number, and special char
139
+ * @memberOf module:decorator-validation.Validation
140
+ */
141
+ /**
142
+ * @description Defines the various default regexp patterns used
143
+ * @summary Collection of frequently used validation patterns grouped under semantic keys.
144
+ * @const DEFAULT_PATTERNS
117
145
  * @memberOf module:decorator-validation.Validation
118
146
  * @category Validation
147
+ * @type {DefaultPatterns}
119
148
  */
120
149
  export declare const DEFAULT_PATTERNS: {
121
150
  EMAIL: RegExp;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@decaf-ts/decorator-validation",
3
- "version": "1.7.16",
3
+ "version": "1.7.18",
4
4
  "description": "simple decorator based validation engine",
5
5
  "type": "module",
6
6
  "exports": {
@@ -34,6 +34,7 @@
34
34
  "coverage": "rimraf ./workdocs/reports/data/*.json && npm run test:all -- --coverage --config=./workdocs/reports/jest.coverage.config.ts",
35
35
  "lint": "eslint .",
36
36
  "lint-fix": "eslint --fix .",
37
+ "prepare-pr": "npm run lint-fix && npm run build:prod && npm run coverage && npm run docs",
37
38
  "prepare-release": "npm run lint-fix && npm run build:prod && npm run coverage && npm run docs",
38
39
  "release": "./bin/tag-release.sh",
39
40
  "clean-publish": "npx clean-publish",
@@ -110,6 +111,7 @@
110
111
  "typescript-eslint": "^8.31.0"
111
112
  },
112
113
  "peerDependencies": {
114
+ "@decaf-ts/decoration": "^0.0.7",
113
115
  "@decaf-ts/reflection": "latest",
114
116
  "reflect-metadata": "^0.2.1",
115
117
  "typed-object-accumulator": "^0.1.5"