@decaf-ts/decorator-validation 1.0.7 → 1.0.11
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.bundle.min.js +1 -1
- package/dist/esm/decorator-validation.bundle.min.esm.js +1 -1
- package/lib/esm/index.d.ts +6 -1
- package/lib/esm/index.js +68 -1
- package/lib/esm/model/Model.d.ts +3 -1
- package/lib/esm/model/Model.js +316 -1
- package/lib/esm/model/ModelErrorDefinition.d.ts +1 -1
- package/lib/esm/model/ModelErrorDefinition.js +55 -3
- package/lib/esm/model/Registry.d.ts +1 -1
- package/lib/esm/model/Registry.js +76 -1
- package/lib/esm/model/constants.js +44 -1
- package/lib/esm/model/construction.js +124 -1
- package/lib/esm/model/decorators.d.ts +3 -3
- package/lib/esm/model/decorators.js +68 -1
- package/lib/esm/model/index.d.ts +3 -3
- package/lib/esm/model/index.js +9 -1
- package/lib/esm/model/types.js +3 -0
- package/lib/esm/reflection/decorators.d.ts +15 -0
- package/lib/esm/reflection/decorators.js +28 -0
- package/lib/esm/reflection/index.d.ts +2 -0
- package/lib/esm/reflection/index.js +4 -0
- package/lib/esm/{utils/general.d.ts → reflection/utils.d.ts} +7 -87
- package/lib/esm/reflection/utils.js +239 -0
- package/lib/esm/utils/constants.js +25 -1
- package/lib/esm/utils/dates.d.ts +76 -0
- package/lib/esm/utils/dates.js +241 -0
- package/lib/esm/utils/equality.d.ts +14 -0
- package/lib/esm/utils/equality.js +34 -0
- package/lib/esm/utils/hashing.d.ts +42 -0
- package/lib/esm/utils/hashing.js +73 -0
- package/lib/esm/utils/index.d.ts +6 -2
- package/lib/esm/utils/index.js +10 -1
- package/lib/esm/utils/registry.js +3 -0
- package/lib/esm/utils/serialization.js +53 -1
- package/lib/esm/utils/strings.d.ts +25 -0
- package/lib/esm/utils/strings.js +31 -0
- package/lib/esm/validation/Validation.d.ts +2 -1
- package/lib/esm/validation/Validation.js +63 -1
- package/lib/esm/validation/Validators/DateValidator.js +55 -1
- package/lib/esm/validation/Validators/EmailValidator.d.ts +0 -1
- package/lib/esm/validation/Validators/EmailValidator.js +49 -1
- package/lib/esm/validation/Validators/ListValidator.js +67 -1
- package/lib/esm/validation/Validators/MaxLengthValidator.js +55 -1
- package/lib/esm/validation/Validators/MaxValidator.js +59 -1
- package/lib/esm/validation/Validators/MinLengthValidator.js +55 -1
- package/lib/esm/validation/Validators/MinValidator.js +59 -1
- package/lib/esm/validation/Validators/PasswordValidator.js +52 -1
- package/lib/esm/validation/Validators/PatternValidator.d.ts +3 -3
- package/lib/esm/validation/Validators/PatternValidator.js +72 -1
- package/lib/esm/validation/Validators/RequiredValidator.js +57 -1
- package/lib/esm/validation/Validators/StepValidator.js +54 -1
- package/lib/esm/validation/Validators/TypeValidator.js +42 -1
- package/lib/esm/validation/Validators/URLValidator.d.ts +0 -1
- package/lib/esm/validation/Validators/URLValidator.js +48 -1
- package/lib/esm/validation/Validators/Validator.js +50 -1
- package/lib/esm/validation/Validators/ValidatorRegistry.js +81 -1
- package/lib/esm/validation/Validators/constants.d.ts +8 -4
- package/lib/esm/validation/Validators/constants.js +135 -1
- package/lib/esm/validation/Validators/decorators.d.ts +13 -0
- package/lib/esm/validation/Validators/decorators.js +23 -0
- package/lib/esm/validation/Validators/index.d.ts +9 -7
- package/lib/esm/validation/Validators/index.js +54 -1
- package/lib/esm/validation/Validators/types.d.ts +2 -2
- package/lib/esm/validation/Validators/types.js +3 -0
- package/lib/esm/validation/decorators.d.ts +14 -87
- package/lib/esm/validation/decorators.js +320 -1
- package/lib/esm/validation/index.d.ts +1 -10
- package/lib/esm/validation/index.js +6 -1
- package/lib/esm/validation/types.d.ts +11 -0
- package/lib/esm/validation/types.js +3 -0
- package/lib/index.cjs +85 -1
- package/lib/index.d.ts +6 -1
- package/lib/model/Model.cjs +321 -1
- package/lib/model/Model.d.ts +3 -1
- package/lib/model/ModelErrorDefinition.cjs +59 -3
- package/lib/model/ModelErrorDefinition.d.ts +1 -1
- package/lib/model/Registry.cjs +81 -1
- package/lib/model/Registry.d.ts +1 -1
- package/lib/model/constants.cjs +47 -1
- package/lib/model/construction.cjs +129 -1
- package/lib/model/decorators.cjs +73 -1
- package/lib/model/decorators.d.ts +3 -3
- package/lib/model/index.cjs +25 -1
- package/lib/model/index.d.ts +3 -3
- package/lib/model/types.cjs +4 -1
- package/lib/reflection/decorators.cjs +31 -0
- package/lib/reflection/decorators.d.ts +15 -0
- package/lib/reflection/index.cjs +20 -0
- package/lib/reflection/index.d.ts +2 -0
- package/lib/reflection/utils.cjs +251 -0
- package/lib/{utils/general.d.ts → reflection/utils.d.ts} +7 -87
- package/lib/utils/constants.cjs +28 -1
- package/lib/utils/dates.cjs +249 -0
- package/lib/utils/dates.d.ts +76 -0
- package/lib/utils/equality.cjs +37 -0
- package/lib/utils/equality.d.ts +14 -0
- package/lib/utils/hashing.cjs +78 -0
- package/lib/utils/hashing.d.ts +42 -0
- package/lib/utils/index.cjs +26 -1
- package/lib/utils/index.d.ts +6 -2
- package/lib/utils/registry.cjs +4 -1
- package/lib/utils/serialization.cjs +57 -1
- package/lib/utils/strings.cjs +35 -0
- package/lib/utils/strings.d.ts +25 -0
- package/lib/validation/Validation.cjs +67 -1
- package/lib/validation/Validation.d.ts +2 -1
- package/lib/validation/Validators/DateValidator.cjs +58 -1
- package/lib/validation/Validators/EmailValidator.cjs +52 -1
- package/lib/validation/Validators/EmailValidator.d.ts +0 -1
- package/lib/validation/Validators/ListValidator.cjs +70 -1
- package/lib/validation/Validators/MaxLengthValidator.cjs +58 -1
- package/lib/validation/Validators/MaxValidator.cjs +62 -1
- package/lib/validation/Validators/MinLengthValidator.cjs +58 -1
- package/lib/validation/Validators/MinValidator.cjs +62 -1
- package/lib/validation/Validators/PasswordValidator.cjs +55 -1
- package/lib/validation/Validators/PatternValidator.cjs +75 -1
- package/lib/validation/Validators/PatternValidator.d.ts +3 -3
- package/lib/validation/Validators/RequiredValidator.cjs +60 -1
- package/lib/validation/Validators/StepValidator.cjs +57 -1
- package/lib/validation/Validators/TypeValidator.cjs +46 -1
- package/lib/validation/Validators/URLValidator.cjs +51 -1
- package/lib/validation/Validators/URLValidator.d.ts +0 -1
- package/lib/validation/Validators/Validator.cjs +54 -1
- package/lib/validation/Validators/ValidatorRegistry.cjs +86 -1
- package/lib/validation/Validators/constants.cjs +138 -1
- package/lib/validation/Validators/constants.d.ts +8 -4
- package/lib/validation/Validators/decorators.cjs +26 -0
- package/lib/validation/Validators/decorators.d.ts +13 -0
- package/lib/validation/Validators/index.cjs +71 -1
- package/lib/validation/Validators/index.d.ts +9 -7
- package/lib/validation/Validators/types.cjs +4 -1
- package/lib/validation/Validators/types.d.ts +2 -2
- package/lib/validation/decorators.cjs +337 -1
- package/lib/validation/decorators.d.ts +14 -87
- package/lib/validation/index.cjs +22 -1
- package/lib/validation/index.d.ts +1 -10
- package/lib/validation/types.cjs +4 -1
- package/lib/validation/types.d.ts +11 -0
- package/package.json +17 -13
- package/lib/esm/utils/general.js +0 -1
- package/lib/utils/general.cjs +0 -1
|
@@ -1 +1,337 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getValidationKey = getValidationKey;
|
|
4
|
+
exports.required = required;
|
|
5
|
+
exports.min = min;
|
|
6
|
+
exports.max = max;
|
|
7
|
+
exports.step = step;
|
|
8
|
+
exports.minlength = minlength;
|
|
9
|
+
exports.maxlength = maxlength;
|
|
10
|
+
exports.pattern = pattern;
|
|
11
|
+
exports.email = email;
|
|
12
|
+
exports.url = url;
|
|
13
|
+
exports.type = type;
|
|
14
|
+
exports.date = date;
|
|
15
|
+
exports.password = password;
|
|
16
|
+
exports.list = list;
|
|
17
|
+
exports.set = set;
|
|
18
|
+
require("reflect-metadata");
|
|
19
|
+
const ListValidator_1 = require("./Validators/ListValidator/index.cjs");
|
|
20
|
+
const Validation_1 = require("./Validation/index.cjs");
|
|
21
|
+
const decorators_1 = require("../reflection/decorators/index.cjs");
|
|
22
|
+
const constants_1 = require("./Validators/constants/index.cjs");
|
|
23
|
+
const strings_1 = require("../utils/strings/index.cjs");
|
|
24
|
+
const PasswordValidator_1 = require("./Validators/PasswordValidator/index.cjs");
|
|
25
|
+
const utils_1 = require("../utils/index.cjs");
|
|
26
|
+
/**
|
|
27
|
+
* @summary Builds the key to store as Metadata under Reflections
|
|
28
|
+
* @description concatenates {@link ValidationKeys#REFLECT} with the provided key
|
|
29
|
+
*
|
|
30
|
+
* @param {string} key
|
|
31
|
+
*
|
|
32
|
+
* @function getModelKey
|
|
33
|
+
* @memberOf module:decorator-validation.Utils
|
|
34
|
+
* @category Utilities
|
|
35
|
+
*/
|
|
36
|
+
function getValidationKey(key) {
|
|
37
|
+
return constants_1.ValidationKeys.REFLECT + key;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* @summary Marks the property as required.
|
|
41
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
42
|
+
*
|
|
43
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
44
|
+
*
|
|
45
|
+
* @function required
|
|
46
|
+
*
|
|
47
|
+
* @category Decorators
|
|
48
|
+
*/
|
|
49
|
+
function required(message = constants_1.DEFAULT_ERROR_MESSAGES.REQUIRED) {
|
|
50
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.REQUIRED), {
|
|
51
|
+
message: message,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* @summary Defines a minimum value for the property
|
|
56
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
57
|
+
*
|
|
58
|
+
* @param {number | Date} value
|
|
59
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
60
|
+
*
|
|
61
|
+
* @function min
|
|
62
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
63
|
+
* @category Decorators
|
|
64
|
+
*/
|
|
65
|
+
function min(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN) {
|
|
66
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.MIN), {
|
|
67
|
+
value: value,
|
|
68
|
+
message: message,
|
|
69
|
+
types: [Number.name, Date.name],
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* @summary Defines a maximum value for the property
|
|
74
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}
|
|
75
|
+
*
|
|
76
|
+
* @param {number | Date} value
|
|
77
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
78
|
+
*
|
|
79
|
+
* @function max
|
|
80
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
81
|
+
* @category Decorators
|
|
82
|
+
*/
|
|
83
|
+
function max(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX) {
|
|
84
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.MAX), {
|
|
85
|
+
value: value,
|
|
86
|
+
message: message,
|
|
87
|
+
types: [Number.name, Date.name],
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* @summary Defines a step value for the property
|
|
92
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}
|
|
93
|
+
*
|
|
94
|
+
* @param {number} value
|
|
95
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
96
|
+
*
|
|
97
|
+
* @function step
|
|
98
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
99
|
+
* @category Decorators
|
|
100
|
+
*/
|
|
101
|
+
function step(value, message = constants_1.DEFAULT_ERROR_MESSAGES.STEP) {
|
|
102
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.STEP), {
|
|
103
|
+
value: value,
|
|
104
|
+
message: message,
|
|
105
|
+
types: [Number.name],
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* @summary Defines a minimum length for the property
|
|
110
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}
|
|
111
|
+
*
|
|
112
|
+
* @param {string} value
|
|
113
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
114
|
+
*
|
|
115
|
+
* @function minlength
|
|
116
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
117
|
+
* @category Decorators
|
|
118
|
+
*/
|
|
119
|
+
function minlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
|
|
120
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.MIN_LENGTH), {
|
|
121
|
+
value: value,
|
|
122
|
+
message: message,
|
|
123
|
+
types: [String.name, Array.name, Set.name],
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* @summary Defines a maximum length for the property
|
|
128
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}
|
|
129
|
+
*
|
|
130
|
+
* @param {string} value
|
|
131
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
132
|
+
*
|
|
133
|
+
* @function maxlength
|
|
134
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
135
|
+
* @category Decorators
|
|
136
|
+
*/
|
|
137
|
+
function maxlength(value, message = constants_1.DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
|
|
138
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.MAX_LENGTH), {
|
|
139
|
+
value: value,
|
|
140
|
+
message: message,
|
|
141
|
+
types: [String.name, Array.name, Set.name],
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* @summary Defines a RegExp pattern the property must respect
|
|
146
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}
|
|
147
|
+
*
|
|
148
|
+
* @param {string} value
|
|
149
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
150
|
+
*
|
|
151
|
+
* @function pattern
|
|
152
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
153
|
+
* @category Decorators
|
|
154
|
+
*/
|
|
155
|
+
function pattern(value, message = constants_1.DEFAULT_ERROR_MESSAGES.PATTERN) {
|
|
156
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.PATTERN), {
|
|
157
|
+
value: typeof value === "string" ? value : value.toString(),
|
|
158
|
+
message: message,
|
|
159
|
+
types: [String.name],
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* @summary Defines the property as an email
|
|
164
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}
|
|
165
|
+
*
|
|
166
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
167
|
+
*
|
|
168
|
+
* @function email
|
|
169
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
170
|
+
* @category Decorators
|
|
171
|
+
*/
|
|
172
|
+
function email(message = constants_1.DEFAULT_ERROR_MESSAGES.EMAIL) {
|
|
173
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.EMAIL), {
|
|
174
|
+
message: message,
|
|
175
|
+
types: [String.name],
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* @summary Defines the property as an URL
|
|
180
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}
|
|
181
|
+
*
|
|
182
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
183
|
+
*
|
|
184
|
+
* @function url
|
|
185
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
186
|
+
* @category Decorators
|
|
187
|
+
*/
|
|
188
|
+
function url(message = constants_1.DEFAULT_ERROR_MESSAGES.URL) {
|
|
189
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.URL), {
|
|
190
|
+
message: message,
|
|
191
|
+
types: [String.name],
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* @summary Enforces type verification
|
|
196
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
|
|
197
|
+
*
|
|
198
|
+
* @param {string[] | string} types accepted types
|
|
199
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
200
|
+
*
|
|
201
|
+
* @function type
|
|
202
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
203
|
+
* @category Decorators
|
|
204
|
+
*/
|
|
205
|
+
function type(types, message = constants_1.DEFAULT_ERROR_MESSAGES.TYPE) {
|
|
206
|
+
return (0, decorators_1.metadata)(getValidationKey(constants_1.ValidationKeys.TYPE), {
|
|
207
|
+
customTypes: types,
|
|
208
|
+
message: message,
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* @summary Date Handler Decorator
|
|
213
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
|
|
214
|
+
*
|
|
215
|
+
* Will enforce serialization according to the selected format
|
|
216
|
+
*
|
|
217
|
+
* @param {string} format accepted format according to {@link formatDate}
|
|
218
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
|
|
219
|
+
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
|
|
220
|
+
*
|
|
221
|
+
* @function date
|
|
222
|
+
*
|
|
223
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
224
|
+
* @category Decorators
|
|
225
|
+
*/
|
|
226
|
+
function date(format = "dd/MM/yyyy", message = constants_1.DEFAULT_ERROR_MESSAGES.DATE) {
|
|
227
|
+
return (target, propertyKey) => {
|
|
228
|
+
Reflect.defineMetadata(getValidationKey(constants_1.ValidationKeys.DATE), {
|
|
229
|
+
format: format,
|
|
230
|
+
message: message,
|
|
231
|
+
types: [Date.name],
|
|
232
|
+
}, target, propertyKey);
|
|
233
|
+
const values = new WeakMap();
|
|
234
|
+
Object.defineProperty(target, propertyKey, {
|
|
235
|
+
configurable: false,
|
|
236
|
+
set(newValue) {
|
|
237
|
+
const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);
|
|
238
|
+
if (!descriptor || descriptor.configurable)
|
|
239
|
+
Object.defineProperty(this, propertyKey, {
|
|
240
|
+
enumerable: true,
|
|
241
|
+
configurable: false,
|
|
242
|
+
get: () => values.get(this),
|
|
243
|
+
set: (newValue) => {
|
|
244
|
+
let val;
|
|
245
|
+
try {
|
|
246
|
+
val = (0, utils_1.parseDate)(format, newValue);
|
|
247
|
+
values.set(this, val);
|
|
248
|
+
}
|
|
249
|
+
catch (e) {
|
|
250
|
+
console.error((0, strings_1.sf)("Failed to parse date: {0}", e.message || e));
|
|
251
|
+
}
|
|
252
|
+
},
|
|
253
|
+
});
|
|
254
|
+
this[propertyKey] = newValue;
|
|
255
|
+
},
|
|
256
|
+
get() {
|
|
257
|
+
console.log("here");
|
|
258
|
+
},
|
|
259
|
+
});
|
|
260
|
+
};
|
|
261
|
+
}
|
|
262
|
+
/**
|
|
263
|
+
* @summary Password Handler Decorator
|
|
264
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
|
265
|
+
*
|
|
266
|
+
* @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
|
|
267
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
|
|
268
|
+
* @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
|
|
269
|
+
*
|
|
270
|
+
* @function password
|
|
271
|
+
*
|
|
272
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
273
|
+
* @category Decorators
|
|
274
|
+
*/
|
|
275
|
+
function password(pattern = constants_1.DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = constants_1.DEFAULT_ERROR_MESSAGES.PASSWORD, validator = PasswordValidator_1.PasswordValidator) {
|
|
276
|
+
return (target, propertyKey) => {
|
|
277
|
+
Reflect.defineMetadata(getValidationKey(constants_1.ValidationKeys.PASSWORD), {
|
|
278
|
+
pattern: pattern,
|
|
279
|
+
message: message,
|
|
280
|
+
types: [String.name],
|
|
281
|
+
}, target, propertyKey);
|
|
282
|
+
Validation_1.Validation.register({
|
|
283
|
+
validator: validator,
|
|
284
|
+
validationKey: constants_1.ValidationKeys.PASSWORD,
|
|
285
|
+
save: true,
|
|
286
|
+
});
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* @summary List Decorator
|
|
291
|
+
* @description Also sets the {@link type} to the provided collection
|
|
292
|
+
*
|
|
293
|
+
* @param {ModelConstructor} clazz
|
|
294
|
+
* @param {string} [collection] The collection being used. defaults to Array
|
|
295
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
296
|
+
* @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
|
|
297
|
+
*
|
|
298
|
+
* @function list
|
|
299
|
+
*
|
|
300
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
301
|
+
* @category Decorators
|
|
302
|
+
*/
|
|
303
|
+
function list(clazz, collection = "Array", message = constants_1.DEFAULT_ERROR_MESSAGES.LIST, validator = ListValidator_1.ListValidator) {
|
|
304
|
+
return (target, propertyKey) => {
|
|
305
|
+
type(collection)(target, propertyKey);
|
|
306
|
+
Reflect.defineMetadata(getValidationKey(constants_1.ValidationKeys.LIST), {
|
|
307
|
+
class: clazz.name,
|
|
308
|
+
type: collection,
|
|
309
|
+
message: message,
|
|
310
|
+
}, target, propertyKey);
|
|
311
|
+
Validation_1.Validation.register({
|
|
312
|
+
validator: validator,
|
|
313
|
+
validationKey: constants_1.ValidationKeys.LIST,
|
|
314
|
+
save: true,
|
|
315
|
+
});
|
|
316
|
+
};
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* @summary Set Decorator
|
|
320
|
+
* @description Wrapper for {@link list} with the 'Set' Collection
|
|
321
|
+
*
|
|
322
|
+
* @param {ModelConstructor} clazz
|
|
323
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
324
|
+
* @param {Constructor<Validator>} [validator]
|
|
325
|
+
*
|
|
326
|
+
* @function set
|
|
327
|
+
*
|
|
328
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
329
|
+
* @category Decorators
|
|
330
|
+
*/
|
|
331
|
+
function set(clazz, message = constants_1.DEFAULT_ERROR_MESSAGES.LIST, validator) {
|
|
332
|
+
return (target, propertyKey) => {
|
|
333
|
+
list(clazz, "Set", message, validator)(target, propertyKey);
|
|
334
|
+
};
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/validation/decorators.ts"],"names":[],"mappings":";;AA2BA,4CAEC;AAYD,4BAOC;AAaD,kBASC;AAaD,kBASC;AAaD,oBASC;AAaD,8BAYC;AAaD,8BAYC;AAaD,0BAYC;AAYD,sBAKC;AAYD,kBAKC;AAaD,oBAQC;AAiBD,oBA4CC;AAeD,4BAsBC;AAgBD,oBAwBC;AAeD,kBAQC;AArZD,4BAA0B;AAC1B,8DAA2D;AAC3D,6CAA0C;AAE1C,yDAAoD;AACpD,sDAIgC;AAChC,8CAAsC;AAEtC,sEAAmE;AAGnE,oCAAqC;AAErC;;;;;;;;;GASG;AACH,SAAgB,gBAAgB,CAAC,GAAW;IAC1C,OAAO,0BAAc,CAAC,OAAO,GAAG,GAAG,CAAC;AACtC,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,QAAQ,CAAC,UAAkB,kCAAsB,CAAC,QAAQ;IACxE,OAAO,IAAA,qBAAQ,EACb,gBAAgB,CAAC,0BAAc,CAAC,QAAQ,CAAC,EACzC;QACE,OAAO,EAAE,OAAO;KACjB,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,GAAG,CACjB,KAA6B,EAC7B,UAAkB,kCAAsB,CAAC,GAAG;IAE5C,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,GAAG,CAAC,EAAE;QACxE,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;KAChC,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,GAAG,CACjB,KAA6B,EAC7B,UAAkB,kCAAsB,CAAC,GAAG;IAE5C,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,GAAG,CAAC,EAAE;QACxE,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;KAChC,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,IAAI,CAClB,KAAa,EACb,UAAkB,kCAAsB,CAAC,IAAI;IAE7C,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,IAAI,CAAC,EAAE;QACzE,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,SAAS,CACvB,KAAa,EACb,UAAkB,kCAAsB,CAAC,UAAU;IAEnD,OAAO,IAAA,qBAAQ,EACb,gBAAgB,CAAC,0BAAc,CAAC,UAAU,CAAC,EAC3C;QACE,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC;KAC3C,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,SAAS,CACvB,KAAa,EACb,UAAkB,kCAAsB,CAAC,UAAU;IAEnD,OAAO,IAAA,qBAAQ,EACb,gBAAgB,CAAC,0BAAc,CAAC,UAAU,CAAC,EAC3C;QACE,KAAK,EAAE,KAAK;QACZ,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC;KAC3C,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,OAAO,CACrB,KAAsB,EACtB,UAAkB,kCAAsB,CAAC,OAAO;IAEhD,OAAO,IAAA,qBAAQ,EACb,gBAAgB,CAAC,0BAAc,CAAC,OAAO,CAAC,EACxC;QACE,KAAK,EAAE,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE;QAC3D,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CACF,CAAC;AACJ,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,KAAK,CAAC,UAAkB,kCAAsB,CAAC,KAAK;IAClE,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,KAAK,CAAC,EAAE;QAC1E,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;GASG;AACH,SAAgB,GAAG,CAAC,UAAkB,kCAAsB,CAAC,GAAG;IAC9D,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,GAAG,CAAC,EAAE;QACxE,OAAO,EAAE,OAAO;QAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;KACrB,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAgB,IAAI,CAClB,KAAwB,EACxB,UAAkB,kCAAsB,CAAC,IAAI;IAE7C,OAAO,IAAA,qBAAQ,EAAqB,gBAAgB,CAAC,0BAAc,CAAC,IAAI,CAAC,EAAE;QACzE,WAAW,EAAE,KAAK;QAClB,OAAO,EAAE,OAAO;KACjB,CAAC,CAAC;AACL,CAAC;AAED;;;;;;;;;;;;;;GAcG;AACH,SAAgB,IAAI,CAClB,SAAiB,YAAY,EAC7B,UAAkB,kCAAsB,CAAC,IAAI;IAE7C,OAAO,CAAC,MAA2B,EAAE,WAAmB,EAAO,EAAE;QAC/D,OAAO,CAAC,cAAc,CACpB,gBAAgB,CAAC,0BAAc,CAAC,IAAI,CAAC,EACrC;YACE,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC;SACnB,EACD,MAAM,EACN,WAAW,CACZ,CAAC;QAEF,MAAM,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QAE7B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;YACzC,YAAY,EAAE,KAAK;YACnB,GAAG,CAAY,QAAuB;gBACpC,MAAM,UAAU,GAAG,MAAM,CAAC,wBAAwB,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;gBACtE,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC,YAAY;oBACxC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE;wBACvC,UAAU,EAAE,IAAI;wBAChB,YAAY,EAAE,KAAK;wBACnB,GAAG,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;wBAC3B,GAAG,EAAE,CAAC,QAAgC,EAAE,EAAE;4BACxC,IAAI,GAAqB,CAAC;4BAC1B,IAAI,CAAC;gCACH,GAAG,GAAG,IAAA,iBAAS,EAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;gCAClC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;4BACxB,CAAC;4BAAC,OAAO,CAAM,EAAE,CAAC;gCAChB,OAAO,CAAC,KAAK,CAAC,IAAA,YAAE,EAAC,2BAA2B,EAAE,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC;4BACjE,CAAC;wBACH,CAAC;qBACF,CAAC,CAAC;gBACL,IAAI,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC;YAC/B,CAAC;YACD,GAAG;gBACD,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YACtB,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,QAAQ,CACtB,UAAkB,4BAAgB,CAAC,QAAQ,CAAC,iBAAiB,EAC7D,UAAkB,kCAAsB,CAAC,QAAQ,EACjD,YAAoC,qCAAiB;IAErD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAE,EAAE;QAC1C,OAAO,CAAC,cAAc,CACpB,gBAAgB,CAAC,0BAAc,CAAC,QAAQ,CAAC,EACzC;YACE,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;YAChB,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC;SACrB,EACD,MAAM,EACN,WAAW,CACZ,CAAC;QACF,uBAAU,CAAC,QAAQ,CAAC;YAClB,SAAS,EAAE,SAAS;YACpB,aAAa,EAAE,0BAAc,CAAC,QAAQ;YACtC,IAAI,EAAE,IAAI;SACY,CAAC,CAAC;IAC5B,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,SAAgB,IAAI,CAClB,KAA4B,EAC5B,aAA8B,OAAO,EACrC,UAAkB,kCAAsB,CAAC,IAAI,EAC7C,YAAoC,6BAAa;IAEjD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAO,EAAE;QAC/C,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QACtC,OAAO,CAAC,cAAc,CACpB,gBAAgB,CAAC,0BAAc,CAAC,IAAI,CAAC,EACrC;YACE,KAAK,EAAE,KAAK,CAAC,IAAI;YACjB,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,OAAO;SACjB,EACD,MAAM,EACN,WAAW,CACZ,CAAC;QACF,uBAAU,CAAC,QAAQ,CAAC;YAClB,SAAS,EAAE,SAAS;YACpB,aAAa,EAAE,0BAAc,CAAC,IAAI;YAClC,IAAI,EAAE,IAAI;SACY,CAAC,CAAC;IAC5B,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAgB,GAAG,CACjB,KAA4B,EAC5B,UAAkB,kCAAsB,CAAC,IAAI,EAC7C,SAAkC;IAElC,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAO,EAAE;QAC/C,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IAC9D,CAAC,CAAC;AACJ,CAAC","file":"validation/decorators.js","sourcesContent":["import \"reflect-metadata\";\nimport { ListValidator } from \"./Validators/ListValidator\";\nimport { Validation } from \"./Validation\";\nimport { ValidationMetadata } from \"./types\";\nimport { metadata } from \"../reflection/decorators\";\nimport {\n  DEFAULT_ERROR_MESSAGES,\n  DEFAULT_PATTERNS,\n  ValidationKeys,\n} from \"./Validators/constants\";\nimport { sf } from \"../utils/strings\";\nimport { Constructor, ModelConstructor } from \"../model/types\";\nimport { PasswordValidator } from \"./Validators/PasswordValidator\";\nimport { ValidatorDefinition } from \"./Validators/types\";\nimport { Validator } from \"./Validators/Validator\";\nimport { parseDate } from \"../utils\";\n\n/**\n * @summary Builds the key to store as Metadata under Reflections\n * @description concatenates {@link ValidationKeys#REFLECT} with the provided key\n *\n * @param {string} key\n *\n * @function getModelKey\n * @memberOf module:decorator-validation.Utils\n * @category Utilities\n */\nexport function getValidationKey(key: string) {\n  return ValidationKeys.REFLECT + key;\n}\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 metadata<ValidationMetadata>(\n    getValidationKey(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 metadata<ValidationMetadata>(getValidationKey(ValidationKeys.MIN), {\n    value: 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 metadata<ValidationMetadata>(getValidationKey(ValidationKeys.MAX), {\n    value: 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 metadata<ValidationMetadata>(getValidationKey(ValidationKeys.STEP), {\n    value: 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 metadata<ValidationMetadata>(\n    getValidationKey(ValidationKeys.MIN_LENGTH),\n    {\n      value: 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 metadata<ValidationMetadata>(\n    getValidationKey(ValidationKeys.MAX_LENGTH),\n    {\n      value: 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 metadata<ValidationMetadata>(\n    getValidationKey(ValidationKeys.PATTERN),\n    {\n      value: 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 metadata<ValidationMetadata>(getValidationKey(ValidationKeys.EMAIL), {\n    message: message,\n    types: [String.name],\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 metadata<ValidationMetadata>(getValidationKey(ValidationKeys.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 metadata<ValidationMetadata>(getValidationKey(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: string): any => {\n    Reflect.defineMetadata(\n      getValidationKey(ValidationKeys.DATE),\n      {\n        format: format,\n        message: message,\n        types: [Date.name],\n      },\n      target,\n      propertyKey,\n    );\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  validator: Constructor<Validator> = PasswordValidator,\n) {\n  return (target: any, propertyKey: string) => {\n    Reflect.defineMetadata(\n      getValidationKey(ValidationKeys.PASSWORD),\n      {\n        pattern: pattern,\n        message: message,\n        types: [String.name],\n      },\n      target,\n      propertyKey,\n    );\n    Validation.register({\n      validator: validator,\n      validationKey: ValidationKeys.PASSWORD,\n      save: true,\n    } as ValidatorDefinition);\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>,\n  collection: \"Array\" | \"Set\" = \"Array\",\n  message: string = DEFAULT_ERROR_MESSAGES.LIST,\n  validator: Constructor<Validator> = ListValidator,\n) {\n  return (target: any, propertyKey: string): any => {\n    type(collection)(target, propertyKey);\n    Reflect.defineMetadata(\n      getValidationKey(ValidationKeys.LIST),\n      {\n        class: clazz.name,\n        type: collection,\n        message: message,\n      },\n      target,\n      propertyKey,\n    );\n    Validation.register({\n      validator: validator,\n      validationKey: ValidationKeys.LIST,\n      save: true,\n    } as ValidatorDefinition);\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  validator?: Constructor<Validator>,\n) {\n  return (target: any, propertyKey: string): any => {\n    list(clazz, \"Set\", message, validator)(target, propertyKey);\n  };\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { Constructor, ModelConstructor } from "../model/types";
|
|
3
|
+
import { Validator } from "./Validators/Validator";
|
|
4
4
|
/**
|
|
5
5
|
* @summary Builds the key to store as Metadata under Reflections
|
|
6
6
|
* @description concatenates {@link ValidationKeys#REFLECT} with the provided key
|
|
@@ -17,191 +17,118 @@ export declare function getValidationKey(key: string): string;
|
|
|
17
17
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
18
18
|
*
|
|
19
19
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
20
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link RequiredValidator}
|
|
21
20
|
*
|
|
22
21
|
* @function required
|
|
23
|
-
*
|
|
22
|
+
*
|
|
24
23
|
* @category Decorators
|
|
25
24
|
*/
|
|
26
|
-
export declare function required(message?: string
|
|
25
|
+
export declare function required(message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
27
26
|
/**
|
|
28
27
|
* @summary Defines a minimum value for the property
|
|
29
28
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
30
29
|
*
|
|
31
30
|
* @param {number | Date} value
|
|
32
31
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
33
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link MinValidator}
|
|
34
32
|
*
|
|
35
33
|
* @function min
|
|
36
34
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
37
35
|
* @category Decorators
|
|
38
36
|
*/
|
|
39
|
-
export declare function min(value: number | Date | string, message?: string
|
|
37
|
+
export declare function min(value: number | Date | string, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
40
38
|
/**
|
|
41
39
|
* @summary Defines a maximum value for the property
|
|
42
40
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}
|
|
43
41
|
*
|
|
44
42
|
* @param {number | Date} value
|
|
45
43
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
46
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link MaxValidator}
|
|
47
44
|
*
|
|
48
45
|
* @function max
|
|
49
46
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
50
47
|
* @category Decorators
|
|
51
48
|
*/
|
|
52
|
-
export declare function max(value: number | Date | string, message?: string
|
|
49
|
+
export declare function max(value: number | Date | string, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
53
50
|
/**
|
|
54
51
|
* @summary Defines a step value for the property
|
|
55
52
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}
|
|
56
53
|
*
|
|
57
54
|
* @param {number} value
|
|
58
55
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
59
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link StepValidator}
|
|
60
56
|
*
|
|
61
57
|
* @function step
|
|
62
58
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
63
59
|
* @category Decorators
|
|
64
60
|
*/
|
|
65
|
-
export declare function step(value: number, message?: string
|
|
61
|
+
export declare function step(value: number, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
66
62
|
/**
|
|
67
63
|
* @summary Defines a minimum length for the property
|
|
68
64
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}
|
|
69
65
|
*
|
|
70
66
|
* @param {string} value
|
|
71
67
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
72
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link MinLengthValidator}
|
|
73
68
|
*
|
|
74
69
|
* @function minlength
|
|
75
70
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
76
71
|
* @category Decorators
|
|
77
72
|
*/
|
|
78
|
-
export declare function minlength(value: number, message?: string
|
|
73
|
+
export declare function minlength(value: number, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
79
74
|
/**
|
|
80
75
|
* @summary Defines a maximum length for the property
|
|
81
76
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}
|
|
82
77
|
*
|
|
83
78
|
* @param {string} value
|
|
84
79
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
85
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link MaxLengthValidator}
|
|
86
80
|
*
|
|
87
81
|
* @function maxlength
|
|
88
82
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
89
83
|
* @category Decorators
|
|
90
84
|
*/
|
|
91
|
-
export declare function maxlength(value: number, message?: string
|
|
85
|
+
export declare function maxlength(value: number, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
92
86
|
/**
|
|
93
87
|
* @summary Defines a RegExp pattern the property must respect
|
|
94
88
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}
|
|
95
89
|
*
|
|
96
90
|
* @param {string} value
|
|
97
91
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
98
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link PatternValidator}
|
|
99
92
|
*
|
|
100
93
|
* @function pattern
|
|
101
94
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
102
95
|
* @category Decorators
|
|
103
96
|
*/
|
|
104
|
-
export declare function pattern(value: RegExp | string, message?: string
|
|
97
|
+
export declare function pattern(value: RegExp | string, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
105
98
|
/**
|
|
106
99
|
* @summary Defines the property as an email
|
|
107
100
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}
|
|
108
101
|
*
|
|
109
102
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
110
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link EmailValidator}
|
|
111
103
|
*
|
|
112
104
|
* @function email
|
|
113
105
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
114
106
|
* @category Decorators
|
|
115
107
|
*/
|
|
116
|
-
export declare function email(message?: string
|
|
108
|
+
export declare function email(message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
117
109
|
/**
|
|
118
110
|
* @summary Defines the property as an URL
|
|
119
111
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}
|
|
120
112
|
*
|
|
121
113
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
122
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link URLValidator}
|
|
123
114
|
*
|
|
124
115
|
* @function url
|
|
125
116
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
126
117
|
* @category Decorators
|
|
127
118
|
*/
|
|
128
|
-
export declare function url(message?: string
|
|
119
|
+
export declare function url(message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
129
120
|
/**
|
|
130
121
|
* @summary Enforces type verification
|
|
131
122
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
|
|
132
123
|
*
|
|
133
124
|
* @param {string[] | string} types accepted types
|
|
134
125
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
135
|
-
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link TypeValidator}
|
|
136
126
|
*
|
|
137
127
|
* @function type
|
|
138
128
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
139
129
|
* @category Decorators
|
|
140
130
|
*/
|
|
141
|
-
export declare function type(types: string[] | string, message?: string
|
|
142
|
-
/**
|
|
143
|
-
* @summary Binds a date format to a string
|
|
144
|
-
* @param {Date} [date]
|
|
145
|
-
* @param {string} [format]
|
|
146
|
-
* @memberOf module:decorator-validation.Utils.Format
|
|
147
|
-
* @category Utilities
|
|
148
|
-
*/
|
|
149
|
-
export declare function bindDateToString(date: Date | undefined, format: string): Date | undefined;
|
|
150
|
-
/**
|
|
151
|
-
* @summary Helper function to be used instead of instanceOf Date
|
|
152
|
-
* @param date
|
|
153
|
-
* @memberOf module:decorator-validation.Utils.Dates
|
|
154
|
-
* @category Validation
|
|
155
|
-
*/
|
|
156
|
-
export declare function isValidDate(date: any): boolean;
|
|
157
|
-
/**
|
|
158
|
-
* @summary Util function to pad numbers
|
|
159
|
-
* @param {number} num
|
|
160
|
-
*
|
|
161
|
-
* @return {string}
|
|
162
|
-
*
|
|
163
|
-
* @function twoDigitPad
|
|
164
|
-
* @memberOf module:decorator-validation.Utils.Format
|
|
165
|
-
* @category Format
|
|
166
|
-
*/
|
|
167
|
-
export declare function twoDigitPad(num: number): string;
|
|
168
|
-
/**
|
|
169
|
-
* @summary Date Format Handling
|
|
170
|
-
* @description Code from {@link https://stackoverflow.com/questions/3552461/how-to-format-a-javascript-date}
|
|
171
|
-
*
|
|
172
|
-
* <pre>
|
|
173
|
-
* Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),
|
|
174
|
-
* I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.
|
|
175
|
-
* You can display date, time, AM/PM, etc.
|
|
176
|
-
*
|
|
177
|
-
* Date and Time Patterns
|
|
178
|
-
* yy = 2-digit year; yyyy = full year
|
|
179
|
-
* M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name
|
|
180
|
-
* EEEE = full weekday name; EEE = short weekday name
|
|
181
|
-
* d = digit day; dd = 2-digit day
|
|
182
|
-
* h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours
|
|
183
|
-
* m = minutes; mm = 2-digit minutes; aaa = AM/PM
|
|
184
|
-
* s = seconds; ss = 2-digit seconds
|
|
185
|
-
* S = miliseconds
|
|
186
|
-
* </pre>
|
|
187
|
-
*
|
|
188
|
-
* @param {Date} date
|
|
189
|
-
* @param {string} [patternStr] defaults to 'yyyy/MM/dd'
|
|
190
|
-
* @return {string} the formatted date
|
|
191
|
-
*
|
|
192
|
-
* @function formatDate
|
|
193
|
-
* @memberOf module:decorator-validation.Utils.Dates
|
|
194
|
-
* @category Format
|
|
195
|
-
*/
|
|
196
|
-
export declare function formatDate(date: Date, patternStr?: string): string;
|
|
197
|
-
/**
|
|
198
|
-
* @summary Parses a date from a specified format
|
|
199
|
-
* @param {string} format
|
|
200
|
-
* @param {string | Date | number} [v]
|
|
201
|
-
* @memberOf module:decorator-validation.Utils.Dates
|
|
202
|
-
* @category Format
|
|
203
|
-
*/
|
|
204
|
-
export declare function parseDate(format: string, v?: string | Date | number): Date | undefined;
|
|
131
|
+
export declare function type(types: string[] | string, message?: string): import("../reflection/decorators").CustomDecorator<V>;
|
|
205
132
|
/**
|
|
206
133
|
* @summary Date Handler Decorator
|
|
207
134
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
|
|
@@ -217,7 +144,7 @@ export declare function parseDate(format: string, v?: string | Date | number): D
|
|
|
217
144
|
* @memberOf module:decorator-validation.Decorators.Validation
|
|
218
145
|
* @category Decorators
|
|
219
146
|
*/
|
|
220
|
-
export declare function date(format?: string, message?: string
|
|
147
|
+
export declare function date(format?: string, message?: string): (target: Record<string, any>, propertyKey: string) => any;
|
|
221
148
|
/**
|
|
222
149
|
* @summary Password Handler Decorator
|
|
223
150
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
package/lib/validation/index.cjs
CHANGED
|
@@ -1 +1,22 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./Validators/index.cjs"), exports);
|
|
18
|
+
__exportStar(require("./decorators/index.cjs"), exports);
|
|
19
|
+
__exportStar(require("./types/index.cjs"), exports);
|
|
20
|
+
__exportStar(require("./Validation/index.cjs"), exports);
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy92YWxpZGF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBNkI7QUFDN0IsK0NBQTZCO0FBQzdCLDBDQUF3QjtBQUN4QiwrQ0FBNkIiLCJmaWxlIjoidmFsaWRhdGlvbi9pbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL1ZhbGlkYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3R5cGVzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9WYWxpZGF0aW9uXCI7XG4iXX0=
|