@decaf-ts/decorator-validation 1.6.2 → 1.6.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.
- 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 +31 -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 +31 -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
|
@@ -14,77 +14,50 @@ exports.date = date;
|
|
|
14
14
|
exports.password = password;
|
|
15
15
|
exports.list = list;
|
|
16
16
|
exports.set = set;
|
|
17
|
+
exports.eq = eq;
|
|
18
|
+
exports.diff = diff;
|
|
19
|
+
exports.lt = lt;
|
|
20
|
+
exports.lte = lte;
|
|
21
|
+
exports.gt = gt;
|
|
22
|
+
exports.gte = gte;
|
|
17
23
|
require("reflect-metadata");
|
|
18
24
|
const constants_1 = require("./Validators/constants.cjs");
|
|
19
25
|
const strings_1 = require("../utils/strings.cjs");
|
|
20
26
|
const dates_1 = require("../utils/dates.cjs");
|
|
21
27
|
const decorators_1 = require("../utils/decorators.cjs");
|
|
22
28
|
const Validation_1 = require("./Validation.cjs");
|
|
23
|
-
const Decoration_1 = require("../utils/Decoration.cjs");
|
|
24
29
|
/**
|
|
25
|
-
* @
|
|
26
|
-
* @
|
|
27
|
-
* Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.
|
|
28
|
-
* This decorator is commonly used as the first validation step for important fields.
|
|
30
|
+
* @summary Marks the property as required.
|
|
31
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
29
32
|
*
|
|
30
|
-
* @param {string} [message]
|
|
31
|
-
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
33
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
32
34
|
*
|
|
33
35
|
* @function required
|
|
34
|
-
* @category Decorators
|
|
35
|
-
*
|
|
36
|
-
* @example
|
|
37
|
-
* ```typescript
|
|
38
|
-
* class User {
|
|
39
|
-
* @required()
|
|
40
|
-
* username: string;
|
|
41
36
|
*
|
|
42
|
-
*
|
|
43
|
-
* email: string;
|
|
44
|
-
* }
|
|
45
|
-
* ```
|
|
37
|
+
* @category Decorators
|
|
46
38
|
*/
|
|
47
39
|
function required(message = constants_1.DEFAULT_ERROR_MESSAGES.REQUIRED) {
|
|
48
|
-
|
|
49
|
-
return Decoration_1.Decoration.for(key)
|
|
50
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
40
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.REQUIRED), {
|
|
51
41
|
message: message,
|
|
52
|
-
})
|
|
53
|
-
.apply();
|
|
42
|
+
});
|
|
54
43
|
}
|
|
55
44
|
/**
|
|
56
|
-
* @
|
|
57
|
-
* @
|
|
58
|
-
* Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.
|
|
59
|
-
* This decorator works with numeric values and dates.
|
|
45
|
+
* @summary Defines a minimum value for the property
|
|
46
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
60
47
|
*
|
|
61
|
-
* @param {number | Date
|
|
62
|
-
* @param {string} [message]
|
|
63
|
-
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
48
|
+
* @param {number | Date} value
|
|
49
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
64
50
|
*
|
|
65
51
|
* @function min
|
|
52
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
66
53
|
* @category Decorators
|
|
67
|
-
*
|
|
68
|
-
* @example
|
|
69
|
-
* ```typescript
|
|
70
|
-
* class Product {
|
|
71
|
-
* @min(0)
|
|
72
|
-
* price: number;
|
|
73
|
-
*
|
|
74
|
-
* @min(new Date(2023, 0, 1), "Date must be after January 1, 2023")
|
|
75
|
-
* releaseDate: Date;
|
|
76
|
-
* }
|
|
77
|
-
* ```
|
|
78
54
|
*/
|
|
79
55
|
function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
|
|
80
|
-
|
|
81
|
-
return Decoration_1.Decoration.for(key)
|
|
82
|
-
.define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN), {
|
|
56
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN), {
|
|
83
57
|
[constants_1.ValidationKeys.MIN]: value,
|
|
84
58
|
message: message,
|
|
85
59
|
types: [Number.name, Date.name],
|
|
86
|
-
})
|
|
87
|
-
.apply();
|
|
60
|
+
});
|
|
88
61
|
}
|
|
89
62
|
/**
|
|
90
63
|
* @summary Defines a maximum value for the property
|
|
@@ -94,17 +67,15 @@ function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
|
|
|
94
67
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
95
68
|
*
|
|
96
69
|
* @function max
|
|
70
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
97
71
|
* @category Decorators
|
|
98
72
|
*/
|
|
99
73
|
function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
|
|
100
|
-
|
|
101
|
-
return Decoration_1.Decoration.for(key)
|
|
102
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
74
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MAX), {
|
|
103
75
|
[constants_1.ValidationKeys.MAX]: value,
|
|
104
76
|
message: message,
|
|
105
77
|
types: [Number.name, Date.name],
|
|
106
|
-
})
|
|
107
|
-
.apply();
|
|
78
|
+
});
|
|
108
79
|
}
|
|
109
80
|
/**
|
|
110
81
|
* @summary Defines a step value for the property
|
|
@@ -114,17 +85,15 @@ function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
|
|
|
114
85
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
115
86
|
*
|
|
116
87
|
* @function step
|
|
88
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
117
89
|
* @category Decorators
|
|
118
90
|
*/
|
|
119
91
|
function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
|
|
120
|
-
|
|
121
|
-
return Decoration_1.Decoration.for(key)
|
|
122
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
92
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.STEP), {
|
|
123
93
|
[constants_1.ValidationKeys.STEP]: value,
|
|
124
94
|
message: message,
|
|
125
95
|
types: [Number.name],
|
|
126
|
-
})
|
|
127
|
-
.apply();
|
|
96
|
+
});
|
|
128
97
|
}
|
|
129
98
|
/**
|
|
130
99
|
* @summary Defines a minimum length for the property
|
|
@@ -134,17 +103,15 @@ function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
|
|
|
134
103
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
135
104
|
*
|
|
136
105
|
* @function minlength
|
|
106
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
137
107
|
* @category Decorators
|
|
138
108
|
*/
|
|
139
109
|
function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
|
|
140
|
-
|
|
141
|
-
return Decoration_1.Decoration.for(key)
|
|
142
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
110
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MIN_LENGTH), {
|
|
143
111
|
[constants_1.ValidationKeys.MIN_LENGTH]: value,
|
|
144
112
|
message: message,
|
|
145
113
|
types: [String.name, Array.name, Set.name],
|
|
146
|
-
})
|
|
147
|
-
.apply();
|
|
114
|
+
});
|
|
148
115
|
}
|
|
149
116
|
/**
|
|
150
117
|
* @summary Defines a maximum length for the property
|
|
@@ -154,17 +121,15 @@ function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGT
|
|
|
154
121
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
155
122
|
*
|
|
156
123
|
* @function maxlength
|
|
124
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
157
125
|
* @category Decorators
|
|
158
126
|
*/
|
|
159
127
|
function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
|
|
160
|
-
|
|
161
|
-
return Decoration_1.Decoration.for(key)
|
|
162
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
128
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.MAX_LENGTH), {
|
|
163
129
|
[constants_1.ValidationKeys.MAX_LENGTH]: value,
|
|
164
130
|
message: message,
|
|
165
131
|
types: [String.name, Array.name, Set.name],
|
|
166
|
-
})
|
|
167
|
-
.apply();
|
|
132
|
+
});
|
|
168
133
|
}
|
|
169
134
|
/**
|
|
170
135
|
* @summary Defines a RegExp pattern the property must respect
|
|
@@ -174,17 +139,15 @@ function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGT
|
|
|
174
139
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
175
140
|
*
|
|
176
141
|
* @function pattern
|
|
142
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
177
143
|
* @category Decorators
|
|
178
144
|
*/
|
|
179
145
|
function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
|
|
180
|
-
|
|
181
|
-
return Decoration_1.Decoration.for(key)
|
|
182
|
-
.define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN), {
|
|
146
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PATTERN), {
|
|
183
147
|
[constants_1.ValidationKeys.PATTERN]: typeof value === "string" ? value : value.toString(),
|
|
184
148
|
message: message,
|
|
185
149
|
types: [String.name],
|
|
186
|
-
})
|
|
187
|
-
.apply();
|
|
150
|
+
});
|
|
188
151
|
}
|
|
189
152
|
/**
|
|
190
153
|
* @summary Defines the property as an email
|
|
@@ -193,17 +156,15 @@ function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
|
|
|
193
156
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
194
157
|
*
|
|
195
158
|
* @function email
|
|
159
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
196
160
|
* @category Decorators
|
|
197
161
|
*/
|
|
198
162
|
function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
|
|
199
|
-
|
|
200
|
-
return Decoration_1.Decoration.for(key)
|
|
201
|
-
.define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL), {
|
|
163
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EMAIL), {
|
|
202
164
|
[constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.EMAIL,
|
|
203
165
|
message: message,
|
|
204
166
|
types: [String.name],
|
|
205
|
-
})
|
|
206
|
-
.apply();
|
|
167
|
+
});
|
|
207
168
|
}
|
|
208
169
|
/**
|
|
209
170
|
* @summary Defines the property as an URL
|
|
@@ -212,17 +173,15 @@ function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
|
|
|
212
173
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
213
174
|
*
|
|
214
175
|
* @function url
|
|
176
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
215
177
|
* @category Decorators
|
|
216
178
|
*/
|
|
217
179
|
function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
|
|
218
|
-
|
|
219
|
-
return Decoration_1.Decoration.for(key)
|
|
220
|
-
.define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.URL), {
|
|
180
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.URL), {
|
|
221
181
|
[constants_1.ValidationKeys.PATTERN]: constants_1.DEFAULT_PATTERNS.URL,
|
|
222
182
|
message: message,
|
|
223
183
|
types: [String.name],
|
|
224
|
-
})
|
|
225
|
-
.apply();
|
|
184
|
+
});
|
|
226
185
|
}
|
|
227
186
|
/**
|
|
228
187
|
* @summary Enforces type verification
|
|
@@ -232,16 +191,14 @@ function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
|
|
|
232
191
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
233
192
|
*
|
|
234
193
|
* @function type
|
|
194
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
235
195
|
* @category Decorators
|
|
236
196
|
*/
|
|
237
197
|
function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
|
|
238
|
-
|
|
239
|
-
return Decoration_1.Decoration.for(key)
|
|
240
|
-
.define((0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.TYPE), {
|
|
198
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.TYPE), {
|
|
241
199
|
customTypes: types,
|
|
242
200
|
message: message,
|
|
243
|
-
})
|
|
244
|
-
.apply();
|
|
201
|
+
});
|
|
245
202
|
}
|
|
246
203
|
/**
|
|
247
204
|
* @summary Date Handler Decorator
|
|
@@ -251,15 +208,16 @@ function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
|
|
|
251
208
|
*
|
|
252
209
|
* @param {string} format accepted format according to {@link formatDate}
|
|
253
210
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
|
|
211
|
+
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
|
|
254
212
|
*
|
|
255
213
|
* @function date
|
|
256
214
|
*
|
|
215
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
257
216
|
* @category Decorators
|
|
258
217
|
*/
|
|
259
218
|
function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGES.DATE) {
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
(0, decorators_1.propMetadata)(key, {
|
|
219
|
+
return (target, propertyKey) => {
|
|
220
|
+
(0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.DATE), {
|
|
263
221
|
[constants_1.ValidationKeys.FORMAT]: format,
|
|
264
222
|
message: message,
|
|
265
223
|
types: [Date.name],
|
|
@@ -292,28 +250,26 @@ function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGE
|
|
|
292
250
|
},
|
|
293
251
|
});
|
|
294
252
|
};
|
|
295
|
-
return Decoration_1.Decoration.for(key).define(dateDec).apply();
|
|
296
253
|
}
|
|
297
254
|
/**
|
|
298
255
|
* @summary Password Handler Decorator
|
|
299
256
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
|
300
257
|
*
|
|
301
|
-
* @param {RegExp} [pattern] defaults to {@link
|
|
258
|
+
* @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
|
|
302
259
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
|
|
260
|
+
* @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
|
|
303
261
|
*
|
|
304
262
|
* @function password
|
|
305
263
|
*
|
|
264
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
306
265
|
* @category Decorators
|
|
307
266
|
*/
|
|
308
267
|
function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = constants_1.DEFAULT_ERROR_MESSAGES.PASSWORD) {
|
|
309
|
-
|
|
310
|
-
return Decoration_1.Decoration.for(key)
|
|
311
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
268
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.PASSWORD), {
|
|
312
269
|
[constants_1.ValidationKeys.PATTERN]: pattern,
|
|
313
270
|
message: message,
|
|
314
271
|
types: [String.name],
|
|
315
|
-
})
|
|
316
|
-
.apply();
|
|
272
|
+
});
|
|
317
273
|
}
|
|
318
274
|
/**
|
|
319
275
|
* @summary List Decorator
|
|
@@ -322,20 +278,19 @@ function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_E
|
|
|
322
278
|
* @param {ModelConstructor} clazz
|
|
323
279
|
* @param {string} [collection] The collection being used. defaults to Array
|
|
324
280
|
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
281
|
+
* @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
|
|
325
282
|
*
|
|
326
283
|
* @function list
|
|
327
284
|
*
|
|
285
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
328
286
|
* @category Decorators
|
|
329
287
|
*/
|
|
330
288
|
function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_MESSAGES.LIST) {
|
|
331
|
-
|
|
332
|
-
return Decoration_1.Decoration.for(key)
|
|
333
|
-
.define((0, decorators_1.propMetadata)(key, {
|
|
289
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LIST), {
|
|
334
290
|
clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
|
|
335
291
|
type: collection,
|
|
336
292
|
message: message,
|
|
337
|
-
})
|
|
338
|
-
.apply();
|
|
293
|
+
});
|
|
339
294
|
}
|
|
340
295
|
/**
|
|
341
296
|
* @summary Set Decorator
|
|
@@ -343,12 +298,134 @@ function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_M
|
|
|
343
298
|
*
|
|
344
299
|
* @param {ModelConstructor} clazz
|
|
345
300
|
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
301
|
+
* @param {Constructor<Validator>} [validator]
|
|
346
302
|
*
|
|
347
303
|
* @function set
|
|
348
304
|
*
|
|
305
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
349
306
|
* @category Decorators
|
|
350
307
|
*/
|
|
351
308
|
function set(clazz, message = constants_1.DEFAULT_ERROR_MESSAGES.LIST) {
|
|
352
309
|
return list(clazz, "Set", message);
|
|
353
310
|
}
|
|
354
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport { ValidationMetadata } from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\nimport { Decoration } from \"../utils/Decoration\";\n\n/**\n * @description Property decorator that marks a field as required\n * @summary Marks the property as required, causing validation to fail if the property is undefined, null, or empty.\n * Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.\n * This decorator is commonly used as the first validation step for important fields.\n *\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function required\n * @category Decorators\n *\n * @example\n * ```typescript\n * class User {\n *   @required()\n *   username: string;\n *\n *   @required(\"Email address is mandatory\")\n *   email: string;\n * }\n * ```\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  const key = Validation.key(ValidationKeys.REQUIRED);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @description Property decorator that enforces a minimum value constraint\n * @summary Defines a minimum value for the property, causing validation to fail if the property value is less than the specified minimum.\n * Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.\n * This decorator works with numeric values and dates.\n *\n * @param {number | Date | string} value - The minimum value allowed. For dates, can be a Date object or a string that can be converted to a date\n * @param {string} [message] - The error message to display when validation fails. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n * @return {PropertyDecorator} A decorator function that can be applied to class properties\n *\n * @function min\n * @category Decorators\n *\n * @example\n * ```typescript\n * class Product {\n *   @min(0)\n *   price: number;\n *\n *   @min(new Date(2023, 0, 1), \"Date must be after January 1, 2023\")\n *   releaseDate: Date;\n * }\n * ```\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  const key = Validation.key(ValidationKeys.MIN);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.MIN), {\n        [ValidationKeys.MIN]: value,\n        message: message,\n        types: [Number.name, Date.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @category Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  const key = Validation.key(ValidationKeys.MAX);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MAX]: value,\n        message: message,\n        types: [Number.name, Date.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @category Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  const key = Validation.key(ValidationKeys.STEP);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.STEP]: value,\n        message: message,\n        types: [Number.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @category Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MIN_LENGTH);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MIN_LENGTH]: value,\n        message: message,\n        types: [String.name, Array.name, Set.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @category Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  const key = Validation.key(ValidationKeys.MAX_LENGTH);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(key, {\n        [ValidationKeys.MAX_LENGTH]: value,\n        message: message,\n        types: [String.name, Array.name, Set.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @category Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  const key = Validation.key(ValidationKeys.PATTERN);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.PATTERN), {\n        [ValidationKeys.PATTERN]:\n          typeof value === \"string\" ? value : value.toString(),\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @category Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  const key = Validation.key(ValidationKeys.EMAIL);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.EMAIL), {\n        [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @category Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  const key = Validation.key(ValidationKeys.URL);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.URL), {\n        [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @category Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  const key = Validation.key(ValidationKeys.TYPE);\n  return Decoration.for(key)\n    .define(\n      propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.TYPE), {\n        customTypes: types,\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n *\n * @function date\n *\n * @category Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  const key = Validation.key(ValidationKeys.DATE);\n  const dateDec = (target: Record<string, any>, propertyKey?: any): any => {\n    propMetadata(key, {\n      [ValidationKeys.FORMAT]: format,\n      message: message,\n      types: [Date.name],\n    })(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n  return Decoration.for(key).define(dateDec).apply();\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link DEFAULT_PATTERNS#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n *\n * @function password\n *\n * @category Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  const key = Validation.key(ValidationKeys.PASSWORD);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        [ValidationKeys.PATTERN]: pattern,\n        message: message,\n        types: [String.name],\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function list\n *\n * @category Decorators\n */\nexport function list(\n  clazz: ModelConstructor<any> | ModelConstructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  const key = Validation.key(ValidationKeys.LIST);\n  return Decoration.for(key)\n    .define(\n      propMetadata(key, {\n        clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n        type: collection,\n        message: message,\n      })\n    )\n    .apply();\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n *\n * @function set\n *\n * @category Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n"]}
|
|
311
|
+
/**
|
|
312
|
+
* @summary Declares that the decorated property must be equal to another specified property.
|
|
313
|
+
* @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.
|
|
314
|
+
*
|
|
315
|
+
* @param {string} propertyToCompare - The name of the property to compare equality against.
|
|
316
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.
|
|
317
|
+
*
|
|
318
|
+
* @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.
|
|
319
|
+
*
|
|
320
|
+
* @function eq
|
|
321
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
322
|
+
* @category Decorators
|
|
323
|
+
*/
|
|
324
|
+
function eq(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.EQUALS) {
|
|
325
|
+
const options = {
|
|
326
|
+
message: message,
|
|
327
|
+
propertyToCompare: propertyToCompare,
|
|
328
|
+
};
|
|
329
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.EQUALS), options);
|
|
330
|
+
}
|
|
331
|
+
/**
|
|
332
|
+
* @summary Declares that the decorated property must be different from another specified property.
|
|
333
|
+
* @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.
|
|
334
|
+
*
|
|
335
|
+
* @param {string} propertyToCompare - The name of the property to compare difference against.
|
|
336
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.
|
|
337
|
+
*
|
|
338
|
+
* @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.
|
|
339
|
+
*
|
|
340
|
+
* @function diff
|
|
341
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
342
|
+
* @category Decorators
|
|
343
|
+
*/
|
|
344
|
+
function diff(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.DIFF) {
|
|
345
|
+
const options = {
|
|
346
|
+
message: message,
|
|
347
|
+
propertyToCompare: propertyToCompare,
|
|
348
|
+
};
|
|
349
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.DIFF), options);
|
|
350
|
+
}
|
|
351
|
+
/**
|
|
352
|
+
* @summary Declares that the decorated property must be less than another specified property.
|
|
353
|
+
* @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.
|
|
354
|
+
*
|
|
355
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
356
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.
|
|
357
|
+
*
|
|
358
|
+
* @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.
|
|
359
|
+
*
|
|
360
|
+
* @function lt
|
|
361
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
362
|
+
* @category Decorators
|
|
363
|
+
*/
|
|
364
|
+
function lt(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.LESS_THAN) {
|
|
365
|
+
const options = {
|
|
366
|
+
message: message,
|
|
367
|
+
propertyToCompare: propertyToCompare,
|
|
368
|
+
};
|
|
369
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN), options);
|
|
370
|
+
}
|
|
371
|
+
/**
|
|
372
|
+
* @summary Declares that the decorated property must be equal or less than another specified property.
|
|
373
|
+
* @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.
|
|
374
|
+
*
|
|
375
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
376
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.
|
|
377
|
+
*
|
|
378
|
+
* @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.
|
|
379
|
+
*
|
|
380
|
+
* @function lte
|
|
381
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
382
|
+
* @category Decorators
|
|
383
|
+
*/
|
|
384
|
+
function lte(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL) {
|
|
385
|
+
const options = {
|
|
386
|
+
message: message,
|
|
387
|
+
propertyToCompare: propertyToCompare,
|
|
388
|
+
};
|
|
389
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.LESS_THAN_OR_EQUAL), options);
|
|
390
|
+
}
|
|
391
|
+
/**
|
|
392
|
+
* @summary Declares that the decorated property must be greater than another specified property.
|
|
393
|
+
* @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.
|
|
394
|
+
*
|
|
395
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
396
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.
|
|
397
|
+
*
|
|
398
|
+
* @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.
|
|
399
|
+
*
|
|
400
|
+
* @function gt
|
|
401
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
402
|
+
* @category Decorators
|
|
403
|
+
*/
|
|
404
|
+
function gt(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.GREATER_THAN) {
|
|
405
|
+
const options = {
|
|
406
|
+
message: message,
|
|
407
|
+
propertyToCompare: propertyToCompare,
|
|
408
|
+
};
|
|
409
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN), options);
|
|
410
|
+
}
|
|
411
|
+
/**
|
|
412
|
+
* @summary Declares that the decorated property must be equal or greater than another specified property.
|
|
413
|
+
* @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.
|
|
414
|
+
*
|
|
415
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
416
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.
|
|
417
|
+
*
|
|
418
|
+
* @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.
|
|
419
|
+
*
|
|
420
|
+
* @function gte
|
|
421
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
422
|
+
* @category Decorators
|
|
423
|
+
*/
|
|
424
|
+
function gte(propertyToCompare, message = constants_1.DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL) {
|
|
425
|
+
const options = {
|
|
426
|
+
message: message,
|
|
427
|
+
propertyToCompare: propertyToCompare,
|
|
428
|
+
};
|
|
429
|
+
return (0, decorators_1.propMetadata)(Validation_1.Validation.key(constants_1.ValidationKeys.GREATER_THAN_OR_EQUAL), options);
|
|
430
|
+
}
|
|
431
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/validation/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import \"reflect-metadata\";\nimport { type ComparisonValidatorOptions, ValidationMetadata } from \"./types\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { ModelConstructor } from \"../model/types\";\nimport { parseDate } from \"../utils/dates\";\nimport { propMetadata } from \"../utils/decorators\";\nimport { Validation } from \"./Validation\";\n\n/**\n * @summary Marks the property as required.\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}\n *\n * @function required\n *\n * @category Decorators\n */\nexport function required(message: string = DEFAULT_ERROR_MESSAGES.REQUIRED) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.REQUIRED),\n    {\n      message: message,\n    }\n  );\n}\n\n/**\n * @summary Defines a minimum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}\n *\n * @function min\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function min(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.MIN), {\n    [ValidationKeys.MIN]: value,\n    message: message,\n    types: [Number.name, Date.name],\n  });\n}\n\n/**\n * @summary Defines a maximum value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}\n *\n * @param {number | Date} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}\n *\n * @function max\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function max(\n  value: number | Date | string,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.MAX), {\n    [ValidationKeys.MAX]: value,\n    message: message,\n    types: [Number.name, Date.name],\n  });\n}\n\n/**\n * @summary Defines a step value for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}\n *\n * @param {number} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}\n *\n * @function step\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function step(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.STEP\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.STEP), {\n    [ValidationKeys.STEP]: value,\n    message: message,\n    types: [Number.name],\n  });\n}\n\n/**\n * @summary Defines a minimum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}\n *\n * @function minlength\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function minlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MIN_LENGTH\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.MIN_LENGTH),\n    {\n      [ValidationKeys.MIN_LENGTH]: value,\n      message: message,\n      types: [String.name, Array.name, Set.name],\n    }\n  );\n}\n\n/**\n * @summary Defines a maximum length for the property\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}\n *\n * @function maxlength\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function maxlength(\n  value: number,\n  message: string = DEFAULT_ERROR_MESSAGES.MAX_LENGTH\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.MAX_LENGTH),\n    {\n      [ValidationKeys.MAX_LENGTH]: value,\n      message: message,\n      types: [String.name, Array.name, Set.name],\n    }\n  );\n}\n\n/**\n * @summary Defines a RegExp pattern the property must respect\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}\n *\n * @param {string} value\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}\n *\n * @function pattern\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function pattern(\n  value: RegExp | string,\n  message: string = DEFAULT_ERROR_MESSAGES.PATTERN\n) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.PATTERN),\n    {\n      [ValidationKeys.PATTERN]:\n        typeof value === \"string\" ? value : value.toString(),\n      message: message,\n      types: [String.name],\n    }\n  );\n}\n\n/**\n * @summary Defines the property as an email\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}\n *\n * @function email\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function email(message: string = DEFAULT_ERROR_MESSAGES.EMAIL) {\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.EMAIL),\n    {\n      [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.EMAIL,\n      message: message,\n      types: [String.name],\n    }\n  );\n}\n\n/**\n * @summary Defines the property as an URL\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}\n *\n * @function url\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function url(message: string = DEFAULT_ERROR_MESSAGES.URL) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.URL), {\n    [ValidationKeys.PATTERN]: DEFAULT_PATTERNS.URL,\n    message: message,\n    types: [String.name],\n  });\n}\n\n/**\n * @summary Enforces type verification\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}\n *\n * @param {string[] | string} types accepted types\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}\n *\n * @function type\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function type(\n  types: string[] | string,\n  message: string = DEFAULT_ERROR_MESSAGES.TYPE\n) {\n  return propMetadata<ValidationMetadata>(Validation.key(ValidationKeys.TYPE), {\n    customTypes: types,\n    message: message,\n  });\n}\n\n/**\n * @summary Date Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}\n *\n * Will enforce serialization according to the selected format\n *\n * @param {string} format accepted format according to {@link formatDate}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}\n * @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}\n *\n * @function date\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function date(\n  format: string = \"dd/MM/yyyy\",\n  message: string = DEFAULT_ERROR_MESSAGES.DATE\n) {\n  return (target: Record<string, any>, propertyKey?: any): any => {\n    propMetadata(Validation.key(ValidationKeys.DATE), {\n      [ValidationKeys.FORMAT]: format,\n      message: message,\n      types: [Date.name],\n    })(target, propertyKey);\n\n    const values = new WeakMap();\n\n    Object.defineProperty(target, propertyKey, {\n      configurable: false,\n      set(this: any, newValue: string | Date) {\n        const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);\n        if (!descriptor || descriptor.configurable)\n          Object.defineProperty(this, propertyKey, {\n            enumerable: true,\n            configurable: false,\n            get: () => values.get(this),\n            set: (newValue: string | Date | number) => {\n              let val: Date | undefined;\n              try {\n                val = parseDate(format, newValue);\n                values.set(this, val);\n              } catch (e: any) {\n                console.error(sf(\"Failed to parse date: {0}\", e.message || e));\n              }\n            },\n          });\n        this[propertyKey] = newValue;\n      },\n      get() {\n        console.log(\"here\");\n      },\n    });\n  };\n}\n\n/**\n * @summary Password Handler Decorator\n * @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}\n *\n * @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}\n * @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}\n *\n * @function password\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function password(\n  pattern: RegExp = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH,\n  message: string = DEFAULT_ERROR_MESSAGES.PASSWORD\n) {\n  return propMetadata(Validation.key(ValidationKeys.PASSWORD), {\n    [ValidationKeys.PATTERN]: pattern,\n    message: message,\n    types: [String.name],\n  });\n}\n\n/**\n * @summary List Decorator\n * @description Also sets the {@link type} to the provided collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [collection] The collection being used. defaults to Array\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n * @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}\n *\n * @function list\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function list(\n  clazz: ModelConstructor<any> | ModelConstructor<any>[],\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return propMetadata(Validation.key(ValidationKeys.LIST), {\n    clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],\n    type: collection,\n    message: message,\n  });\n}\n\n/**\n * @summary Set Decorator\n * @description Wrapper for {@link list} with the 'Set' Collection\n *\n * @param {ModelConstructor} clazz\n * @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}\n * @param {Constructor<Validator>} [validator]\n *\n * @function set\n *\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function set(\n  clazz: ModelConstructor<any>,\n  message: string = DEFAULT_ERROR_MESSAGES.LIST\n) {\n  return list(clazz, \"Set\", message);\n}\n\n/**\n * @summary Declares that the decorated property must be equal to another specified property.\n * @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare equality against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.\n *\n * @function eq\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function eq(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.EQUALS\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.EQUALS),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be different from another specified property.\n * @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare difference against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.\n *\n * @function diff\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function diff(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.DIFF\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.DIFF),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.\n *\n * @function lt\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function lt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.LESS_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or less than another specified property.\n * @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.\n *\n * @function lte\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function lte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.LESS_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.\n *\n * @function gt\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function gt(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.GREATER_THAN),\n    options as ValidationMetadata\n  );\n}\n\n/**\n * @summary Declares that the decorated property must be equal or greater than another specified property.\n * @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.\n *\n * @param {string} propertyToCompare - The name of the property to compare against.\n * @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.\n *\n * @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.\n *\n * @function gte\n * @memberOf module:decorator-validation.Decorators.Validation\n * @category Decorators\n */\nexport function gte(\n  propertyToCompare: string,\n  message: string = DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL\n) {\n  const options: ComparisonValidatorOptions = {\n    message: message,\n    propertyToCompare: propertyToCompare,\n  };\n\n  return propMetadata<ValidationMetadata>(\n    Validation.key(ValidationKeys.GREATER_THAN_OR_EQUAL),\n    options as ValidationMetadata\n  );\n}\n"]}
|