@decaf-ts/decorator-validation 1.5.2 → 1.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +0 -0
- package/README.md +34 -108
- package/dist/decorator-validation.js +2 -0
- package/dist/decorator-validation.js.LICENSE.txt +14 -0
- package/dist/esm/decorator-validation.js +2 -0
- package/dist/esm/decorator-validation.js.LICENSE.txt +14 -0
- package/lib/esm/index.d.ts +42 -0
- package/lib/esm/index.js +44 -0
- package/lib/esm/model/Model.d.ts +138 -0
- package/lib/esm/model/Model.js +298 -0
- package/lib/esm/model/ModelErrorDefinition.d.ts +22 -0
- package/lib/esm/model/ModelErrorDefinition.js +54 -0
- package/lib/esm/model/Registry.d.ts +59 -0
- package/lib/esm/model/Registry.js +75 -0
- package/lib/esm/model/constants.d.ts +56 -0
- package/lib/esm/model/constants.js +71 -0
- package/lib/esm/model/construction.d.ts +29 -0
- package/lib/esm/model/construction.js +65 -0
- package/lib/esm/model/decorators.d.ts +25 -0
- package/lib/esm/model/decorators.js +64 -0
- package/lib/esm/model/index.d.ts +9 -0
- package/lib/esm/model/index.js +11 -0
- package/lib/esm/model/types.d.ts +79 -0
- package/lib/esm/model/types.js +3 -0
- package/lib/esm/model/utils.d.ts +11 -0
- package/lib/esm/model/utils.js +27 -0
- package/lib/esm/model/validation.d.ts +14 -0
- package/lib/esm/model/validation.js +137 -0
- package/lib/esm/utils/constants.d.ts +26 -0
- package/lib/esm/utils/constants.js +29 -0
- package/lib/esm/utils/dates.d.ts +76 -0
- package/lib/esm/utils/dates.js +245 -0
- package/lib/esm/utils/decorators.d.ts +2 -0
- package/lib/esm/utils/decorators.js +20 -0
- package/lib/esm/utils/hashing.d.ts +52 -0
- package/lib/esm/utils/hashing.js +101 -0
- package/lib/esm/utils/index.d.ts +7 -0
- package/lib/esm/utils/index.js +9 -0
- package/lib/esm/utils/registry.d.ts +68 -0
- package/lib/esm/utils/registry.js +3 -0
- package/lib/esm/utils/serialization.d.ts +79 -0
- package/lib/esm/utils/serialization.js +90 -0
- package/lib/esm/utils/strings.d.ts +25 -0
- package/lib/esm/utils/strings.js +33 -0
- package/lib/esm/validation/Validation.d.ts +51 -0
- package/lib/esm/validation/Validation.js +73 -0
- package/lib/esm/validation/Validators/DateValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/DateValidator.js +56 -0
- package/lib/esm/validation/Validators/EmailValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/EmailValidator.js +52 -0
- package/lib/esm/validation/Validators/ListValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/ListValidator.js +69 -0
- package/lib/esm/validation/Validators/MaxLengthValidator.d.ts +29 -0
- package/lib/esm/validation/Validators/MaxLengthValidator.js +54 -0
- package/lib/esm/validation/Validators/MaxValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/MaxValidator.js +59 -0
- package/lib/esm/validation/Validators/MinLengthValidator.d.ts +29 -0
- package/lib/esm/validation/Validators/MinLengthValidator.js +54 -0
- package/lib/esm/validation/Validators/MinValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/MinValidator.js +59 -0
- package/lib/esm/validation/Validators/PasswordValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/PasswordValidator.js +52 -0
- package/lib/esm/validation/Validators/PatternValidator.d.ts +37 -0
- package/lib/esm/validation/Validators/PatternValidator.js +72 -0
- package/lib/esm/validation/Validators/RequiredValidator.d.ts +28 -0
- package/lib/esm/validation/Validators/RequiredValidator.js +59 -0
- package/lib/esm/validation/Validators/StepValidator.d.ts +29 -0
- package/lib/esm/validation/Validators/StepValidator.js +54 -0
- package/lib/esm/validation/Validators/TypeValidator.d.ts +25 -0
- package/lib/esm/validation/Validators/TypeValidator.js +62 -0
- package/lib/esm/validation/Validators/URLValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/URLValidator.js +51 -0
- package/lib/esm/validation/Validators/Validator.d.ts +41 -0
- package/lib/esm/validation/Validators/Validator.js +49 -0
- package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +47 -0
- package/lib/esm/validation/Validators/ValidatorRegistry.js +82 -0
- package/lib/esm/validation/Validators/constants.d.ts +96 -0
- package/lib/esm/validation/Validators/constants.js +136 -0
- package/lib/esm/validation/Validators/decorators.d.ts +12 -0
- package/lib/esm/validation/Validators/decorators.js +27 -0
- package/lib/esm/validation/Validators/index.d.ts +52 -0
- package/lib/esm/validation/Validators/index.js +54 -0
- package/lib/esm/validation/Validators/types.d.ts +88 -0
- package/lib/esm/validation/Validators/types.js +3 -0
- package/lib/esm/validation/decorators.d.ts +178 -0
- package/lib/esm/validation/decorators.js +290 -0
- package/lib/esm/validation/index.d.ts +4 -0
- package/lib/esm/validation/index.js +6 -0
- package/lib/esm/validation/types.d.ts +46 -0
- package/lib/esm/validation/types.js +3 -0
- package/lib/index.cjs +61 -0
- package/lib/index.d.ts +42 -0
- package/lib/model/Model.cjs +302 -0
- package/lib/model/Model.d.ts +138 -0
- package/lib/model/ModelErrorDefinition.cjs +58 -0
- package/lib/model/ModelErrorDefinition.d.ts +22 -0
- package/lib/model/Registry.cjs +80 -0
- package/lib/model/Registry.d.ts +59 -0
- package/lib/model/constants.cjs +74 -0
- package/lib/model/constants.d.ts +56 -0
- package/lib/model/construction.cjs +70 -0
- package/lib/model/construction.d.ts +29 -0
- package/lib/model/decorators.cjs +69 -0
- package/lib/model/decorators.d.ts +25 -0
- package/lib/model/index.cjs +27 -0
- package/lib/model/index.d.ts +9 -0
- package/lib/model/types.cjs +4 -0
- package/lib/model/types.d.ts +79 -0
- package/lib/model/utils.cjs +31 -0
- package/lib/model/utils.d.ts +11 -0
- package/lib/model/validation.cjs +140 -0
- package/lib/model/validation.d.ts +14 -0
- package/lib/utils/constants.cjs +32 -0
- package/lib/utils/constants.d.ts +26 -0
- package/lib/utils/dates.cjs +253 -0
- package/lib/utils/dates.d.ts +76 -0
- package/lib/utils/decorators.cjs +24 -0
- package/lib/utils/decorators.d.ts +2 -0
- package/lib/utils/hashing.cjs +108 -0
- package/lib/utils/hashing.d.ts +52 -0
- package/lib/utils/index.cjs +25 -0
- package/lib/utils/index.d.ts +7 -0
- package/lib/utils/registry.cjs +4 -0
- package/lib/utils/registry.d.ts +68 -0
- package/lib/utils/serialization.cjs +95 -0
- package/lib/utils/serialization.d.ts +79 -0
- package/lib/utils/strings.cjs +37 -0
- package/lib/utils/strings.d.ts +25 -0
- package/lib/validation/Validation.cjs +77 -0
- package/lib/validation/Validation.d.ts +51 -0
- package/lib/validation/Validators/DateValidator.cjs +59 -0
- package/lib/validation/Validators/DateValidator.d.ts +28 -0
- package/lib/validation/Validators/EmailValidator.cjs +55 -0
- package/lib/validation/Validators/EmailValidator.d.ts +28 -0
- package/lib/validation/Validators/ListValidator.cjs +72 -0
- package/lib/validation/Validators/ListValidator.d.ts +28 -0
- package/lib/validation/Validators/MaxLengthValidator.cjs +57 -0
- package/lib/validation/Validators/MaxLengthValidator.d.ts +29 -0
- package/lib/validation/Validators/MaxValidator.cjs +62 -0
- package/lib/validation/Validators/MaxValidator.d.ts +28 -0
- package/lib/validation/Validators/MinLengthValidator.cjs +57 -0
- package/lib/validation/Validators/MinLengthValidator.d.ts +29 -0
- package/lib/validation/Validators/MinValidator.cjs +62 -0
- package/lib/validation/Validators/MinValidator.d.ts +28 -0
- package/lib/validation/Validators/PasswordValidator.cjs +55 -0
- package/lib/validation/Validators/PasswordValidator.d.ts +28 -0
- package/lib/validation/Validators/PatternValidator.cjs +75 -0
- package/lib/validation/Validators/PatternValidator.d.ts +37 -0
- package/lib/validation/Validators/RequiredValidator.cjs +62 -0
- package/lib/validation/Validators/RequiredValidator.d.ts +28 -0
- package/lib/validation/Validators/StepValidator.cjs +57 -0
- package/lib/validation/Validators/StepValidator.d.ts +29 -0
- package/lib/validation/Validators/TypeValidator.cjs +65 -0
- package/lib/validation/Validators/TypeValidator.d.ts +25 -0
- package/lib/validation/Validators/URLValidator.cjs +54 -0
- package/lib/validation/Validators/URLValidator.d.ts +27 -0
- package/lib/validation/Validators/Validator.cjs +53 -0
- package/lib/validation/Validators/Validator.d.ts +41 -0
- package/lib/validation/Validators/ValidatorRegistry.cjs +87 -0
- package/lib/validation/Validators/ValidatorRegistry.d.ts +47 -0
- package/lib/validation/Validators/constants.cjs +139 -0
- package/lib/validation/Validators/constants.d.ts +96 -0
- package/lib/validation/Validators/decorators.cjs +30 -0
- package/lib/validation/Validators/decorators.d.ts +12 -0
- package/lib/validation/Validators/index.cjs +71 -0
- package/lib/validation/Validators/index.d.ts +52 -0
- package/lib/validation/Validators/types.d.ts +88 -0
- package/lib/validation/decorators.cjs +306 -0
- package/lib/validation/decorators.d.ts +178 -0
- package/lib/validation/index.cjs +22 -0
- package/lib/validation/index.d.ts +4 -0
- package/lib/validation/types.cjs +4 -0
- package/lib/validation/types.d.ts +46 -0
- package/package.json +18 -13
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Validator } from "./Validator";
|
|
2
|
+
import { IRegistry } from "../../utils/registry";
|
|
3
|
+
import { Constructor } from "../../model/types";
|
|
4
|
+
/**
|
|
5
|
+
* @summary Util type for {@link Validator} configuration
|
|
6
|
+
* @memberOf module:decorator-validation.Validation
|
|
7
|
+
* @category Validation
|
|
8
|
+
*/
|
|
9
|
+
export type ValidatorDefinition = {
|
|
10
|
+
validator: Constructor<Validator>;
|
|
11
|
+
validationKey: string;
|
|
12
|
+
save: boolean;
|
|
13
|
+
};
|
|
14
|
+
/**
|
|
15
|
+
* @summary Base API for a {@link Validator} registry
|
|
16
|
+
*
|
|
17
|
+
* @interface ValidatorRegistry
|
|
18
|
+
* @extends IRegistry
|
|
19
|
+
*
|
|
20
|
+
* @category Validation
|
|
21
|
+
*/
|
|
22
|
+
export interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {
|
|
23
|
+
/**
|
|
24
|
+
* @summary retrieves the custom keys
|
|
25
|
+
* @method
|
|
26
|
+
*/
|
|
27
|
+
getCustomKeys(): Record<string, string>;
|
|
28
|
+
/**
|
|
29
|
+
* @summary Retrieves the Registered validator keys
|
|
30
|
+
* @return {string[]} the registered validators keys
|
|
31
|
+
* @method
|
|
32
|
+
*/
|
|
33
|
+
getKeys(): string[];
|
|
34
|
+
/**
|
|
35
|
+
* @summary Registers the provided validators onto the registry
|
|
36
|
+
*
|
|
37
|
+
* @typedef T extends Validator
|
|
38
|
+
* @param {T[] | ValidatorDefinition[]} validator
|
|
39
|
+
* @method
|
|
40
|
+
*/
|
|
41
|
+
register<T extends Validator>(...validator: (T | ValidatorDefinition)[]): void;
|
|
42
|
+
/**
|
|
43
|
+
* @summary Retrieves the Validator constructor if registered
|
|
44
|
+
*
|
|
45
|
+
* @typedef T extends Validator
|
|
46
|
+
* @param {string} key one of the {@link ValidationKeys}
|
|
47
|
+
* @return {Validator | undefined} the registered Validator or undefined if there is nono matching the provided key
|
|
48
|
+
* @method
|
|
49
|
+
*/
|
|
50
|
+
get<T extends Validator>(key: string): T | undefined;
|
|
51
|
+
}
|
|
52
|
+
export type ValidatorOptions = {
|
|
53
|
+
message?: string;
|
|
54
|
+
};
|
|
55
|
+
export interface URLValidatorOptions extends ValidatorOptions {
|
|
56
|
+
types: string | string[] | {
|
|
57
|
+
name: string;
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
export interface TypeValidatorOptions extends ValidatorOptions {
|
|
61
|
+
types: string | string[] | {
|
|
62
|
+
name: string;
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
export interface StepValidatorOptions extends ValidatorOptions {
|
|
66
|
+
step: number | string;
|
|
67
|
+
}
|
|
68
|
+
export interface PatternValidatorOptions extends ValidatorOptions {
|
|
69
|
+
pattern?: RegExp | string;
|
|
70
|
+
}
|
|
71
|
+
export interface MinValidatorOptions extends ValidatorOptions {
|
|
72
|
+
min: number | Date | string;
|
|
73
|
+
}
|
|
74
|
+
export interface MinLengthValidatorOptions extends ValidatorOptions {
|
|
75
|
+
minLength: number;
|
|
76
|
+
}
|
|
77
|
+
export interface MaxValidatorOptions extends ValidatorOptions {
|
|
78
|
+
max: number | Date | string;
|
|
79
|
+
}
|
|
80
|
+
export interface MaxLengthValidatorOptions extends ValidatorOptions {
|
|
81
|
+
maxLength: number;
|
|
82
|
+
}
|
|
83
|
+
export interface ListValidatorOptions extends ValidatorOptions {
|
|
84
|
+
clazz: string[];
|
|
85
|
+
}
|
|
86
|
+
export interface DateValidatorOptions extends ValidatorOptions {
|
|
87
|
+
format?: string;
|
|
88
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy92YWxpZGF0aW9uL1ZhbGlkYXRvcnMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJ2YWxpZGF0aW9uL1ZhbGlkYXRvcnMvdHlwZXMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWYWxpZGF0b3IgfSBmcm9tIFwiLi9WYWxpZGF0b3JcIjtcbmltcG9ydCB7IElSZWdpc3RyeSB9IGZyb20gXCIuLi8uLi91dGlscy9yZWdpc3RyeVwiO1xuaW1wb3J0IHsgQ29uc3RydWN0b3IgfSBmcm9tIFwiLi4vLi4vbW9kZWwvdHlwZXNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBVdGlsIHR5cGUgZm9yIHtAbGluayBWYWxpZGF0b3J9IGNvbmZpZ3VyYXRpb25cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uVmFsaWRhdGlvblxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgVmFsaWRhdG9yRGVmaW5pdGlvbiA9IHtcbiAgdmFsaWRhdG9yOiBDb25zdHJ1Y3RvcjxWYWxpZGF0b3I+O1xuICB2YWxpZGF0aW9uS2V5OiBzdHJpbmc7XG4gIHNhdmU6IGJvb2xlYW47XG59O1xuXG4vKipcbiAqIEBzdW1tYXJ5IEJhc2UgQVBJIGZvciBhIHtAbGluayBWYWxpZGF0b3J9IHJlZ2lzdHJ5XG4gKlxuICogQGludGVyZmFjZSBWYWxpZGF0b3JSZWdpc3RyeVxuICogQGV4dGVuZHMgSVJlZ2lzdHJ5XG4gKlxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJVmFsaWRhdG9yUmVnaXN0cnk8VCBleHRlbmRzIFZhbGlkYXRvcj4gZXh0ZW5kcyBJUmVnaXN0cnk8VD4ge1xuICAvKipcbiAgICogQHN1bW1hcnkgcmV0cmlldmVzIHRoZSBjdXN0b20ga2V5c1xuICAgKiBAbWV0aG9kXG4gICAqL1xuICBnZXRDdXN0b21LZXlzKCk6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG5cbiAgLyoqXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgUmVnaXN0ZXJlZCB2YWxpZGF0b3Iga2V5c1xuICAgKiBAcmV0dXJuIHtzdHJpbmdbXX0gdGhlIHJlZ2lzdGVyZWQgdmFsaWRhdG9ycyBrZXlzXG4gICAqIEBtZXRob2RcbiAgICovXG4gIGdldEtleXMoKTogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEBzdW1tYXJ5IFJlZ2lzdGVycyB0aGUgcHJvdmlkZWQgdmFsaWRhdG9ycyBvbnRvIHRoZSByZWdpc3RyeVxuICAgKlxuICAgKiBAdHlwZWRlZiBUIGV4dGVuZHMgVmFsaWRhdG9yXG4gICAqIEBwYXJhbSB7VFtdIHwgVmFsaWRhdG9yRGVmaW5pdGlvbltdfSB2YWxpZGF0b3JcbiAgICogQG1ldGhvZFxuICAgKi9cbiAgcmVnaXN0ZXI8VCBleHRlbmRzIFZhbGlkYXRvcj4oXG4gICAgLi4udmFsaWRhdG9yOiAoVCB8IFZhbGlkYXRvckRlZmluaXRpb24pW11cbiAgKTogdm9pZDtcblxuICAvKipcbiAgICogQHN1bW1hcnkgUmV0cmlldmVzIHRoZSBWYWxpZGF0b3IgY29uc3RydWN0b3IgaWYgcmVnaXN0ZXJlZFxuICAgKlxuICAgKiBAdHlwZWRlZiBUIGV4dGVuZHMgVmFsaWRhdG9yXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgb25lIG9mIHRoZSB7QGxpbmsgVmFsaWRhdGlvbktleXN9XG4gICAqIEByZXR1cm4ge1ZhbGlkYXRvciB8IHVuZGVmaW5lZH0gdGhlIHJlZ2lzdGVyZWQgVmFsaWRhdG9yIG9yIHVuZGVmaW5lZCBpZiB0aGVyZSBpcyBub25vIG1hdGNoaW5nIHRoZSBwcm92aWRlZCBrZXlcbiAgICogQG1ldGhvZFxuICAgKi9cbiAgZ2V0PFQgZXh0ZW5kcyBWYWxpZGF0b3I+KGtleTogc3RyaW5nKTogVCB8IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0IHR5cGUgVmFsaWRhdG9yT3B0aW9ucyA9IHtcbiAgbWVzc2FnZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgVVJMVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICB0eXBlczogc3RyaW5nIHwgc3RyaW5nW10gfCB7IG5hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFR5cGVWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIHR5cGVzOiBzdHJpbmcgfCBzdHJpbmdbXSB8IHsgbmFtZTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RlcFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgc3RlcDogbnVtYmVyIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBhdHRlcm5WYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIHBhdHRlcm4/OiBSZWdFeHAgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWluVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBtaW46IG51bWJlciB8IERhdGUgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWluTGVuZ3RoVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBtaW5MZW5ndGg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXhWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIG1heDogbnVtYmVyIHwgRGF0ZSB8IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXhMZW5ndGhWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIG1heExlbmd0aDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExpc3RWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIGNsYXp6OiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEYXRlVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBmb3JtYXQ/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { ModelConstructor } from "../model/types";
|
|
3
|
+
/**
|
|
4
|
+
* @summary Marks the property as required.
|
|
5
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
6
|
+
*
|
|
7
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
8
|
+
*
|
|
9
|
+
* @function required
|
|
10
|
+
*
|
|
11
|
+
* @category Decorators
|
|
12
|
+
*/
|
|
13
|
+
export declare function required(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
14
|
+
/**
|
|
15
|
+
* @summary Defines a minimum value for the property
|
|
16
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
17
|
+
*
|
|
18
|
+
* @param {number | Date} value
|
|
19
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
20
|
+
*
|
|
21
|
+
* @function min
|
|
22
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
23
|
+
* @category Decorators
|
|
24
|
+
*/
|
|
25
|
+
export declare function min(value: number | Date | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
26
|
+
/**
|
|
27
|
+
* @summary Defines a maximum value for the property
|
|
28
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}
|
|
29
|
+
*
|
|
30
|
+
* @param {number | Date} value
|
|
31
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
32
|
+
*
|
|
33
|
+
* @function max
|
|
34
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
35
|
+
* @category Decorators
|
|
36
|
+
*/
|
|
37
|
+
export declare function max(value: number | Date | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
38
|
+
/**
|
|
39
|
+
* @summary Defines a step value for the property
|
|
40
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}
|
|
41
|
+
*
|
|
42
|
+
* @param {number} value
|
|
43
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
44
|
+
*
|
|
45
|
+
* @function step
|
|
46
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
47
|
+
* @category Decorators
|
|
48
|
+
*/
|
|
49
|
+
export declare function step(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
50
|
+
/**
|
|
51
|
+
* @summary Defines a minimum length for the property
|
|
52
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}
|
|
53
|
+
*
|
|
54
|
+
* @param {string} value
|
|
55
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
56
|
+
*
|
|
57
|
+
* @function minlength
|
|
58
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
59
|
+
* @category Decorators
|
|
60
|
+
*/
|
|
61
|
+
export declare function minlength(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
62
|
+
/**
|
|
63
|
+
* @summary Defines a maximum length for the property
|
|
64
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}
|
|
65
|
+
*
|
|
66
|
+
* @param {string} value
|
|
67
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
68
|
+
*
|
|
69
|
+
* @function maxlength
|
|
70
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
71
|
+
* @category Decorators
|
|
72
|
+
*/
|
|
73
|
+
export declare function maxlength(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
74
|
+
/**
|
|
75
|
+
* @summary Defines a RegExp pattern the property must respect
|
|
76
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}
|
|
77
|
+
*
|
|
78
|
+
* @param {string} value
|
|
79
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
80
|
+
*
|
|
81
|
+
* @function pattern
|
|
82
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
83
|
+
* @category Decorators
|
|
84
|
+
*/
|
|
85
|
+
export declare function pattern(value: RegExp | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
86
|
+
/**
|
|
87
|
+
* @summary Defines the property as an email
|
|
88
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}
|
|
89
|
+
*
|
|
90
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
91
|
+
*
|
|
92
|
+
* @function email
|
|
93
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
94
|
+
* @category Decorators
|
|
95
|
+
*/
|
|
96
|
+
export declare function email(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
97
|
+
/**
|
|
98
|
+
* @summary Defines the property as an URL
|
|
99
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}
|
|
100
|
+
*
|
|
101
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
102
|
+
*
|
|
103
|
+
* @function url
|
|
104
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
105
|
+
* @category Decorators
|
|
106
|
+
*/
|
|
107
|
+
export declare function url(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
108
|
+
/**
|
|
109
|
+
* @summary Enforces type verification
|
|
110
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
|
|
111
|
+
*
|
|
112
|
+
* @param {string[] | string} types accepted types
|
|
113
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
114
|
+
*
|
|
115
|
+
* @function type
|
|
116
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
117
|
+
* @category Decorators
|
|
118
|
+
*/
|
|
119
|
+
export declare function type(types: string[] | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
120
|
+
/**
|
|
121
|
+
* @summary Date Handler Decorator
|
|
122
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
|
|
123
|
+
*
|
|
124
|
+
* Will enforce serialization according to the selected format
|
|
125
|
+
*
|
|
126
|
+
* @param {string} format accepted format according to {@link formatDate}
|
|
127
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
|
|
128
|
+
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
|
|
129
|
+
*
|
|
130
|
+
* @function date
|
|
131
|
+
*
|
|
132
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
133
|
+
* @category Decorators
|
|
134
|
+
*/
|
|
135
|
+
export declare function date(format?: string, message?: string): (target: Record<string, any>, propertyKey?: any) => any;
|
|
136
|
+
/**
|
|
137
|
+
* @summary Password Handler Decorator
|
|
138
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
|
139
|
+
*
|
|
140
|
+
* @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
|
|
141
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
|
|
142
|
+
* @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
|
|
143
|
+
*
|
|
144
|
+
* @function password
|
|
145
|
+
*
|
|
146
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
147
|
+
* @category Decorators
|
|
148
|
+
*/
|
|
149
|
+
export declare function password(pattern?: RegExp, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
150
|
+
/**
|
|
151
|
+
* @summary List Decorator
|
|
152
|
+
* @description Also sets the {@link type} to the provided collection
|
|
153
|
+
*
|
|
154
|
+
* @param {ModelConstructor} clazz
|
|
155
|
+
* @param {string} [collection] The collection being used. defaults to Array
|
|
156
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
157
|
+
* @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
|
|
158
|
+
*
|
|
159
|
+
* @function list
|
|
160
|
+
*
|
|
161
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
162
|
+
* @category Decorators
|
|
163
|
+
*/
|
|
164
|
+
export declare function list(clazz: ModelConstructor<any> | ModelConstructor<any>[], collection?: "Array" | "Set", message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
165
|
+
/**
|
|
166
|
+
* @summary Set Decorator
|
|
167
|
+
* @description Wrapper for {@link list} with the 'Set' Collection
|
|
168
|
+
*
|
|
169
|
+
* @param {ModelConstructor} clazz
|
|
170
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
171
|
+
* @param {Constructor<Validator>} [validator]
|
|
172
|
+
*
|
|
173
|
+
* @function set
|
|
174
|
+
*
|
|
175
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
176
|
+
* @category Decorators
|
|
177
|
+
*/
|
|
178
|
+
export declare function set(clazz: ModelConstructor<any>, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { DEFAULT_ERROR_MESSAGES, DEFAULT_PATTERNS, ValidationKeys, } from "./Validators/constants";
|
|
3
|
+
import { sf } from "../utils/strings";
|
|
4
|
+
import { parseDate } from "../utils/dates";
|
|
5
|
+
import { propMetadata } from "../utils/decorators";
|
|
6
|
+
import { Validation } from "./Validation";
|
|
7
|
+
/**
|
|
8
|
+
* @summary Marks the property as required.
|
|
9
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
10
|
+
*
|
|
11
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
12
|
+
*
|
|
13
|
+
* @function required
|
|
14
|
+
*
|
|
15
|
+
* @category Decorators
|
|
16
|
+
*/
|
|
17
|
+
export function required(message = DEFAULT_ERROR_MESSAGES.REQUIRED) {
|
|
18
|
+
return propMetadata(Validation.key(ValidationKeys.REQUIRED), {
|
|
19
|
+
message: message,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* @summary Defines a minimum value for the property
|
|
24
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
25
|
+
*
|
|
26
|
+
* @param {number | Date} value
|
|
27
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
28
|
+
*
|
|
29
|
+
* @function min
|
|
30
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
31
|
+
* @category Decorators
|
|
32
|
+
*/
|
|
33
|
+
export function min(value, message = DEFAULT_ERROR_MESSAGES.MIN) {
|
|
34
|
+
return propMetadata(Validation.key(ValidationKeys.MIN), {
|
|
35
|
+
min: value,
|
|
36
|
+
message: message,
|
|
37
|
+
types: [Number.name, Date.name],
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* @summary Defines a maximum value for the property
|
|
42
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}
|
|
43
|
+
*
|
|
44
|
+
* @param {number | Date} value
|
|
45
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
46
|
+
*
|
|
47
|
+
* @function max
|
|
48
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
49
|
+
* @category Decorators
|
|
50
|
+
*/
|
|
51
|
+
export function max(value, message = DEFAULT_ERROR_MESSAGES.MAX) {
|
|
52
|
+
return propMetadata(Validation.key(ValidationKeys.MAX), {
|
|
53
|
+
max: value,
|
|
54
|
+
message: message,
|
|
55
|
+
types: [Number.name, Date.name],
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* @summary Defines a step value for the property
|
|
60
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}
|
|
61
|
+
*
|
|
62
|
+
* @param {number} value
|
|
63
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
64
|
+
*
|
|
65
|
+
* @function step
|
|
66
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
67
|
+
* @category Decorators
|
|
68
|
+
*/
|
|
69
|
+
export function step(value, message = DEFAULT_ERROR_MESSAGES.STEP) {
|
|
70
|
+
return propMetadata(Validation.key(ValidationKeys.STEP), {
|
|
71
|
+
step: value,
|
|
72
|
+
message: message,
|
|
73
|
+
types: [Number.name],
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* @summary Defines a minimum length for the property
|
|
78
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}
|
|
79
|
+
*
|
|
80
|
+
* @param {string} value
|
|
81
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
82
|
+
*
|
|
83
|
+
* @function minlength
|
|
84
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
85
|
+
* @category Decorators
|
|
86
|
+
*/
|
|
87
|
+
export function minlength(value, message = DEFAULT_ERROR_MESSAGES.MIN_LENGTH) {
|
|
88
|
+
return propMetadata(Validation.key(ValidationKeys.MIN_LENGTH), {
|
|
89
|
+
minLength: value,
|
|
90
|
+
message: message,
|
|
91
|
+
types: [String.name, Array.name, Set.name],
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* @summary Defines a maximum length for the property
|
|
96
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}
|
|
97
|
+
*
|
|
98
|
+
* @param {string} value
|
|
99
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
100
|
+
*
|
|
101
|
+
* @function maxlength
|
|
102
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
103
|
+
* @category Decorators
|
|
104
|
+
*/
|
|
105
|
+
export function maxlength(value, message = DEFAULT_ERROR_MESSAGES.MAX_LENGTH) {
|
|
106
|
+
return propMetadata(Validation.key(ValidationKeys.MAX_LENGTH), {
|
|
107
|
+
maxLength: value,
|
|
108
|
+
message: message,
|
|
109
|
+
types: [String.name, Array.name, Set.name],
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* @summary Defines a RegExp pattern the property must respect
|
|
114
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}
|
|
115
|
+
*
|
|
116
|
+
* @param {string} value
|
|
117
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
118
|
+
*
|
|
119
|
+
* @function pattern
|
|
120
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
121
|
+
* @category Decorators
|
|
122
|
+
*/
|
|
123
|
+
export function pattern(value, message = DEFAULT_ERROR_MESSAGES.PATTERN) {
|
|
124
|
+
return propMetadata(Validation.key(ValidationKeys.PATTERN), {
|
|
125
|
+
pattern: typeof value === "string" ? value : value.toString(),
|
|
126
|
+
message: message,
|
|
127
|
+
types: [String.name],
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* @summary Defines the property as an email
|
|
132
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}
|
|
133
|
+
*
|
|
134
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
135
|
+
*
|
|
136
|
+
* @function email
|
|
137
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
138
|
+
* @category Decorators
|
|
139
|
+
*/
|
|
140
|
+
export function email(message = DEFAULT_ERROR_MESSAGES.EMAIL) {
|
|
141
|
+
return propMetadata(Validation.key(ValidationKeys.EMAIL), {
|
|
142
|
+
pattern: DEFAULT_PATTERNS.EMAIL,
|
|
143
|
+
message: message,
|
|
144
|
+
types: [String.name],
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* @summary Defines the property as an URL
|
|
149
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}
|
|
150
|
+
*
|
|
151
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
152
|
+
*
|
|
153
|
+
* @function url
|
|
154
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
155
|
+
* @category Decorators
|
|
156
|
+
*/
|
|
157
|
+
export function url(message = DEFAULT_ERROR_MESSAGES.URL) {
|
|
158
|
+
return propMetadata(Validation.key(ValidationKeys.URL), {
|
|
159
|
+
pattern: DEFAULT_PATTERNS.URL,
|
|
160
|
+
message: message,
|
|
161
|
+
types: [String.name],
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* @summary Enforces type verification
|
|
166
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
|
|
167
|
+
*
|
|
168
|
+
* @param {string[] | string} types accepted types
|
|
169
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
170
|
+
*
|
|
171
|
+
* @function type
|
|
172
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
173
|
+
* @category Decorators
|
|
174
|
+
*/
|
|
175
|
+
export function type(types, message = DEFAULT_ERROR_MESSAGES.TYPE) {
|
|
176
|
+
return propMetadata(Validation.key(ValidationKeys.TYPE), {
|
|
177
|
+
customTypes: types,
|
|
178
|
+
message: message,
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* @summary Date Handler Decorator
|
|
183
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
|
|
184
|
+
*
|
|
185
|
+
* Will enforce serialization according to the selected format
|
|
186
|
+
*
|
|
187
|
+
* @param {string} format accepted format according to {@link formatDate}
|
|
188
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#DATE}
|
|
189
|
+
* @param {Constructor<Validator>} [validator] the Validator to be used. Defaults to {@link DateValidator}
|
|
190
|
+
*
|
|
191
|
+
* @function date
|
|
192
|
+
*
|
|
193
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
194
|
+
* @category Decorators
|
|
195
|
+
*/
|
|
196
|
+
export function date(format = "dd/MM/yyyy", message = DEFAULT_ERROR_MESSAGES.DATE) {
|
|
197
|
+
return (target, propertyKey) => {
|
|
198
|
+
propMetadata(Validation.key(ValidationKeys.DATE), {
|
|
199
|
+
format: format,
|
|
200
|
+
message: message,
|
|
201
|
+
types: [Date.name],
|
|
202
|
+
})(target, propertyKey);
|
|
203
|
+
const values = new WeakMap();
|
|
204
|
+
Object.defineProperty(target, propertyKey, {
|
|
205
|
+
configurable: false,
|
|
206
|
+
set(newValue) {
|
|
207
|
+
const descriptor = Object.getOwnPropertyDescriptor(this, propertyKey);
|
|
208
|
+
if (!descriptor || descriptor.configurable)
|
|
209
|
+
Object.defineProperty(this, propertyKey, {
|
|
210
|
+
enumerable: true,
|
|
211
|
+
configurable: false,
|
|
212
|
+
get: () => values.get(this),
|
|
213
|
+
set: (newValue) => {
|
|
214
|
+
let val;
|
|
215
|
+
try {
|
|
216
|
+
val = parseDate(format, newValue);
|
|
217
|
+
values.set(this, val);
|
|
218
|
+
}
|
|
219
|
+
catch (e) {
|
|
220
|
+
console.error(sf("Failed to parse date: {0}", e.message || e));
|
|
221
|
+
}
|
|
222
|
+
},
|
|
223
|
+
});
|
|
224
|
+
this[propertyKey] = newValue;
|
|
225
|
+
},
|
|
226
|
+
get() {
|
|
227
|
+
console.log("here");
|
|
228
|
+
},
|
|
229
|
+
});
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* @summary Password Handler Decorator
|
|
234
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
|
235
|
+
*
|
|
236
|
+
* @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
|
|
237
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
|
|
238
|
+
* @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
|
|
239
|
+
*
|
|
240
|
+
* @function password
|
|
241
|
+
*
|
|
242
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
243
|
+
* @category Decorators
|
|
244
|
+
*/
|
|
245
|
+
export function password(pattern = DEFAULT_PATTERNS.PASSWORD.CHAR8_ONE_OF_EACH, message = DEFAULT_ERROR_MESSAGES.PASSWORD) {
|
|
246
|
+
return propMetadata(Validation.key(ValidationKeys.PASSWORD), {
|
|
247
|
+
pattern: pattern,
|
|
248
|
+
message: message,
|
|
249
|
+
types: [String.name],
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* @summary List Decorator
|
|
254
|
+
* @description Also sets the {@link type} to the provided collection
|
|
255
|
+
*
|
|
256
|
+
* @param {ModelConstructor} clazz
|
|
257
|
+
* @param {string} [collection] The collection being used. defaults to Array
|
|
258
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
259
|
+
* @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
|
|
260
|
+
*
|
|
261
|
+
* @function list
|
|
262
|
+
*
|
|
263
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
264
|
+
* @category Decorators
|
|
265
|
+
*/
|
|
266
|
+
export function list(clazz, collection = "Array", message = DEFAULT_ERROR_MESSAGES.LIST) {
|
|
267
|
+
return propMetadata(Validation.key(ValidationKeys.LIST), {
|
|
268
|
+
clazz: Array.isArray(clazz) ? clazz.map((c) => c.name) : [clazz.name],
|
|
269
|
+
type: collection,
|
|
270
|
+
message: message,
|
|
271
|
+
});
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* @summary Set Decorator
|
|
275
|
+
* @description Wrapper for {@link list} with the 'Set' Collection
|
|
276
|
+
*
|
|
277
|
+
* @param {ModelConstructor} clazz
|
|
278
|
+
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
279
|
+
* @param {Constructor<Validator>} [validator]
|
|
280
|
+
*
|
|
281
|
+
* @function set
|
|
282
|
+
*
|
|
283
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
284
|
+
* @category Decorators
|
|
285
|
+
*/
|
|
286
|
+
export function set(clazz, message = DEFAULT_ERROR_MESSAGES.LIST) {
|
|
287
|
+
return list(clazz, "Set", message);
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/validation/decorators.ts"],"names":[],"mappings":"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","file":"validation/decorators.js","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\";\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    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    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    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      minLength: 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      maxLength: 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      pattern: 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      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    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      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    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"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from "./Validators";
|
|
2
|
+
export * from "./decorators";
|
|
3
|
+
export * from "./types";
|
|
4
|
+
export * from "./Validation";
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy92YWxpZGF0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMsY0FBYyxDQUFDIiwiZmlsZSI6InZhbGlkYXRpb24vaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9WYWxpZGF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90eXBlc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vVmFsaWRhdGlvblwiO1xuIl19
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { DecoratorMetadata } from "@decaf-ts/reflection";
|
|
2
|
+
/**
|
|
3
|
+
* @summary Type for validation decorator metadata
|
|
4
|
+
* @memberOf module:decorator-validation.Reflection
|
|
5
|
+
* @category Reflection
|
|
6
|
+
*/
|
|
7
|
+
export type ValidationMetadata = {
|
|
8
|
+
[indexer: string]: any;
|
|
9
|
+
args?: any[];
|
|
10
|
+
message: string;
|
|
11
|
+
types?: string[];
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* @summary Type for a validator property decorator definition
|
|
15
|
+
* @memberOf module:decorator-validation.Validation
|
|
16
|
+
* @category Validation
|
|
17
|
+
*/
|
|
18
|
+
export type ValidationPropertyDecoratorDefinition = {
|
|
19
|
+
prop: string | symbol;
|
|
20
|
+
decorators: ValidationDecoratorDefinition[];
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* @summary Type for a validator decorator definition
|
|
24
|
+
* @memberOf module:decorator-validation.Validation
|
|
25
|
+
* @category Validation
|
|
26
|
+
*/
|
|
27
|
+
export type ValidationDecoratorDefinition = DecoratorMetadata & {
|
|
28
|
+
props: ValidationElementDefinition;
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* @summary Type for a validator element metadata
|
|
32
|
+
* @memberOf module:decorator-validation.Validation
|
|
33
|
+
* @category Validation
|
|
34
|
+
*/
|
|
35
|
+
export type ValidationElementDefinition = {
|
|
36
|
+
[indexer: string]: any;
|
|
37
|
+
value?: string | number;
|
|
38
|
+
message: string;
|
|
39
|
+
types?: string[];
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* @summary Type for a model errors
|
|
43
|
+
* @memberOf module:decorator-validation.Validation
|
|
44
|
+
* @category Validation
|
|
45
|
+
*/
|
|
46
|
+
export type ModelErrors = Record<string, Record<string, string | undefined>>;
|