@decaf-ts/decorator-validation 1.6.3 → 1.6.5
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.
- package/dist/decorator-validation.cjs +1016 -1164
- package/dist/decorator-validation.esm.cjs +971 -1134
- package/lib/constants/index.cjs +18 -0
- package/lib/constants/index.d.ts +1 -0
- package/lib/constants/validation.cjs +14 -0
- package/lib/constants/validation.d.ts +10 -0
- package/lib/esm/constants/index.d.ts +1 -0
- package/lib/esm/constants/index.js +2 -0
- package/lib/esm/constants/validation.d.ts +10 -0
- package/lib/esm/constants/validation.js +11 -0
- package/lib/esm/index.d.ts +37 -5
- package/lib/esm/index.js +38 -6
- package/lib/esm/model/Model.d.ts +29 -100
- package/lib/esm/model/Model.js +37 -104
- package/lib/esm/model/constants.d.ts +3 -3
- package/lib/esm/model/constants.js +4 -4
- package/lib/esm/model/construction.d.ts +3 -3
- package/lib/esm/model/construction.js +4 -4
- package/lib/esm/model/decorators.d.ts +4 -4
- package/lib/esm/model/decorators.js +5 -6
- package/lib/esm/model/types.d.ts +11 -30
- package/lib/esm/model/types.js +1 -1
- package/lib/esm/model/validation.d.ts +2 -2
- package/lib/esm/model/validation.js +18 -7
- package/lib/esm/utils/constants.d.ts +9 -27
- package/lib/esm/utils/constants.js +10 -28
- package/lib/esm/utils/dates.d.ts +16 -26
- package/lib/esm/utils/dates.js +17 -27
- package/lib/esm/utils/decorators.d.ts +0 -41
- package/lib/esm/utils/decorators.js +1 -42
- package/lib/esm/utils/hashing.d.ts +6 -50
- package/lib/esm/utils/hashing.js +5 -49
- package/lib/esm/utils/index.d.ts +0 -1
- package/lib/esm/utils/index.js +1 -2
- package/lib/esm/utils/registry.d.ts +2 -2
- package/lib/esm/utils/registry.js +1 -1
- package/lib/esm/utils/serialization.d.ts +1 -1
- package/lib/esm/utils/serialization.js +2 -2
- package/lib/esm/utils/strings.d.ts +4 -4
- package/lib/esm/utils/strings.js +5 -5
- package/lib/esm/utils/types.d.ts +16 -123
- package/lib/esm/utils/types.js +1 -1
- package/lib/esm/validation/Validators/DateValidator.d.ts +8 -40
- package/lib/esm/validation/Validators/DateValidator.js +9 -41
- package/lib/esm/validation/Validators/DiffValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/DiffValidator.js +58 -0
- package/lib/esm/validation/Validators/EmailValidator.d.ts +7 -39
- package/lib/esm/validation/Validators/EmailValidator.js +8 -40
- package/lib/esm/validation/Validators/EqualsValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/EqualsValidator.js +63 -0
- package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +65 -0
- package/lib/esm/validation/Validators/GreaterThanValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/GreaterThanValidator.js +62 -0
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +65 -0
- package/lib/esm/validation/Validators/LessThanValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/LessThanValidator.js +62 -0
- package/lib/esm/validation/Validators/ListValidator.d.ts +6 -44
- package/lib/esm/validation/Validators/ListValidator.js +7 -45
- package/lib/esm/validation/Validators/MaxValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/MaxValidator.js +7 -53
- package/lib/esm/validation/Validators/MinValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/MinValidator.js +7 -53
- package/lib/esm/validation/Validators/PatternValidator.d.ts +9 -75
- package/lib/esm/validation/Validators/PatternValidator.js +10 -76
- package/lib/esm/validation/Validators/RequiredValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/RequiredValidator.js +7 -53
- package/lib/esm/validation/Validators/TypeValidator.d.ts +6 -60
- package/lib/esm/validation/Validators/TypeValidator.js +7 -69
- package/lib/esm/validation/Validators/URLValidator.d.ts +7 -41
- package/lib/esm/validation/Validators/URLValidator.js +8 -42
- package/lib/esm/validation/Validators/Validator.d.ts +17 -77
- package/lib/esm/validation/Validators/Validator.js +11 -68
- package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +7 -1
- package/lib/esm/validation/Validators/ValidatorRegistry.js +11 -4
- package/lib/esm/validation/Validators/constants.d.ts +41 -0
- package/lib/esm/validation/Validators/constants.js +43 -1
- package/lib/esm/validation/Validators/index.d.ts +7 -0
- package/lib/esm/validation/Validators/index.js +8 -1
- package/lib/esm/validation/Validators/utils.d.ts +52 -0
- package/lib/esm/validation/Validators/utils.js +174 -0
- package/lib/esm/validation/decorators.d.ts +124 -50
- package/lib/esm/validation/decorators.js +173 -102
- package/lib/esm/validation/types.d.ts +46 -146
- package/lib/esm/validation/types.js +1 -1
- package/lib/index.cjs +39 -7
- package/lib/index.d.ts +37 -5
- package/lib/model/Model.cjs +39 -104
- package/lib/model/Model.d.ts +29 -100
- package/lib/model/constants.cjs +4 -4
- package/lib/model/constants.d.ts +3 -3
- package/lib/model/construction.cjs +4 -4
- package/lib/model/construction.d.ts +3 -3
- package/lib/model/decorators.cjs +5 -6
- package/lib/model/decorators.d.ts +4 -4
- package/lib/model/types.cjs +1 -1
- package/lib/model/types.d.ts +11 -30
- package/lib/model/validation.cjs +25 -14
- package/lib/model/validation.d.ts +2 -2
- package/lib/utils/constants.cjs +11 -29
- package/lib/utils/constants.d.ts +9 -27
- package/lib/utils/dates.cjs +17 -27
- package/lib/utils/dates.d.ts +16 -26
- package/lib/utils/decorators.cjs +1 -42
- package/lib/utils/decorators.d.ts +0 -41
- package/lib/utils/hashing.cjs +5 -49
- package/lib/utils/hashing.d.ts +6 -50
- package/lib/utils/index.cjs +1 -2
- package/lib/utils/index.d.ts +0 -1
- package/lib/utils/registry.cjs +1 -1
- package/lib/utils/registry.d.ts +2 -2
- package/lib/utils/serialization.cjs +2 -2
- package/lib/utils/serialization.d.ts +1 -1
- package/lib/utils/strings.cjs +5 -5
- package/lib/utils/strings.d.ts +4 -4
- package/lib/utils/types.cjs +1 -1
- package/lib/utils/types.d.ts +16 -123
- package/lib/validation/Validators/DateValidator.cjs +9 -41
- package/lib/validation/Validators/DateValidator.d.ts +8 -40
- package/lib/validation/Validators/DiffValidator.cjs +61 -0
- package/lib/validation/Validators/DiffValidator.d.ts +27 -0
- package/lib/validation/Validators/EmailValidator.cjs +8 -40
- package/lib/validation/Validators/EmailValidator.d.ts +7 -39
- package/lib/validation/Validators/EqualsValidator.cjs +66 -0
- package/lib/validation/Validators/EqualsValidator.d.ts +27 -0
- package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +68 -0
- package/lib/validation/Validators/GreaterThanOrEqualValidator.d.ts +27 -0
- package/lib/validation/Validators/GreaterThanValidator.cjs +65 -0
- package/lib/validation/Validators/GreaterThanValidator.d.ts +27 -0
- package/lib/validation/Validators/LessThanOrEqualValidator.cjs +68 -0
- package/lib/validation/Validators/LessThanOrEqualValidator.d.ts +27 -0
- package/lib/validation/Validators/LessThanValidator.cjs +65 -0
- package/lib/validation/Validators/LessThanValidator.d.ts +27 -0
- package/lib/validation/Validators/ListValidator.cjs +7 -45
- package/lib/validation/Validators/ListValidator.d.ts +6 -44
- package/lib/validation/Validators/MaxValidator.cjs +7 -53
- package/lib/validation/Validators/MaxValidator.d.ts +6 -52
- package/lib/validation/Validators/MinValidator.cjs +7 -53
- package/lib/validation/Validators/MinValidator.d.ts +6 -52
- package/lib/validation/Validators/PatternValidator.cjs +10 -76
- package/lib/validation/Validators/PatternValidator.d.ts +9 -75
- package/lib/validation/Validators/RequiredValidator.cjs +7 -53
- package/lib/validation/Validators/RequiredValidator.d.ts +6 -52
- package/lib/validation/Validators/TypeValidator.cjs +7 -69
- package/lib/validation/Validators/TypeValidator.d.ts +6 -60
- package/lib/validation/Validators/URLValidator.cjs +8 -42
- package/lib/validation/Validators/URLValidator.d.ts +7 -41
- package/lib/validation/Validators/Validator.cjs +11 -68
- package/lib/validation/Validators/Validator.d.ts +17 -77
- package/lib/validation/Validators/ValidatorRegistry.cjs +12 -4
- package/lib/validation/Validators/ValidatorRegistry.d.ts +7 -1
- package/lib/validation/Validators/constants.cjs +44 -2
- package/lib/validation/Validators/constants.d.ts +41 -0
- package/lib/validation/Validators/index.cjs +8 -1
- package/lib/validation/Validators/index.d.ts +7 -0
- package/lib/validation/Validators/utils.cjs +180 -0
- package/lib/validation/Validators/utils.d.ts +52 -0
- package/lib/validation/decorators.cjs +179 -102
- package/lib/validation/decorators.d.ts +124 -50
- package/lib/validation/types.cjs +1 -1
- package/lib/validation/types.d.ts +46 -146
- package/package.json +1 -1
- package/lib/esm/utils/Decoration.d.ts +0 -123
- package/lib/esm/utils/Decoration.js +0 -188
- package/lib/utils/Decoration.cjs +0 -192
- package/lib/utils/Decoration.d.ts +0 -123
|
@@ -1,3 +1,25 @@
|
|
|
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
|
|
13
|
+
* @category Validation
|
|
14
|
+
*/
|
|
15
|
+
export declare const ComparisonValidationKeys: {
|
|
16
|
+
readonly EQUALS: "equals";
|
|
17
|
+
readonly DIFF: "different";
|
|
18
|
+
readonly LESS_THAN: "lessThan";
|
|
19
|
+
readonly LESS_THAN_OR_EQUAL: "lessThanOrEqual";
|
|
20
|
+
readonly GREATER_THAN: "greaterThan";
|
|
21
|
+
readonly GREATER_THAN_OR_EQUAL: "greaterThanOrEqual";
|
|
22
|
+
};
|
|
1
23
|
/**
|
|
2
24
|
* @summary The keys used for validation
|
|
3
25
|
*
|
|
@@ -21,6 +43,12 @@
|
|
|
21
43
|
* @category Validation
|
|
22
44
|
*/
|
|
23
45
|
export declare const ValidationKeys: {
|
|
46
|
+
readonly EQUALS: "equals";
|
|
47
|
+
readonly DIFF: "different";
|
|
48
|
+
readonly LESS_THAN: "lessThan";
|
|
49
|
+
readonly LESS_THAN_OR_EQUAL: "lessThanOrEqual";
|
|
50
|
+
readonly GREATER_THAN: "greaterThan";
|
|
51
|
+
readonly GREATER_THAN_OR_EQUAL: "greaterThanOrEqual";
|
|
24
52
|
readonly REFLECT: "decaf.model.validation.";
|
|
25
53
|
readonly VALIDATOR: "validator";
|
|
26
54
|
readonly REQUIRED: "required";
|
|
@@ -81,6 +109,19 @@ export declare const DAYS_OF_WEEK_NAMES: string[];
|
|
|
81
109
|
* @category Validation
|
|
82
110
|
*/
|
|
83
111
|
export declare const DEFAULT_ERROR_MESSAGES: Record<string, string>;
|
|
112
|
+
export declare const COMPARISON_ERROR_MESSAGES: {
|
|
113
|
+
INVALID_PATH: string;
|
|
114
|
+
CONTEXT_NOT_OBJECT_COMPARISON: string;
|
|
115
|
+
NO_PARENT_COMPARISON: string;
|
|
116
|
+
PROPERTY_NOT_FOUND: string;
|
|
117
|
+
PROPERTY_NOT_FOUND_ON_PARENT: string;
|
|
118
|
+
PROPERTY_NOT_FOUND_AFTER_PARENT: string;
|
|
119
|
+
UNSUPPORTED_TYPES_COMPARISON: string;
|
|
120
|
+
NULL_OR_UNDEFINED_COMPARISON: string;
|
|
121
|
+
INVALID_DATE_COMPARISON: string;
|
|
122
|
+
TYPE_MISMATCH_COMPARISON: string;
|
|
123
|
+
NAN_COMPARISON: string;
|
|
124
|
+
};
|
|
84
125
|
/**
|
|
85
126
|
* @summary Defines the various default regexp patterns used
|
|
86
127
|
*
|
|
@@ -17,7 +17,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./constants.cjs"), exports);
|
|
18
18
|
__exportStar(require("./DateValidator.cjs"), exports);
|
|
19
19
|
__exportStar(require("./decorators.cjs"), exports);
|
|
20
|
+
__exportStar(require("./DiffValidator.cjs"), exports);
|
|
20
21
|
__exportStar(require("./EmailValidator.cjs"), exports);
|
|
22
|
+
__exportStar(require("./EqualsValidator.cjs"), exports);
|
|
23
|
+
__exportStar(require("./GreaterThanValidator.cjs"), exports);
|
|
24
|
+
__exportStar(require("./GreaterThanOrEqualValidator.cjs"), exports);
|
|
25
|
+
__exportStar(require("./LessThanValidator.cjs"), exports);
|
|
26
|
+
__exportStar(require("./LessThanOrEqualValidator.cjs"), exports);
|
|
21
27
|
__exportStar(require("./ListValidator.cjs"), exports);
|
|
22
28
|
__exportStar(require("./MaxLengthValidator.cjs"), exports);
|
|
23
29
|
__exportStar(require("./MaxValidator.cjs"), exports);
|
|
@@ -31,4 +37,5 @@ __exportStar(require("./TypeValidator.cjs"), exports);
|
|
|
31
37
|
__exportStar(require("./URLValidator.cjs"), exports);
|
|
32
38
|
__exportStar(require("./Validator.cjs"), exports);
|
|
33
39
|
__exportStar(require("./ValidatorRegistry.cjs"), exports);
|
|
34
|
-
|
|
40
|
+
__exportStar(require("./utils.cjs"), exports);
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdmFsaWRhdGlvbi9WYWxpZGF0b3JzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSw4Q0FBNEI7QUFDNUIsa0RBQWdDO0FBQ2hDLCtDQUE2QjtBQUM3QixrREFBZ0M7QUFDaEMsbURBQWlDO0FBQ2pDLG9EQUFrQztBQUNsQyx5REFBdUM7QUFDdkMsZ0VBQThDO0FBQzlDLHNEQUFvQztBQUNwQyw2REFBMkM7QUFDM0Msa0RBQWdDO0FBQ2hDLHVEQUFxQztBQUNyQyxpREFBK0I7QUFDL0IsdURBQXFDO0FBQ3JDLGlEQUErQjtBQUMvQixzREFBb0M7QUFDcEMscURBQW1DO0FBQ25DLHNEQUFvQztBQUNwQyxrREFBZ0M7QUFDaEMsa0RBQWdDO0FBQ2hDLGlEQUErQjtBQUMvQiw4Q0FBNEI7QUFDNUIsc0RBQW9DO0FBQ3BDLDBDQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbnN0YW50c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vRGF0ZVZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZGVjb3JhdG9yc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vRGlmZlZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vRW1haWxWYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0VxdWFsc1ZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vR3JlYXRlclRoYW5WYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0dyZWF0ZXJUaGFuT3JFcXVhbFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vTGVzc1RoYW5WYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL0xlc3NUaGFuT3JFcXVhbFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vTGlzdFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vTWF4TGVuZ3RoVmFsaWRhdG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9NYXhWYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL01pbkxlbmd0aFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vTWluVmFsaWRhdG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9QYXNzd29yZFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUGF0dGVyblZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vUmVxdWlyZWRWYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1N0ZXBWYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1R5cGVWYWxpZGF0b3JcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1VSTFZhbGlkYXRvclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vVmFsaWRhdG9yXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9WYWxpZGF0b3JSZWdpc3RyeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbHNcIjtcbiJdfQ==
|
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
export * from "./constants";
|
|
2
2
|
export * from "./DateValidator";
|
|
3
3
|
export * from "./decorators";
|
|
4
|
+
export * from "./DiffValidator";
|
|
4
5
|
export * from "./EmailValidator";
|
|
6
|
+
export * from "./EqualsValidator";
|
|
7
|
+
export * from "./GreaterThanValidator";
|
|
8
|
+
export * from "./GreaterThanOrEqualValidator";
|
|
9
|
+
export * from "./LessThanValidator";
|
|
10
|
+
export * from "./LessThanOrEqualValidator";
|
|
5
11
|
export * from "./ListValidator";
|
|
6
12
|
export * from "./MaxLengthValidator";
|
|
7
13
|
export * from "./MaxValidator";
|
|
@@ -15,3 +21,4 @@ export * from "./TypeValidator";
|
|
|
15
21
|
export * from "./URLValidator";
|
|
16
22
|
export * from "./Validator";
|
|
17
23
|
export * from "./ValidatorRegistry";
|
|
24
|
+
export * from "./utils";
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getValueByPath = getValueByPath;
|
|
4
|
+
exports.isValidForGteOrLteComparison = isValidForGteOrLteComparison;
|
|
5
|
+
exports.isLessThan = isLessThan;
|
|
6
|
+
exports.isGreaterThan = isGreaterThan;
|
|
7
|
+
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
|
+
*/
|
|
22
|
+
function getValueByPath(obj, path) {
|
|
23
|
+
if (typeof path !== "string" || !path.trim()) {
|
|
24
|
+
throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_PATH, path));
|
|
25
|
+
}
|
|
26
|
+
// Process parent directory access (../)
|
|
27
|
+
const parentAccessors = path.match(/\.\.\//g) || [];
|
|
28
|
+
const parentLevel = parentAccessors.length;
|
|
29
|
+
const cleanPath = path.replace(/\.\.\//g, "");
|
|
30
|
+
// Navigate up the parent chain
|
|
31
|
+
let currentContext = obj;
|
|
32
|
+
for (let i = 0; i < parentLevel; i++) {
|
|
33
|
+
if (!currentContext || typeof currentContext !== "object") {
|
|
34
|
+
throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.CONTEXT_NOT_OBJECT_COMPARISON, i + 1, path));
|
|
35
|
+
}
|
|
36
|
+
if (!currentContext[constants_1.VALIDATION_PARENT_KEY]) {
|
|
37
|
+
throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.NO_PARENT_COMPARISON, i + 1, path));
|
|
38
|
+
}
|
|
39
|
+
currentContext = currentContext[constants_1.VALIDATION_PARENT_KEY];
|
|
40
|
+
}
|
|
41
|
+
// Process dot notation path
|
|
42
|
+
const parts = cleanPath.split(".");
|
|
43
|
+
let currentValue = currentContext;
|
|
44
|
+
for (const part of parts) {
|
|
45
|
+
if (currentValue !== null &&
|
|
46
|
+
typeof currentValue === "object" &&
|
|
47
|
+
part in currentValue) {
|
|
48
|
+
currentValue = currentValue[part];
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
const errorMsgTemplate = parentLevel === 0
|
|
52
|
+
? constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND
|
|
53
|
+
: parentLevel === 1
|
|
54
|
+
? constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_ON_PARENT
|
|
55
|
+
: constants_2.COMPARISON_ERROR_MESSAGES.PROPERTY_NOT_FOUND_AFTER_PARENT;
|
|
56
|
+
throw new Error((0, strings_1.sf)(errorMsgTemplate, path, part, parentLevel));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return currentValue;
|
|
60
|
+
}
|
|
61
|
+
const getTypeName = (value) => {
|
|
62
|
+
if (value === null)
|
|
63
|
+
return "null";
|
|
64
|
+
if (value instanceof Date)
|
|
65
|
+
return "Date";
|
|
66
|
+
if (Number.isNaN(value))
|
|
67
|
+
return "NaN";
|
|
68
|
+
if (value === Infinity)
|
|
69
|
+
return "Infinity";
|
|
70
|
+
if (value === -Infinity)
|
|
71
|
+
return "-Infinity";
|
|
72
|
+
if (Array.isArray(value))
|
|
73
|
+
return "array";
|
|
74
|
+
return typeof value;
|
|
75
|
+
};
|
|
76
|
+
const isSupported = (value) => {
|
|
77
|
+
if (value === undefined || value instanceof Date)
|
|
78
|
+
return true;
|
|
79
|
+
if (typeof value === "bigint")
|
|
80
|
+
return true;
|
|
81
|
+
// Numbers must be finite (excludes NaN, Infinity, -Infinity)
|
|
82
|
+
if (typeof value === "number")
|
|
83
|
+
return Number.isFinite(value);
|
|
84
|
+
return false;
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Validates whether two values are eligible for comparison using >= or <= operators.
|
|
88
|
+
*
|
|
89
|
+
* Supported types: `undefined`, `number`, `bigint`, and `Date`.
|
|
90
|
+
*
|
|
91
|
+
* @param a - The first value to compare.
|
|
92
|
+
* @param b - The second value to compare.
|
|
93
|
+
*
|
|
94
|
+
* @returns {boolean} True if both values are of supported types.
|
|
95
|
+
*
|
|
96
|
+
* @throws {TypeError} If either value is of an unsupported type.
|
|
97
|
+
*/
|
|
98
|
+
function isValidForGteOrLteComparison(a, b) {
|
|
99
|
+
if (isSupported(a) && isSupported(b))
|
|
100
|
+
return true;
|
|
101
|
+
throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* @summary Compares two values to determine if the first is less than the second.
|
|
105
|
+
* @description Supports numbers and dates. Throws an error for unsupported types.
|
|
106
|
+
*
|
|
107
|
+
* @param {any} a - The first value to compare.
|
|
108
|
+
* @param {any} b - The second value to compare against.
|
|
109
|
+
*
|
|
110
|
+
* @returns {boolean} True if `a` is less than `b`, false otherwise.
|
|
111
|
+
*
|
|
112
|
+
* @throws {Error} If either `a` or `b` is `null` or `undefined`.
|
|
113
|
+
* @throws {TypeError} If values are of mismatched or unsupported types.
|
|
114
|
+
*/
|
|
115
|
+
function isLessThan(a, b) {
|
|
116
|
+
if ([null, undefined].includes(a) || [null, undefined].includes(b))
|
|
117
|
+
throw new Error(constants_2.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
|
|
118
|
+
// Validate type compatibility
|
|
119
|
+
const aType = typeof a;
|
|
120
|
+
const bType = typeof b;
|
|
121
|
+
if (aType !== bType) {
|
|
122
|
+
// Allow number X bigint
|
|
123
|
+
if (aType === "bigint" && bType === "number")
|
|
124
|
+
return Number(a) < b;
|
|
125
|
+
if (aType === "number" && bType === "bigint")
|
|
126
|
+
return a < Number(b);
|
|
127
|
+
throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
|
|
128
|
+
}
|
|
129
|
+
if ((aType === "number" && bType === "number") ||
|
|
130
|
+
(aType === "bigint" && bType === "bigint")) {
|
|
131
|
+
if (Number.isNaN(a) || Number.isNaN(b))
|
|
132
|
+
throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
|
|
133
|
+
return a < b;
|
|
134
|
+
}
|
|
135
|
+
if (a instanceof Date && b instanceof Date) {
|
|
136
|
+
if (isNaN(a.getTime()) || isNaN(b.getTime()))
|
|
137
|
+
throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
|
|
138
|
+
return a.getTime() < b.getTime();
|
|
139
|
+
}
|
|
140
|
+
throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Checks if `a` is greater than `b`.
|
|
144
|
+
* Supports comparison for numbers and Date objects.
|
|
145
|
+
*
|
|
146
|
+
* @param {any} a - The value to validate.
|
|
147
|
+
* @param {any} b - The value to compare against.
|
|
148
|
+
*
|
|
149
|
+
* @returns {boolean} True if `a` is greater than `b`, otherwise false.
|
|
150
|
+
*
|
|
151
|
+
* @throws {Error} If either `a` or `b` is `null` or `undefined`.
|
|
152
|
+
* @throws {TypeError} If values are of mismatched or unsupported types.
|
|
153
|
+
*/
|
|
154
|
+
function isGreaterThan(a, b) {
|
|
155
|
+
if ([null, undefined].includes(a) || [null, undefined].includes(b))
|
|
156
|
+
throw new Error(constants_2.COMPARISON_ERROR_MESSAGES.NULL_OR_UNDEFINED_COMPARISON);
|
|
157
|
+
const aType = typeof a;
|
|
158
|
+
const bType = typeof b;
|
|
159
|
+
if (aType !== bType) {
|
|
160
|
+
// Allow number X bigint
|
|
161
|
+
if (aType === "bigint" && bType === "number")
|
|
162
|
+
return Number(a) > b;
|
|
163
|
+
if (aType === "number" && bType === "bigint")
|
|
164
|
+
return a > Number(b);
|
|
165
|
+
throw new Error((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.TYPE_MISMATCH_COMPARISON, aType, bType));
|
|
166
|
+
}
|
|
167
|
+
if ((aType === "number" && bType === "number") ||
|
|
168
|
+
(aType === "bigint" && bType === "bigint")) {
|
|
169
|
+
if (Number.isNaN(a) || Number.isNaN(b))
|
|
170
|
+
throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.NAN_COMPARISON);
|
|
171
|
+
return a > b;
|
|
172
|
+
}
|
|
173
|
+
if (a instanceof Date && b instanceof Date) {
|
|
174
|
+
if (isNaN(a.getTime()) || isNaN(b.getTime()))
|
|
175
|
+
throw new TypeError(constants_2.COMPARISON_ERROR_MESSAGES.INVALID_DATE_COMPARISON);
|
|
176
|
+
return a.getTime() > b.getTime();
|
|
177
|
+
}
|
|
178
|
+
throw new TypeError((0, strings_1.sf)(constants_2.COMPARISON_ERROR_MESSAGES.UNSUPPORTED_TYPES_COMPARISON, getTypeName(a), getTypeName(b)));
|
|
179
|
+
}
|
|
180
|
+
//# 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 */\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 */\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 */\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 */\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"]}
|
|
@@ -0,0 +1,52 @@
|
|
|
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
|
+
*/
|
|
13
|
+
export declare function getValueByPath<T>(obj: Record<string, any>, path: string): T;
|
|
14
|
+
/**
|
|
15
|
+
* Validates whether two values are eligible for comparison using >= or <= operators.
|
|
16
|
+
*
|
|
17
|
+
* Supported types: `undefined`, `number`, `bigint`, and `Date`.
|
|
18
|
+
*
|
|
19
|
+
* @param a - The first value to compare.
|
|
20
|
+
* @param b - The second value to compare.
|
|
21
|
+
*
|
|
22
|
+
* @returns {boolean} True if both values are of supported types.
|
|
23
|
+
*
|
|
24
|
+
* @throws {TypeError} If either value is of an unsupported type.
|
|
25
|
+
*/
|
|
26
|
+
export declare function isValidForGteOrLteComparison(a: any, b: any): boolean;
|
|
27
|
+
/**
|
|
28
|
+
* @summary Compares two values to determine if the first is less than the second.
|
|
29
|
+
* @description Supports numbers and dates. Throws an error for unsupported types.
|
|
30
|
+
*
|
|
31
|
+
* @param {any} a - The first value to compare.
|
|
32
|
+
* @param {any} b - The second value to compare against.
|
|
33
|
+
*
|
|
34
|
+
* @returns {boolean} True if `a` is less than `b`, false otherwise.
|
|
35
|
+
*
|
|
36
|
+
* @throws {Error} If either `a` or `b` is `null` or `undefined`.
|
|
37
|
+
* @throws {TypeError} If values are of mismatched or unsupported types.
|
|
38
|
+
*/
|
|
39
|
+
export declare function isLessThan(a: any, b: any): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Checks if `a` is greater than `b`.
|
|
42
|
+
* Supports comparison for numbers and Date objects.
|
|
43
|
+
*
|
|
44
|
+
* @param {any} a - The value to validate.
|
|
45
|
+
* @param {any} b - The value to compare against.
|
|
46
|
+
*
|
|
47
|
+
* @returns {boolean} True if `a` is greater than `b`, otherwise false.
|
|
48
|
+
*
|
|
49
|
+
* @throws {Error} If either `a` or `b` is `null` or `undefined`.
|
|
50
|
+
* @throws {TypeError} If values are of mismatched or unsupported types.
|
|
51
|
+
*/
|
|
52
|
+
export declare function isGreaterThan(a: any, b: any): boolean;
|