@decaf-ts/decorator-validation 1.7.3 → 1.7.4

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 (62) hide show
  1. package/LICENSE.md +21 -157
  2. package/dist/decorator-validation.cjs +320 -211
  3. package/dist/decorator-validation.esm.cjs +320 -211
  4. package/lib/constants/errors.cjs +19 -0
  5. package/lib/constants/errors.d.ts +11 -0
  6. package/lib/constants/index.cjs +2 -1
  7. package/lib/constants/index.d.ts +1 -0
  8. package/lib/esm/constants/errors.d.ts +11 -0
  9. package/lib/esm/constants/errors.js +16 -0
  10. package/lib/esm/constants/index.d.ts +1 -0
  11. package/lib/esm/constants/index.js +2 -1
  12. package/lib/esm/index.d.ts +1 -1
  13. package/lib/esm/index.js +1 -1
  14. package/lib/esm/model/validation.js +3 -3
  15. package/lib/esm/utils/PathProxy.d.ts +43 -0
  16. package/lib/esm/utils/PathProxy.js +89 -0
  17. package/lib/esm/utils/index.d.ts +1 -0
  18. package/lib/esm/utils/index.js +2 -1
  19. package/lib/esm/validation/Validators/DiffValidator.d.ts +4 -2
  20. package/lib/esm/validation/Validators/DiffValidator.js +5 -5
  21. package/lib/esm/validation/Validators/EqualsValidator.d.ts +4 -2
  22. package/lib/esm/validation/Validators/EqualsValidator.js +5 -5
  23. package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.d.ts +4 -2
  24. package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +6 -5
  25. package/lib/esm/validation/Validators/GreaterThanValidator.d.ts +4 -2
  26. package/lib/esm/validation/Validators/GreaterThanValidator.js +6 -5
  27. package/lib/esm/validation/Validators/LessThanOrEqualValidator.d.ts +4 -2
  28. package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +6 -5
  29. package/lib/esm/validation/Validators/LessThanValidator.d.ts +4 -2
  30. package/lib/esm/validation/Validators/LessThanValidator.js +6 -5
  31. package/lib/esm/validation/Validators/Validator.d.ts +3 -2
  32. package/lib/esm/validation/Validators/Validator.js +1 -1
  33. package/lib/esm/validation/Validators/constants.d.ts +0 -13
  34. package/lib/esm/validation/Validators/constants.js +1 -14
  35. package/lib/esm/validation/Validators/utils.d.ts +0 -14
  36. package/lib/esm/validation/Validators/utils.js +69 -56
  37. package/lib/index.cjs +1 -1
  38. package/lib/index.d.ts +1 -1
  39. package/lib/model/validation.cjs +3 -3
  40. package/lib/utils/PathProxy.cjs +93 -0
  41. package/lib/utils/PathProxy.d.ts +43 -0
  42. package/lib/utils/index.cjs +2 -1
  43. package/lib/utils/index.d.ts +1 -0
  44. package/lib/validation/Validators/DiffValidator.cjs +5 -5
  45. package/lib/validation/Validators/DiffValidator.d.ts +4 -2
  46. package/lib/validation/Validators/EqualsValidator.cjs +5 -5
  47. package/lib/validation/Validators/EqualsValidator.d.ts +4 -2
  48. package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +5 -4
  49. package/lib/validation/Validators/GreaterThanOrEqualValidator.d.ts +4 -2
  50. package/lib/validation/Validators/GreaterThanValidator.cjs +5 -4
  51. package/lib/validation/Validators/GreaterThanValidator.d.ts +4 -2
  52. package/lib/validation/Validators/LessThanOrEqualValidator.cjs +5 -4
  53. package/lib/validation/Validators/LessThanOrEqualValidator.d.ts +4 -2
  54. package/lib/validation/Validators/LessThanValidator.cjs +5 -4
  55. package/lib/validation/Validators/LessThanValidator.d.ts +4 -2
  56. package/lib/validation/Validators/Validator.cjs +1 -1
  57. package/lib/validation/Validators/Validator.d.ts +3 -2
  58. package/lib/validation/Validators/constants.cjs +2 -15
  59. package/lib/validation/Validators/constants.d.ts +0 -13
  60. package/lib/validation/Validators/utils.cjs +79 -67
  61. package/lib/validation/Validators/utils.d.ts +0 -14
  62. package/package.json +2 -2
@@ -1,64 +1,76 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getValueByPath = getValueByPath;
4
3
  exports.isValidForGteOrLteComparison = isValidForGteOrLteComparison;
5
4
  exports.isLessThan = isLessThan;
6
5
  exports.isGreaterThan = isGreaterThan;
7
6
  const constants_1 = require("./../../constants/index.cjs");
8
- const strings_1 = require("./../../utils/strings.cjs");
9
- const constants_2 = require("./constants.cjs");
10
- /**
11
- * Safely retrieves a nested property value from an object using a dot-notated path string.
12
- *
13
- * @template T - The expected return type of the property value.
14
- *
15
- * @param {Record<string, any>} obj - The source object to retrieve the value from.
16
- * @param {string} path - A dot-separated string representing the path to the desired property (e.g., "user.address.street").
17
- *
18
- * @returns {T} - The value found at the specified path
19
- *
20
- * @throws {Error} - Throws an error if the path is not a non-empty string or if any part of the path does not exist in the object.
21
- * @memberOf module:decorator-validation
22
- */
23
- function getValueByPath(obj, path) {
24
- if (typeof path !== "string" || !path.trim()) {
25
- throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_PATH, path));
26
- }
27
- // Process parent directory access (../)
28
- const parentAccessors = path.match(/\.\.\//g) || [];
29
- const parentLevel = parentAccessors.length;
30
- const cleanPath = path.replace(/\.\.\//g, "");
31
- // Navigate up the parent chain
32
- let currentContext = obj;
33
- for (let i = 0; i < parentLevel; i++) {
34
- if (!currentContext || typeof currentContext !== "object") {
35
- throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.CONTEXT_NOT_OBJECT_COMPARISON, i + 1, path));
36
- }
37
- if (!currentContext[constants_1.VALIDATION_PARENT_KEY]) {
38
- throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.NO_PARENT_COMPARISON, i + 1, path));
39
- }
40
- currentContext = currentContext[constants_1.VALIDATION_PARENT_KEY];
41
- }
42
- // Process dot notation path
43
- const parts = cleanPath.split(".");
44
- let currentValue = currentContext;
45
- for (const part of parts) {
46
- if (currentValue !== null &&
47
- typeof currentValue === "object" &&
48
- part in currentValue) {
49
- currentValue = currentValue[part];
50
- }
51
- else {
52
- const errorMsgTemplate = parentLevel === 0
53
- ? constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND
54
- : parentLevel === 1
55
- ? constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_ON_PARENT
56
- : constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_AFTER_PARENT;
57
- throw new Error((0, strings_1.sf)(errorMsgTemplate, path, part, parentLevel));
58
- }
59
- }
60
- return currentValue;
61
- }
7
+ const utils_1 = require("./../../utils/index.cjs");
8
+ // /**
9
+ // * Safely retrieves a nested property value from an object using a dot-notated path string.
10
+ // *
11
+ // * @template T - The expected return type of the property value.
12
+ // *
13
+ // * @param {Record<string, any>} obj - The source object to retrieve the value from.
14
+ // * @param {string} path - A dot-separated string representing the path to the desired property (e.g., "user.address.street").
15
+ // *
16
+ // * @returns {T} - The value found at the specified path
17
+ // *
18
+ // * @throws {Error} - Throws an error if the path is not a non-empty string or if any part of the path does not exist in the object.
19
+ // * @memberOf module:decorator-validation
20
+ // */
21
+ // export function getValueByPath<T>(obj: Record<string, any>, path: string): T {
22
+ // if (typeof path !== "string" || !path.trim()) {
23
+ // throw new Error(sf(COMPARISON_ERROR_MESSAGES.INVALID_PATH, path));
24
+ // }
25
+ //
26
+ // // Process parent directory access (../)
27
+ // const parentAccessors = path.match(/\.\.\//g) || [];
28
+ // const parentLevel = parentAccessors.length;
29
+ // const cleanPath = path.replace(/\.\.\//g, "");
30
+ //
31
+ // // Navigate up the parent chain
32
+ // let currentContext: any = obj;
33
+ // for (let i = 0; i < parentLevel; i++) {
34
+ // if (!currentContext || typeof currentContext !== "object") {
35
+ // throw new Error(
36
+ // sf(COMPARISON_ERROR_MESSAGES.CONTEXT_NOT_OBJECT_COMPARISON, i + 1, path)
37
+ // );
38
+ // }
39
+ //
40
+ // if (!currentContext[VALIDATION_PARENT_KEY]) {
41
+ // throw new Error(
42
+ // sf(COMPARISON_ERROR_MESSAGES.NO_PARENT_COMPARISON, i + 1, path)
43
+ // );
44
+ // }
45
+ //
46
+ // currentContext = currentContext[VALIDATION_PARENT_KEY];
47
+ // }
48
+ //
49
+ // // Process dot notation path
50
+ // const parts = cleanPath.split(".");
51
+ // let currentValue: any = currentContext;
52
+ //
53
+ // for (const part of parts) {
54
+ // if (
55
+ // currentValue !== null &&
56
+ // typeof currentValue === "object" &&
57
+ // part in currentValue
58
+ // ) {
59
+ // currentValue = (currentValue as Record<string, any>)[part];
60
+ // } else {
61
+ // const errorMsgTemplate =
62
+ // parentLevel === 0
63
+ // ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND
64
+ // : parentLevel === 1
65
+ // ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_ON_PARENT
66
+ // : COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_AFTER_PARENT;
67
+ //
68
+ // throw new Error(sf(errorMsgTemplate, path, part, parentLevel));
69
+ // }
70
+ // }
71
+ //
72
+ // return currentValue as T;
73
+ // }
62
74
  const getTypeName = (value) => {
63
75
  if (value === null)
64
76
  return "null";
@@ -100,7 +112,7 @@ const isSupported = (value) => {
100
112
  function isValidForGteOrLteComparison(a, b) {
101
113
  if (isSupported(a) && isSupported(b))
102
114
  return true;
103
- throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
115
+ throw new TypeError((0, utils_1.sf)(constants_1.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
104
116
  }
105
117
  /**
106
118
  * @summary Compares two values to determine if the first is less than the second.
@@ -117,7 +129,7 @@ function isValidForGteOrLteComparison(a, b) {
117
129
  */
118
130
  function isLessThan(a, b) {
119
131
  if ([null, undefined].includes(a) || [null, undefined].includes(b))
120
- throw new Error(constants_2.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
132
+ throw new Error(constants_1.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
121
133
  // Validate type compatibility
122
134
  const aType = typeof a;
123
135
  const bType = typeof b;
@@ -127,20 +139,20 @@ function isLessThan(a, b) {
127
139
  return Number(a) < b;
128
140
  if (aType === "number" && bType === "bigint")
129
141
  return a < Number(b);
130
- throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
142
+ throw new TypeError((0, utils_1.sf)(constants_1.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
131
143
  }
132
144
  if ((aType === "number" && bType === "number") ||
133
145
  (aType === "bigint" && bType === "bigint")) {
134
146
  if (Number.isNaN(a) || Number.isNaN(b))
135
- throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
147
+ throw new TypeError(constants_1.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
136
148
  return a < b;
137
149
  }
138
150
  if (a instanceof Date && b instanceof Date) {
139
151
  if (isNaN(a.getTime()) || isNaN(b.getTime()))
140
- throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
152
+ throw new TypeError(constants_1.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
141
153
  return a.getTime() < b.getTime();
142
154
  }
143
- throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
155
+ throw new TypeError((0, utils_1.sf)(constants_1.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
144
156
  }
145
157
  /**
146
158
  * Checks if `a` is greater than `b`.
@@ -157,7 +169,7 @@ function isLessThan(a, b) {
157
169
  */
158
170
  function isGreaterThan(a, b) {
159
171
  if ([null, undefined].includes(a) || [null, undefined].includes(b))
160
- throw new Error(constants_2.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
172
+ throw new Error(constants_1.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
161
173
  const aType = typeof a;
162
174
  const bType = typeof b;
163
175
  if (aType !== bType) {
@@ -166,19 +178,19 @@ function isGreaterThan(a, b) {
166
178
  return Number(a) > b;
167
179
  if (aType === "number" && bType === "bigint")
168
180
  return a > Number(b);
169
- throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
181
+ throw new Error((0, utils_1.sf)(constants_1.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
170
182
  }
171
183
  if ((aType === "number" && bType === "number") ||
172
184
  (aType === "bigint" && bType === "bigint")) {
173
185
  if (Number.isNaN(a) || Number.isNaN(b))
174
- throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
186
+ throw new TypeError(constants_1.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
175
187
  return a > b;
176
188
  }
177
189
  if (a instanceof Date && b instanceof Date) {
178
190
  if (isNaN(a.getTime()) || isNaN(b.getTime()))
179
- throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
191
+ throw new TypeError(constants_1.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
180
192
  return a.getTime() > b.getTime();
181
193
  }
182
- throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
194
+ throw new TypeError((0, utils_1.sf)(constants_1.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
183
195
  }
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/validation/Validators/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { VALIDATION_PARENT_KEY } from \"../../constants\";\nimport { sf } from \"../../utils/strings\";\nimport { COMPARISON_ERROR_MESSAGES } from \"./constants\";\n\n/**\n * Safely retrieves a nested property value from an object using a dot-notated path string.\n *\n * @template T - The expected return type of the property value.\n *\n * @param {Record<string, any>} obj - The source object to retrieve the value from.\n * @param {string} path - A dot-separated string representing the path to the desired property (e.g., \"user.address.street\").\n *\n * @returns {T} - The value found at the specified path\n *\n * @throws {Error} - Throws an error if the path is not a non-empty string or if any part of the path does not exist in the object.\n * @memberOf module:decorator-validation\n */\nexport function getValueByPath<T>(obj: Record<string, any>, path: string): T {\n  if (typeof path !== \"string\" || !path.trim()) {\n    throw new Error(sf(COMPARISON_ERROR_MESSAGES.INVALID_PATH, path));\n  }\n\n  // Process parent directory access (../)\n  const parentAccessors = path.match(/\\.\\.\\//g) || [];\n  const parentLevel = parentAccessors.length;\n  const cleanPath = path.replace(/\\.\\.\\//g, \"\");\n\n  // Navigate up the parent chain\n  let currentContext: any = obj;\n  for (let i = 0; i < parentLevel; i++) {\n    if (!currentContext || typeof currentContext !== \"object\") {\n      throw new Error(\n        sf(COMPARISON_ERROR_MESSAGES.CONTEXT_NOT_OBJECT_COMPARISON, i + 1, path)\n      );\n    }\n\n    if (!currentContext[VALIDATION_PARENT_KEY]) {\n      throw new Error(\n        sf(COMPARISON_ERROR_MESSAGES.NO_PARENT_COMPARISON, i + 1, path)\n      );\n    }\n\n    currentContext = currentContext[VALIDATION_PARENT_KEY];\n  }\n\n  // Process dot notation path\n  const parts = cleanPath.split(\".\");\n  let currentValue: any = currentContext;\n\n  for (const part of parts) {\n    if (\n      currentValue !== null &&\n      typeof currentValue === \"object\" &&\n      part in currentValue\n    ) {\n      currentValue = (currentValue as Record<string, any>)[part];\n    } else {\n      const errorMsgTemplate =\n        parentLevel === 0\n          ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND\n          : parentLevel === 1\n            ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_ON_PARENT\n            : COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_AFTER_PARENT;\n\n      throw new Error(sf(errorMsgTemplate, path, part, parentLevel));\n    }\n  }\n\n  return currentValue as T;\n}\n\nconst getTypeName = (value: unknown): string => {\n  if (value === null) return \"null\";\n  if (value instanceof Date) return \"Date\";\n  if (Number.isNaN(value)) return \"NaN\";\n  if (value === Infinity) return \"Infinity\";\n  if (value === -Infinity) return \"-Infinity\";\n  if (Array.isArray(value)) return \"array\";\n  return typeof value;\n};\n\nconst isSupported = (\n  value: unknown\n): value is undefined | number | bigint | Date => {\n  if (value === undefined || value instanceof Date) return true;\n\n  if (typeof value === \"bigint\") return true;\n\n  // Numbers must be finite (excludes NaN, Infinity, -Infinity)\n  if (typeof value === \"number\") return Number.isFinite(value);\n\n  return false;\n};\n\n/**\n * Validates whether two values are eligible for comparison using >= or <= operators.\n *\n * Supported types: `undefined`, `number`, `bigint`, and `Date`.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n *\n * @returns {boolean} True if both values are of supported types.\n *\n * @throws {TypeError} If either value is of an unsupported type.\n * @memberOf module:decorator-validation\n */\nexport function isValidForGteOrLteComparison(a: any, b: any): boolean {\n  if (isSupported(a) && isSupported(b)) return true;\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n\n/**\n * @summary Compares two values to determine if the first is less than the second.\n * @description Supports numbers and dates. Throws an error for unsupported types.\n *\n * @param {any} a - The first value to compare.\n * @param {any} b - The second value to compare against.\n *\n * @returns {boolean} True if `a` is less than `b`, false otherwise.\n *\n * @throws {Error} If either `a` or `b` is `null` or `undefined`.\n * @throws {TypeError} If values are of mismatched or unsupported types.\n * @memberOf module:decorator-validation\n */\nexport function isLessThan(a: any, b: any): boolean {\n  if ([null, undefined].includes(a) || [null, undefined].includes(b))\n    throw new Error(COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);\n\n  // Validate type compatibility\n  const aType = typeof a;\n  const bType = typeof b;\n\n  if (aType !== bType) {\n    // Allow number X bigint\n    if (aType === \"bigint\" && bType === \"number\")\n      return Number(a) < (b as number);\n    if (aType === \"number\" && bType === \"bigint\")\n      return (a as number) < Number(b);\n    throw new TypeError(\n      sf(COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType)\n    );\n  }\n\n  if (\n    (aType === \"number\" && bType === \"number\") ||\n    (aType === \"bigint\" && bType === \"bigint\")\n  ) {\n    if (Number.isNaN(a) || Number.isNaN(b))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);\n    return a < b;\n  }\n\n  if (a instanceof Date && b instanceof Date) {\n    if (isNaN(a.getTime()) || isNaN(b.getTime()))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);\n    return a.getTime() < b.getTime();\n  }\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n\n/**\n * Checks if `a` is greater than `b`.\n * Supports comparison for numbers and Date objects.\n *\n * @param {any} a - The value to validate.\n * @param {any} b - The value to compare against.\n *\n * @returns {boolean} True if `a` is greater than `b`, otherwise false.\n *\n * @throws {Error} If either `a` or `b` is `null` or `undefined`.\n * @throws {TypeError} If values are of mismatched or unsupported types.\n * @memberOf module:decorator-validation\n */\nexport function isGreaterThan(a: any, b: any): boolean {\n  if ([null, undefined].includes(a) || [null, undefined].includes(b))\n    throw new Error(COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);\n\n  const aType = typeof a;\n  const bType = typeof b;\n\n  if (aType !== bType) {\n    // Allow number X bigint\n    if (aType === \"bigint\" && bType === \"number\")\n      return Number(a) > (b as number);\n    if (aType === \"number\" && bType === \"bigint\")\n      return (a as number) > Number(b);\n    throw new Error(\n      sf(COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType)\n    );\n  }\n\n  if (\n    (aType === \"number\" && bType === \"number\") ||\n    (aType === \"bigint\" && bType === \"bigint\")\n  ) {\n    if (Number.isNaN(a) || Number.isNaN(b))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);\n    return a > b;\n  }\n\n  if (a instanceof Date && b instanceof Date) {\n    if (isNaN(a.getTime()) || isNaN(b.getTime()))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);\n    return a.getTime() > b.getTime();\n  }\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/validation/Validators/utils.ts"],"names":[],"mappings":";;AA0GA,oEAUC;AAeD,gCAyCC;AAeD,sCAwCC;AAnOD,2DAA4D;AAC5D,mDAAiC;AAEjC,MAAM;AACN,8FAA8F;AAC9F,KAAK;AACL,mEAAmE;AACnE,KAAK;AACL,sFAAsF;AACtF,gIAAgI;AAChI,KAAK;AACL,0DAA0D;AAC1D,KAAK;AACL,sIAAsI;AACtI,2CAA2C;AAC3C,MAAM;AACN,iFAAiF;AACjF,oDAAoD;AACpD,yEAAyE;AACzE,MAAM;AACN,EAAE;AACF,6CAA6C;AAC7C,yDAAyD;AACzD,gDAAgD;AAChD,mDAAmD;AACnD,EAAE;AACF,oCAAoC;AACpC,mCAAmC;AACnC,4CAA4C;AAC5C,mEAAmE;AACnE,yBAAyB;AACzB,mFAAmF;AACnF,WAAW;AACX,QAAQ;AACR,EAAE;AACF,oDAAoD;AACpD,yBAAyB;AACzB,0EAA0E;AAC1E,WAAW;AACX,QAAQ;AACR,EAAE;AACF,8DAA8D;AAC9D,MAAM;AACN,EAAE;AACF,iCAAiC;AACjC,wCAAwC;AACxC,4CAA4C;AAC5C,EAAE;AACF,gCAAgC;AAChC,WAAW;AACX,iCAAiC;AACjC,4CAA4C;AAC5C,6BAA6B;AAC7B,UAAU;AACV,oEAAoE;AACpE,eAAe;AACf,iCAAiC;AACjC,4BAA4B;AAC5B,2DAA2D;AAC3D,gCAAgC;AAChC,uEAAuE;AACvE,2EAA2E;AAC3E,EAAE;AACF,wEAAwE;AACxE,QAAQ;AACR,MAAM;AACN,EAAE;AACF,8BAA8B;AAC9B,IAAI;AAEJ,MAAM,WAAW,GAAG,CAAC,KAAc,EAAU,EAAE;IAC7C,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,MAAM,CAAC;IAClC,IAAI,KAAK,YAAY,IAAI;QAAE,OAAO,MAAM,CAAC;IACzC,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IACtC,IAAI,KAAK,KAAK,QAAQ;QAAE,OAAO,UAAU,CAAC;IAC1C,IAAI,KAAK,KAAK,CAAC,QAAQ;QAAE,OAAO,WAAW,CAAC;IAC5C,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAAE,OAAO,OAAO,CAAC;IACzC,OAAO,OAAO,KAAK,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAClB,KAAc,EAC+B,EAAE;IAC/C,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,YAAY,IAAI;QAAE,OAAO,IAAI,CAAC;IAE9D,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAE3C,6DAA6D;IAC7D,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE7D,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF;;;;;;;;;;;;GAYG;AACH,SAAgB,4BAA4B,CAAC,CAAM,EAAE,CAAM;IACzD,IAAI,WAAW,CAAC,CAAC,CAAC,IAAI,WAAW,CAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAElD,MAAM,IAAI,SAAS,CACjB,IAAA,UAAE,EACA,qCAAyB,CAAC,4BAA4B,EACtD,WAAW,CAAC,CAAC,CAAC,EACd,WAAW,CAAC,CAAC,CAAC,CACf,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,UAAU,CAAC,CAAM,EAAE,CAAM;IACvC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAChE,MAAM,IAAI,KAAK,CAAC,qCAAyB,CAAC,4BAA4B,CAAC,CAAC;IAE1E,8BAA8B;IAC9B,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC;IACvB,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC;IAEvB,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;QACpB,wBAAwB;QACxB,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ;YAC1C,OAAO,MAAM,CAAC,CAAC,CAAC,GAAI,CAAY,CAAC;QACnC,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ;YAC1C,OAAQ,CAAY,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,IAAI,SAAS,CACjB,IAAA,UAAE,EAAC,qCAAyB,CAAC,wBAAwB,EAAE,KAAK,EAAE,KAAK,CAAC,CACrE,CAAC;IACJ,CAAC;IAED,IACE,CAAC,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,CAAC;QAC1C,CAAC,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,CAAC,EAC1C,CAAC;QACD,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACpC,MAAM,IAAI,SAAS,CAAC,qCAAyB,CAAC,cAAc,CAAC,CAAC;QAChE,OAAO,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IAED,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC;QAC3C,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAC1C,MAAM,IAAI,SAAS,CAAC,qCAAyB,CAAC,uBAAuB,CAAC,CAAC;QACzE,OAAO,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;IACnC,CAAC;IAED,MAAM,IAAI,SAAS,CACjB,IAAA,UAAE,EACA,qCAAyB,CAAC,4BAA4B,EACtD,WAAW,CAAC,CAAC,CAAC,EACd,WAAW,CAAC,CAAC,CAAC,CACf,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,aAAa,CAAC,CAAM,EAAE,CAAM;IAC1C,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAChE,MAAM,IAAI,KAAK,CAAC,qCAAyB,CAAC,4BAA4B,CAAC,CAAC;IAE1E,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC;IACvB,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC;IAEvB,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;QACpB,wBAAwB;QACxB,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ;YAC1C,OAAO,MAAM,CAAC,CAAC,CAAC,GAAI,CAAY,CAAC;QACnC,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ;YAC1C,OAAQ,CAAY,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,IAAI,KAAK,CACb,IAAA,UAAE,EAAC,qCAAyB,CAAC,wBAAwB,EAAE,KAAK,EAAE,KAAK,CAAC,CACrE,CAAC;IACJ,CAAC;IAED,IACE,CAAC,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,CAAC;QAC1C,CAAC,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,QAAQ,CAAC,EAC1C,CAAC;QACD,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACpC,MAAM,IAAI,SAAS,CAAC,qCAAyB,CAAC,cAAc,CAAC,CAAC;QAChE,OAAO,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IAED,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC;QAC3C,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;YAC1C,MAAM,IAAI,SAAS,CAAC,qCAAyB,CAAC,uBAAuB,CAAC,CAAC;QACzE,OAAO,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;IACnC,CAAC;IAED,MAAM,IAAI,SAAS,CACjB,IAAA,UAAE,EACA,qCAAyB,CAAC,4BAA4B,EACtD,WAAW,CAAC,CAAC,CAAC,EACd,WAAW,CAAC,CAAC,CAAC,CACf,CACF,CAAC;AACJ,CAAC","sourcesContent":["import { COMPARISON_ERROR_MESSAGES } from \"../../constants\";\nimport { sf } from \"../../utils\";\n\n// /**\n//  * Safely retrieves a nested property value from an object using a dot-notated path string.\n//  *\n//  * @template T - The expected return type of the property value.\n//  *\n//  * @param {Record<string, any>} obj - The source object to retrieve the value from.\n//  * @param {string} path - A dot-separated string representing the path to the desired property (e.g., \"user.address.street\").\n//  *\n//  * @returns {T} - The value found at the specified path\n//  *\n//  * @throws {Error} - Throws an error if the path is not a non-empty string or if any part of the path does not exist in the object.\n//  * @memberOf module:decorator-validation\n//  */\n// export function getValueByPath<T>(obj: Record<string, any>, path: string): T {\n//   if (typeof path !== \"string\" || !path.trim()) {\n//     throw new Error(sf(COMPARISON_ERROR_MESSAGES.INVALID_PATH, path));\n//   }\n//\n//   // Process parent directory access (../)\n//   const parentAccessors = path.match(/\\.\\.\\//g) || [];\n//   const parentLevel = parentAccessors.length;\n//   const cleanPath = path.replace(/\\.\\.\\//g, \"\");\n//\n//   // Navigate up the parent chain\n//   let currentContext: any = obj;\n//   for (let i = 0; i < parentLevel; i++) {\n//     if (!currentContext || typeof currentContext !== \"object\") {\n//       throw new Error(\n//         sf(COMPARISON_ERROR_MESSAGES.CONTEXT_NOT_OBJECT_COMPARISON, i + 1, path)\n//       );\n//     }\n//\n//     if (!currentContext[VALIDATION_PARENT_KEY]) {\n//       throw new Error(\n//         sf(COMPARISON_ERROR_MESSAGES.NO_PARENT_COMPARISON, i + 1, path)\n//       );\n//     }\n//\n//     currentContext = currentContext[VALIDATION_PARENT_KEY];\n//   }\n//\n//   // Process dot notation path\n//   const parts = cleanPath.split(\".\");\n//   let currentValue: any = currentContext;\n//\n//   for (const part of parts) {\n//     if (\n//       currentValue !== null &&\n//       typeof currentValue === \"object\" &&\n//       part in currentValue\n//     ) {\n//       currentValue = (currentValue as Record<string, any>)[part];\n//     } else {\n//       const errorMsgTemplate =\n//         parentLevel === 0\n//           ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND\n//           : parentLevel === 1\n//             ? COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_ON_PARENT\n//             : COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_AFTER_PARENT;\n//\n//       throw new Error(sf(errorMsgTemplate, path, part, parentLevel));\n//     }\n//   }\n//\n//   return currentValue as T;\n// }\n\nconst getTypeName = (value: unknown): string => {\n  if (value === null) return \"null\";\n  if (value instanceof Date) return \"Date\";\n  if (Number.isNaN(value)) return \"NaN\";\n  if (value === Infinity) return \"Infinity\";\n  if (value === -Infinity) return \"-Infinity\";\n  if (Array.isArray(value)) return \"array\";\n  return typeof value;\n};\n\nconst isSupported = (\n  value: unknown\n): value is undefined | number | bigint | Date => {\n  if (value === undefined || value instanceof Date) return true;\n\n  if (typeof value === \"bigint\") return true;\n\n  // Numbers must be finite (excludes NaN, Infinity, -Infinity)\n  if (typeof value === \"number\") return Number.isFinite(value);\n\n  return false;\n};\n\n/**\n * Validates whether two values are eligible for comparison using >= or <= operators.\n *\n * Supported types: `undefined`, `number`, `bigint`, and `Date`.\n *\n * @param a - The first value to compare.\n * @param b - The second value to compare.\n *\n * @returns {boolean} True if both values are of supported types.\n *\n * @throws {TypeError} If either value is of an unsupported type.\n * @memberOf module:decorator-validation\n */\nexport function isValidForGteOrLteComparison(a: any, b: any): boolean {\n  if (isSupported(a) && isSupported(b)) return true;\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n\n/**\n * @summary Compares two values to determine if the first is less than the second.\n * @description Supports numbers and dates. Throws an error for unsupported types.\n *\n * @param {any} a - The first value to compare.\n * @param {any} b - The second value to compare against.\n *\n * @returns {boolean} True if `a` is less than `b`, false otherwise.\n *\n * @throws {Error} If either `a` or `b` is `null` or `undefined`.\n * @throws {TypeError} If values are of mismatched or unsupported types.\n * @memberOf module:decorator-validation\n */\nexport function isLessThan(a: any, b: any): boolean {\n  if ([null, undefined].includes(a) || [null, undefined].includes(b))\n    throw new Error(COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);\n\n  // Validate type compatibility\n  const aType = typeof a;\n  const bType = typeof b;\n\n  if (aType !== bType) {\n    // Allow number X bigint\n    if (aType === \"bigint\" && bType === \"number\")\n      return Number(a) < (b as number);\n    if (aType === \"number\" && bType === \"bigint\")\n      return (a as number) < Number(b);\n    throw new TypeError(\n      sf(COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType)\n    );\n  }\n\n  if (\n    (aType === \"number\" && bType === \"number\") ||\n    (aType === \"bigint\" && bType === \"bigint\")\n  ) {\n    if (Number.isNaN(a) || Number.isNaN(b))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);\n    return a < b;\n  }\n\n  if (a instanceof Date && b instanceof Date) {\n    if (isNaN(a.getTime()) || isNaN(b.getTime()))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);\n    return a.getTime() < b.getTime();\n  }\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n\n/**\n * Checks if `a` is greater than `b`.\n * Supports comparison for numbers and Date objects.\n *\n * @param {any} a - The value to validate.\n * @param {any} b - The value to compare against.\n *\n * @returns {boolean} True if `a` is greater than `b`, otherwise false.\n *\n * @throws {Error} If either `a` or `b` is `null` or `undefined`.\n * @throws {TypeError} If values are of mismatched or unsupported types.\n * @memberOf module:decorator-validation\n */\nexport function isGreaterThan(a: any, b: any): boolean {\n  if ([null, undefined].includes(a) || [null, undefined].includes(b))\n    throw new Error(COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);\n\n  const aType = typeof a;\n  const bType = typeof b;\n\n  if (aType !== bType) {\n    // Allow number X bigint\n    if (aType === \"bigint\" && bType === \"number\")\n      return Number(a) > (b as number);\n    if (aType === \"number\" && bType === \"bigint\")\n      return (a as number) > Number(b);\n    throw new Error(\n      sf(COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType)\n    );\n  }\n\n  if (\n    (aType === \"number\" && bType === \"number\") ||\n    (aType === \"bigint\" && bType === \"bigint\")\n  ) {\n    if (Number.isNaN(a) || Number.isNaN(b))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);\n    return a > b;\n  }\n\n  if (a instanceof Date && b instanceof Date) {\n    if (isNaN(a.getTime()) || isNaN(b.getTime()))\n      throw new TypeError(COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);\n    return a.getTime() > b.getTime();\n  }\n\n  throw new TypeError(\n    sf(\n      COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON,\n      getTypeName(a),\n      getTypeName(b)\n    )\n  );\n}\n"]}
@@ -1,17 +1,3 @@
1
- /**
2
- * Safely retrieves a nested property value from an object using a dot-notated path string.
3
- *
4
- * @template T - The expected return type of the property value.
5
- *
6
- * @param {Record<string, any>} obj - The source object to retrieve the value from.
7
- * @param {string} path - A dot-separated string representing the path to the desired property (e.g., "user.address.street").
8
- *
9
- * @returns {T} - The value found at the specified path
10
- *
11
- * @throws {Error} - Throws an error if the path is not a non-empty string or if any part of the path does not exist in the object.
12
- * @memberOf module:decorator-validation
13
- */
14
- export declare function getValueByPath<T>(obj: Record<string, any>, path: string): T;
15
1
  /**
16
2
  * Validates whether two values are eligible for comparison using >= or <= operators.
17
3
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@decaf-ts/decorator-validation",
3
- "version": "1.7.3",
3
+ "version": "1.7.4",
4
4
  "description": "simple decorator based validation engine",
5
5
  "type": "module",
6
6
  "exports": {
@@ -60,7 +60,7 @@
60
60
  "ts"
61
61
  ],
62
62
  "author": "Tiago Venceslau",
63
- "license": "LGPL-3.0-or-later",
63
+ "license": "MIT",
64
64
  "bugs": {
65
65
  "url": "https://github.com/decaf-ts/decorator-validation/issues"
66
66
  },