@decaf-ts/decorator-validation 1.6.3 → 1.6.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decorator-validation.cjs +1016 -1164
- package/dist/decorator-validation.esm.cjs +971 -1134
- package/lib/constants/index.cjs +18 -0
- package/lib/constants/index.d.ts +1 -0
- package/lib/constants/validation.cjs +14 -0
- package/lib/constants/validation.d.ts +10 -0
- package/lib/esm/constants/index.d.ts +1 -0
- package/lib/esm/constants/index.js +2 -0
- package/lib/esm/constants/validation.d.ts +10 -0
- package/lib/esm/constants/validation.js +11 -0
- package/lib/esm/index.d.ts +37 -5
- package/lib/esm/index.js +38 -6
- package/lib/esm/model/Model.d.ts +29 -100
- package/lib/esm/model/Model.js +37 -104
- package/lib/esm/model/constants.d.ts +3 -3
- package/lib/esm/model/constants.js +4 -4
- package/lib/esm/model/construction.d.ts +3 -3
- package/lib/esm/model/construction.js +4 -4
- package/lib/esm/model/decorators.d.ts +4 -4
- package/lib/esm/model/decorators.js +5 -6
- package/lib/esm/model/types.d.ts +11 -30
- package/lib/esm/model/types.js +1 -1
- package/lib/esm/model/validation.d.ts +2 -2
- package/lib/esm/model/validation.js +18 -7
- package/lib/esm/utils/constants.d.ts +9 -27
- package/lib/esm/utils/constants.js +10 -28
- package/lib/esm/utils/dates.d.ts +16 -26
- package/lib/esm/utils/dates.js +17 -27
- package/lib/esm/utils/decorators.d.ts +0 -41
- package/lib/esm/utils/decorators.js +1 -42
- package/lib/esm/utils/hashing.d.ts +6 -50
- package/lib/esm/utils/hashing.js +5 -49
- package/lib/esm/utils/index.d.ts +0 -1
- package/lib/esm/utils/index.js +1 -2
- package/lib/esm/utils/registry.d.ts +2 -2
- package/lib/esm/utils/registry.js +1 -1
- package/lib/esm/utils/serialization.d.ts +1 -1
- package/lib/esm/utils/serialization.js +2 -2
- package/lib/esm/utils/strings.d.ts +4 -4
- package/lib/esm/utils/strings.js +5 -5
- package/lib/esm/utils/types.d.ts +16 -123
- package/lib/esm/utils/types.js +1 -1
- package/lib/esm/validation/Validators/DateValidator.d.ts +8 -40
- package/lib/esm/validation/Validators/DateValidator.js +9 -41
- package/lib/esm/validation/Validators/DiffValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/DiffValidator.js +58 -0
- package/lib/esm/validation/Validators/EmailValidator.d.ts +7 -39
- package/lib/esm/validation/Validators/EmailValidator.js +8 -40
- package/lib/esm/validation/Validators/EqualsValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/EqualsValidator.js +63 -0
- package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +65 -0
- package/lib/esm/validation/Validators/GreaterThanValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/GreaterThanValidator.js +62 -0
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +65 -0
- package/lib/esm/validation/Validators/LessThanValidator.d.ts +27 -0
- package/lib/esm/validation/Validators/LessThanValidator.js +62 -0
- package/lib/esm/validation/Validators/ListValidator.d.ts +6 -44
- package/lib/esm/validation/Validators/ListValidator.js +7 -45
- package/lib/esm/validation/Validators/MaxValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/MaxValidator.js +7 -53
- package/lib/esm/validation/Validators/MinValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/MinValidator.js +7 -53
- package/lib/esm/validation/Validators/PatternValidator.d.ts +9 -75
- package/lib/esm/validation/Validators/PatternValidator.js +10 -76
- package/lib/esm/validation/Validators/RequiredValidator.d.ts +6 -52
- package/lib/esm/validation/Validators/RequiredValidator.js +7 -53
- package/lib/esm/validation/Validators/TypeValidator.d.ts +6 -60
- package/lib/esm/validation/Validators/TypeValidator.js +7 -69
- package/lib/esm/validation/Validators/URLValidator.d.ts +7 -41
- package/lib/esm/validation/Validators/URLValidator.js +8 -42
- package/lib/esm/validation/Validators/Validator.d.ts +17 -77
- package/lib/esm/validation/Validators/Validator.js +11 -68
- package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +7 -1
- package/lib/esm/validation/Validators/ValidatorRegistry.js +11 -4
- package/lib/esm/validation/Validators/constants.d.ts +41 -0
- package/lib/esm/validation/Validators/constants.js +43 -1
- package/lib/esm/validation/Validators/index.d.ts +7 -0
- package/lib/esm/validation/Validators/index.js +8 -1
- package/lib/esm/validation/Validators/utils.d.ts +52 -0
- package/lib/esm/validation/Validators/utils.js +174 -0
- package/lib/esm/validation/decorators.d.ts +124 -50
- package/lib/esm/validation/decorators.js +173 -102
- package/lib/esm/validation/types.d.ts +46 -146
- package/lib/esm/validation/types.js +1 -1
- package/lib/index.cjs +39 -7
- package/lib/index.d.ts +37 -5
- package/lib/model/Model.cjs +39 -104
- package/lib/model/Model.d.ts +29 -100
- package/lib/model/constants.cjs +4 -4
- package/lib/model/constants.d.ts +3 -3
- package/lib/model/construction.cjs +4 -4
- package/lib/model/construction.d.ts +3 -3
- package/lib/model/decorators.cjs +5 -6
- package/lib/model/decorators.d.ts +4 -4
- package/lib/model/types.cjs +1 -1
- package/lib/model/types.d.ts +11 -30
- package/lib/model/validation.cjs +25 -14
- package/lib/model/validation.d.ts +2 -2
- package/lib/utils/constants.cjs +11 -29
- package/lib/utils/constants.d.ts +9 -27
- package/lib/utils/dates.cjs +17 -27
- package/lib/utils/dates.d.ts +16 -26
- package/lib/utils/decorators.cjs +1 -42
- package/lib/utils/decorators.d.ts +0 -41
- package/lib/utils/hashing.cjs +5 -49
- package/lib/utils/hashing.d.ts +6 -50
- package/lib/utils/index.cjs +1 -2
- package/lib/utils/index.d.ts +0 -1
- package/lib/utils/registry.cjs +1 -1
- package/lib/utils/registry.d.ts +2 -2
- package/lib/utils/serialization.cjs +2 -2
- package/lib/utils/serialization.d.ts +1 -1
- package/lib/utils/strings.cjs +5 -5
- package/lib/utils/strings.d.ts +4 -4
- package/lib/utils/types.cjs +1 -1
- package/lib/utils/types.d.ts +16 -123
- package/lib/validation/Validators/DateValidator.cjs +9 -41
- package/lib/validation/Validators/DateValidator.d.ts +8 -40
- package/lib/validation/Validators/DiffValidator.cjs +61 -0
- package/lib/validation/Validators/DiffValidator.d.ts +27 -0
- package/lib/validation/Validators/EmailValidator.cjs +8 -40
- package/lib/validation/Validators/EmailValidator.d.ts +7 -39
- package/lib/validation/Validators/EqualsValidator.cjs +66 -0
- package/lib/validation/Validators/EqualsValidator.d.ts +27 -0
- package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +68 -0
- package/lib/validation/Validators/GreaterThanOrEqualValidator.d.ts +27 -0
- package/lib/validation/Validators/GreaterThanValidator.cjs +65 -0
- package/lib/validation/Validators/GreaterThanValidator.d.ts +27 -0
- package/lib/validation/Validators/LessThanOrEqualValidator.cjs +68 -0
- package/lib/validation/Validators/LessThanOrEqualValidator.d.ts +27 -0
- package/lib/validation/Validators/LessThanValidator.cjs +65 -0
- package/lib/validation/Validators/LessThanValidator.d.ts +27 -0
- package/lib/validation/Validators/ListValidator.cjs +7 -45
- package/lib/validation/Validators/ListValidator.d.ts +6 -44
- package/lib/validation/Validators/MaxValidator.cjs +7 -53
- package/lib/validation/Validators/MaxValidator.d.ts +6 -52
- package/lib/validation/Validators/MinValidator.cjs +7 -53
- package/lib/validation/Validators/MinValidator.d.ts +6 -52
- package/lib/validation/Validators/PatternValidator.cjs +10 -76
- package/lib/validation/Validators/PatternValidator.d.ts +9 -75
- package/lib/validation/Validators/RequiredValidator.cjs +7 -53
- package/lib/validation/Validators/RequiredValidator.d.ts +6 -52
- package/lib/validation/Validators/TypeValidator.cjs +7 -69
- package/lib/validation/Validators/TypeValidator.d.ts +6 -60
- package/lib/validation/Validators/URLValidator.cjs +8 -42
- package/lib/validation/Validators/URLValidator.d.ts +7 -41
- package/lib/validation/Validators/Validator.cjs +11 -68
- package/lib/validation/Validators/Validator.d.ts +17 -77
- package/lib/validation/Validators/ValidatorRegistry.cjs +12 -4
- package/lib/validation/Validators/ValidatorRegistry.d.ts +7 -1
- package/lib/validation/Validators/constants.cjs +44 -2
- package/lib/validation/Validators/constants.d.ts +41 -0
- package/lib/validation/Validators/index.cjs +8 -1
- package/lib/validation/Validators/index.d.ts +7 -0
- package/lib/validation/Validators/utils.cjs +180 -0
- package/lib/validation/Validators/utils.d.ts +52 -0
- package/lib/validation/decorators.cjs +179 -102
- package/lib/validation/decorators.d.ts +124 -50
- package/lib/validation/types.cjs +1 -1
- package/lib/validation/types.d.ts +46 -146
- package/package.json +1 -1
- package/lib/esm/utils/Decoration.d.ts +0 -123
- package/lib/esm/utils/Decoration.js +0 -188
- package/lib/utils/Decoration.cjs +0 -192
- package/lib/utils/Decoration.d.ts +0 -123
|
@@ -1,54 +1,28 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
2
|
import { ModelConstructor } from "../model/types";
|
|
3
3
|
/**
|
|
4
|
-
* @
|
|
5
|
-
* @
|
|
6
|
-
* Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}.
|
|
7
|
-
* This decorator is commonly used as the first validation step for important fields.
|
|
4
|
+
* @summary Marks the property as required.
|
|
5
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#REQUIRED}
|
|
8
6
|
*
|
|
9
|
-
* @param {string} [message]
|
|
10
|
-
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
7
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#REQUIRED}
|
|
11
8
|
*
|
|
12
9
|
* @function required
|
|
13
|
-
* @category Decorators
|
|
14
|
-
*
|
|
15
|
-
* @example
|
|
16
|
-
* ```typescript
|
|
17
|
-
* class User {
|
|
18
|
-
* @required()
|
|
19
|
-
* username: string;
|
|
20
10
|
*
|
|
21
|
-
*
|
|
22
|
-
* email: string;
|
|
23
|
-
* }
|
|
24
|
-
* ```
|
|
11
|
+
* @category Decorators
|
|
25
12
|
*/
|
|
26
|
-
export declare function required(message?: string): (target: object, propertyKey?:
|
|
13
|
+
export declare function required(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
27
14
|
/**
|
|
28
|
-
* @
|
|
29
|
-
* @
|
|
30
|
-
* Validators to validate a decorated property must use key {@link ValidationKeys#MIN}.
|
|
31
|
-
* This decorator works with numeric values and dates.
|
|
15
|
+
* @summary Defines a minimum value for the property
|
|
16
|
+
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN}
|
|
32
17
|
*
|
|
33
|
-
* @param {number | Date
|
|
34
|
-
* @param {string} [message]
|
|
35
|
-
* @return {PropertyDecorator} A decorator function that can be applied to class properties
|
|
18
|
+
* @param {number | Date} value
|
|
19
|
+
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN}
|
|
36
20
|
*
|
|
37
21
|
* @function min
|
|
22
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
38
23
|
* @category Decorators
|
|
39
|
-
*
|
|
40
|
-
* @example
|
|
41
|
-
* ```typescript
|
|
42
|
-
* class Product {
|
|
43
|
-
* @min(0)
|
|
44
|
-
* price: number;
|
|
45
|
-
*
|
|
46
|
-
* @min(new Date(2023, 0, 1), "Date must be after January 1, 2023")
|
|
47
|
-
* releaseDate: Date;
|
|
48
|
-
* }
|
|
49
|
-
* ```
|
|
50
24
|
*/
|
|
51
|
-
export declare function min(value: number | Date | string, message?: string): (target: object, propertyKey?:
|
|
25
|
+
export declare function min(value: number | Date | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
52
26
|
/**
|
|
53
27
|
* @summary Defines a maximum value for the property
|
|
54
28
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX}
|
|
@@ -57,9 +31,10 @@ export declare function min(value: number | Date | string, message?: string): (t
|
|
|
57
31
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX}
|
|
58
32
|
*
|
|
59
33
|
* @function max
|
|
34
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
60
35
|
* @category Decorators
|
|
61
36
|
*/
|
|
62
|
-
export declare function max(value: number | Date | string, message?: string): (target: object, propertyKey?:
|
|
37
|
+
export declare function max(value: number | Date | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
63
38
|
/**
|
|
64
39
|
* @summary Defines a step value for the property
|
|
65
40
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#STEP}
|
|
@@ -68,9 +43,10 @@ export declare function max(value: number | Date | string, message?: string): (t
|
|
|
68
43
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#STEP}
|
|
69
44
|
*
|
|
70
45
|
* @function step
|
|
46
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
71
47
|
* @category Decorators
|
|
72
48
|
*/
|
|
73
|
-
export declare function step(value: number, message?: string): (target: object, propertyKey?:
|
|
49
|
+
export declare function step(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
74
50
|
/**
|
|
75
51
|
* @summary Defines a minimum length for the property
|
|
76
52
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MIN_LENGTH}
|
|
@@ -79,9 +55,10 @@ export declare function step(value: number, message?: string): (target: object,
|
|
|
79
55
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MIN_LENGTH}
|
|
80
56
|
*
|
|
81
57
|
* @function minlength
|
|
58
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
82
59
|
* @category Decorators
|
|
83
60
|
*/
|
|
84
|
-
export declare function minlength(value: number, message?: string): (target: object, propertyKey?:
|
|
61
|
+
export declare function minlength(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
85
62
|
/**
|
|
86
63
|
* @summary Defines a maximum length for the property
|
|
87
64
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#MAX_LENGTH}
|
|
@@ -90,9 +67,10 @@ export declare function minlength(value: number, message?: string): (target: obj
|
|
|
90
67
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#MAX_LENGTH}
|
|
91
68
|
*
|
|
92
69
|
* @function maxlength
|
|
70
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
93
71
|
* @category Decorators
|
|
94
72
|
*/
|
|
95
|
-
export declare function maxlength(value: number, message?: string): (target: object, propertyKey?:
|
|
73
|
+
export declare function maxlength(value: number, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
96
74
|
/**
|
|
97
75
|
* @summary Defines a RegExp pattern the property must respect
|
|
98
76
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PATTERN}
|
|
@@ -101,9 +79,10 @@ export declare function maxlength(value: number, message?: string): (target: obj
|
|
|
101
79
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PATTERN}
|
|
102
80
|
*
|
|
103
81
|
* @function pattern
|
|
82
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
104
83
|
* @category Decorators
|
|
105
84
|
*/
|
|
106
|
-
export declare function pattern(value: RegExp | string, message?: string): (target: object, propertyKey?:
|
|
85
|
+
export declare function pattern(value: RegExp | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
107
86
|
/**
|
|
108
87
|
* @summary Defines the property as an email
|
|
109
88
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#EMAIL}
|
|
@@ -111,9 +90,10 @@ export declare function pattern(value: RegExp | string, message?: string): (targ
|
|
|
111
90
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#EMAIL}
|
|
112
91
|
*
|
|
113
92
|
* @function email
|
|
93
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
114
94
|
* @category Decorators
|
|
115
95
|
*/
|
|
116
|
-
export declare function email(message?: string): (target: object, propertyKey?:
|
|
96
|
+
export declare function email(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
117
97
|
/**
|
|
118
98
|
* @summary Defines the property as an URL
|
|
119
99
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#URL}
|
|
@@ -121,9 +101,10 @@ export declare function email(message?: string): (target: object, propertyKey?:
|
|
|
121
101
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#URL}
|
|
122
102
|
*
|
|
123
103
|
* @function url
|
|
104
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
124
105
|
* @category Decorators
|
|
125
106
|
*/
|
|
126
|
-
export declare function url(message?: string): (target: object, propertyKey?:
|
|
107
|
+
export declare function url(message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
127
108
|
/**
|
|
128
109
|
* @summary Enforces type verification
|
|
129
110
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#TYPE}
|
|
@@ -132,9 +113,10 @@ export declare function url(message?: string): (target: object, propertyKey?: an
|
|
|
132
113
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#TYPE}
|
|
133
114
|
*
|
|
134
115
|
* @function type
|
|
116
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
135
117
|
* @category Decorators
|
|
136
118
|
*/
|
|
137
|
-
export declare function type(types: string[] | string, message?: string): (target: object, propertyKey?:
|
|
119
|
+
export declare function type(types: string[] | string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
138
120
|
/**
|
|
139
121
|
* @summary Date Handler Decorator
|
|
140
122
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#DATE}
|
|
@@ -143,24 +125,28 @@ export declare function type(types: string[] | string, message?: string): (targe
|
|
|
143
125
|
*
|
|
144
126
|
* @param {string} format accepted format according to {@link formatDate}
|
|
145
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}
|
|
146
129
|
*
|
|
147
130
|
* @function date
|
|
148
131
|
*
|
|
132
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
149
133
|
* @category Decorators
|
|
150
134
|
*/
|
|
151
|
-
export declare function date(format?: string, message?: string): (target:
|
|
135
|
+
export declare function date(format?: string, message?: string): (target: Record<string, any>, propertyKey?: any) => any;
|
|
152
136
|
/**
|
|
153
137
|
* @summary Password Handler Decorator
|
|
154
138
|
* @description Validators to validate a decorated property must use key {@link ValidationKeys#PASSWORD}
|
|
155
139
|
*
|
|
156
|
-
* @param {RegExp} [pattern] defaults to {@link
|
|
140
|
+
* @param {RegExp} [pattern] defaults to {@link PasswordPatterns#CHAR8_ONE_OF_EACH}
|
|
157
141
|
* @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES#PASSWORD}
|
|
142
|
+
* @param {Constructor<Validator>} [validator] Defaults to {@link PasswordValidator}
|
|
158
143
|
*
|
|
159
144
|
* @function password
|
|
160
145
|
*
|
|
146
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
161
147
|
* @category Decorators
|
|
162
148
|
*/
|
|
163
|
-
export declare function password(pattern?: RegExp, message?: string): (target: object, propertyKey?:
|
|
149
|
+
export declare function password(pattern?: RegExp, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
164
150
|
/**
|
|
165
151
|
* @summary List Decorator
|
|
166
152
|
* @description Also sets the {@link type} to the provided collection
|
|
@@ -168,21 +154,109 @@ export declare function password(pattern?: RegExp, message?: string): (target: o
|
|
|
168
154
|
* @param {ModelConstructor} clazz
|
|
169
155
|
* @param {string} [collection] The collection being used. defaults to Array
|
|
170
156
|
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
157
|
+
* @param {Constructor<Validator>} [validator] defaults to {@link ListValidator}
|
|
171
158
|
*
|
|
172
159
|
* @function list
|
|
173
160
|
*
|
|
161
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
174
162
|
* @category Decorators
|
|
175
163
|
*/
|
|
176
|
-
export declare function list(clazz: ModelConstructor<any> | ModelConstructor<any>[], collection?: "Array" | "Set", message?: string): (target: object, propertyKey?:
|
|
164
|
+
export declare function list(clazz: ModelConstructor<any> | ModelConstructor<any>[], collection?: "Array" | "Set", message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
177
165
|
/**
|
|
178
166
|
* @summary Set Decorator
|
|
179
167
|
* @description Wrapper for {@link list} with the 'Set' Collection
|
|
180
168
|
*
|
|
181
169
|
* @param {ModelConstructor} clazz
|
|
182
170
|
* @param {string} [message] defaults to {@link DEFAULT_ERROR_MESSAGES#LIST}
|
|
171
|
+
* @param {Constructor<Validator>} [validator]
|
|
183
172
|
*
|
|
184
173
|
* @function set
|
|
185
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;
|
|
179
|
+
/**
|
|
180
|
+
* @summary Declares that the decorated property must be equal to another specified property.
|
|
181
|
+
* @description Applies the {@link ValidationKeys.EQUALS} validator to ensure the decorated value matches the value of the given property.
|
|
182
|
+
*
|
|
183
|
+
* @param {string} propertyToCompare - The name of the property to compare equality against.
|
|
184
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.EQUALS] - Custom error message to return if validation fails.
|
|
185
|
+
*
|
|
186
|
+
* @returns {PropertyDecorator} A property decorator used to register the equality validation metadata.
|
|
187
|
+
*
|
|
188
|
+
* @function eq
|
|
189
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
190
|
+
* @category Decorators
|
|
191
|
+
*/
|
|
192
|
+
export declare function eq(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
193
|
+
/**
|
|
194
|
+
* @summary Declares that the decorated property must be different from another specified property.
|
|
195
|
+
* @description Applies the {@link ValidationKeys.DIFF} validator to ensure the decorated value is different from the value of the given property.
|
|
196
|
+
*
|
|
197
|
+
* @param {string} propertyToCompare - The name of the property to compare difference against.
|
|
198
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.DIFF] - Custom error message to return if validation fails.
|
|
199
|
+
*
|
|
200
|
+
* @returns {PropertyDecorator} A property decorator used to register the difference validation metadata.
|
|
201
|
+
*
|
|
202
|
+
* @function diff
|
|
203
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
204
|
+
* @category Decorators
|
|
205
|
+
*/
|
|
206
|
+
export declare function diff(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
207
|
+
/**
|
|
208
|
+
* @summary Declares that the decorated property must be less than another specified property.
|
|
209
|
+
* @description Applies the {@link ValidationKeys.LESS_THAN} validator to ensure the decorated value is less than the value of the given property.
|
|
210
|
+
*
|
|
211
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
212
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN] - Custom error message to return if validation fails.
|
|
213
|
+
*
|
|
214
|
+
* @returns {PropertyDecorator} A property decorator used to register the less than validation metadata.
|
|
215
|
+
*
|
|
216
|
+
* @function lt
|
|
217
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
218
|
+
* @category Decorators
|
|
219
|
+
*/
|
|
220
|
+
export declare function lt(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
221
|
+
/**
|
|
222
|
+
* @summary Declares that the decorated property must be equal or less than another specified property.
|
|
223
|
+
* @description Applies the {@link ValidationKeys.LESS_THAN_OR_EQUAL} validator to ensure the decorated value is equal or less than the value of the given property.
|
|
224
|
+
*
|
|
225
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
226
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.LESS_THAN_OR_EQUAL] - Custom error message to return if validation fails.
|
|
227
|
+
*
|
|
228
|
+
* @returns {PropertyDecorator} A property decorator used to register the less than or equal validation metadata.
|
|
229
|
+
*
|
|
230
|
+
* @function lte
|
|
231
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
232
|
+
* @category Decorators
|
|
233
|
+
*/
|
|
234
|
+
export declare function lte(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
235
|
+
/**
|
|
236
|
+
* @summary Declares that the decorated property must be greater than another specified property.
|
|
237
|
+
* @description Applies the {@link ValidationKeys.GREATER_THAN} validator to ensure the decorated value is greater than the value of the given property.
|
|
238
|
+
*
|
|
239
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
240
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN] - Custom error message to return if validation fails.
|
|
241
|
+
*
|
|
242
|
+
* @returns {PropertyDecorator} A property decorator used to register the greater than validation metadata.
|
|
243
|
+
*
|
|
244
|
+
* @function gt
|
|
245
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
246
|
+
* @category Decorators
|
|
247
|
+
*/
|
|
248
|
+
export declare function gt(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
249
|
+
/**
|
|
250
|
+
* @summary Declares that the decorated property must be equal or greater than another specified property.
|
|
251
|
+
* @description Applies the {@link ValidationKeys.GREATER_THAN_OR_EQUAL} validator to ensure the decorated value is equal or greater than the value of the given property.
|
|
252
|
+
*
|
|
253
|
+
* @param {string} propertyToCompare - The name of the property to compare against.
|
|
254
|
+
* @param {string} [message=DEFAULT_ERROR_MESSAGES.GREATER_THAN_OR_EQUAL] - Custom error message to return if validation fails.
|
|
255
|
+
*
|
|
256
|
+
* @returns {PropertyDecorator} A property decorator used to register the greater than or equal validation metadata.
|
|
257
|
+
*
|
|
258
|
+
* @function gte
|
|
259
|
+
* @memberOf module:decorator-validation.Decorators.Validation
|
|
186
260
|
* @category Decorators
|
|
187
261
|
*/
|
|
188
|
-
export declare function
|
|
262
|
+
export declare function gte(propertyToCompare: string, message?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
package/lib/validation/types.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const Validators_1 = require("./Validators/index.cjs");
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/validation/types.ts"],"names":[],"mappings":";;AAEA,6CAAyD","sourcesContent":["import { DecoratorMetadata } from \"@decaf-ts/reflection\";\nimport { Constructor } from \"../model\";\nimport { ValidationKeys, Validator } from \"./Validators\";\nimport { IRegistry } from \"../utils\";\n\n/**\n * @description Type definition for metadata used by validation decorators\n * @summary Defines the structure of metadata attached to properties by validation decorators.\n * This metadata is used during validation to determine validation rules and error messages.\n *\n * @property {any[]} [args] - Optional arguments for the validator\n * @property {string} message - Error message to display when validation fails\n * @property {string[]} [types] - Array of type names that the property can have\n *\n * @typedef {Object} ValidationMetadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationMetadata = {\n  [indexer: string]: any;\n  args?: any[];\n  message: string;\n  types?: string[];\n};\n\n/**\n * @description Type definition for property-level validation decorator configuration\n * @summary Defines the structure that associates a property with its validation decorators.\n * This type is used to track which decorators are applied to a specific property during validation.\n *\n * @property {string|symbol} prop - The property name or symbol that the decorators are applied to\n * @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property\n *\n * @typedef {Object} ValidationPropertyDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationPropertyDecoratorDefinition = {\n  prop: string | symbol;\n  decorators: ValidationDecoratorDefinition[];\n};\n\n/**\n * @description Type definition for individual validation decorator metadata\n * @summary Extends the base DecoratorMetadata type with validation-specific properties.\n * This type represents the metadata for a single validation decorator applied to a property.\n *\n * @property {ValidationElementDefinition} props - The validation element properties and configuration\n *\n * @typedef {Object} ValidationDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationDecoratorDefinition = DecoratorMetadata & {\n  props: ValidationElementDefinition;\n};\n\n/**\n * @summary Type for a validator element metadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationElementDefinition = {\n  [indexer: string]: any;\n\n  value?: string | number;\n  message: string;\n  types?: string[];\n};\n\n/**\n * @summary Type for a model errors\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ModelErrors = Record<string, Record<string, string | undefined>>;\n\n/**\n * @summary Util type for {@link Validator} configuration\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorDefinition = {\n  validator: Constructor<Validator>;\n  validationKey: string;\n  save: boolean;\n};\n\n/**\n * @description Interface for a registry that manages validator instances\n * @summary Defines the contract for a registry that stores and retrieves validators.\n * The registry is responsible for maintaining a collection of validators and providing\n * access to them by key.\n *\n * @interface IValidatorRegistry\n * @template T Type of validator, must extend Validator\n * @extends IRegistry<T>\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {\n  /**\n   * @description Retrieves custom validation keys defined in the registry\n   * @summary Returns a mapping of custom validation keys to their corresponding standard keys.\n   * This allows for aliasing validation keys for specific use cases.\n   *\n   * @return {Record<string, string>} Object mapping custom keys to standard validation keys\n   */\n  getCustomKeys(): Record<string, string>;\n\n  /**\n   * @description Gets all registered validator keys\n   * @summary Returns an array of all validation keys that have registered validators.\n   *\n   * @return {string[]} Array of registered validator keys\n   */\n  getKeys(): string[];\n\n  /**\n   * @description Registers one or more validators with the registry\n   * @summary Adds validators to the registry, making them available for validation operations.\n   * Validators can be provided as instances or as validator definitions.\n   *\n   * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register\n   * @return {void}\n   */\n  register<T extends Validator>(\n    ...validator: (T | ValidatorDefinition)[]\n  ): void;\n\n  /**\n   * @description Retrieves a validator by its key\n   * @summary Looks up a validator in the registry using its validation key.\n   * Returns the validator if found, or undefined if no validator is registered for the key.\n   *\n   * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}\n   * @return {T|undefined} The registered validator or undefined if none matches the provided key\n   */\n  get<T extends Validator>(key: string): T | undefined;\n}\n\n/**\n * @description Base options type for all validators\n * @summary Defines the common properties available to all validators\n * @typedef ValidatorOptions\n * @property {string} [message] - Custom error message to display when validation fails\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorOptions = {\n  message?: string;\n};\n\n/**\n * @description URL validation options interface\n * @summary Defines options for URL validation, including allowed URL types\n * @interface URLValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface URLValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Type validation options interface\n * @summary Defines options for type validation, specifying allowed types\n * @interface TypeValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Step validation options interface\n * @summary Defines options for step validation, specifying the step increment\n * @interface StepValidatorOptions\n * @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface StepValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.STEP]: number | string;\n}\n\n/**\n * @description Pattern validation options interface\n * @summary Defines options for pattern validation using regular expressions\n * @interface PatternValidatorOptions\n * @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface PatternValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.PATTERN]?: RegExp | string;\n}\n\n/**\n * @description Minimum value validation options interface\n * @summary Defines options for minimum value validation\n * @interface MinValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN]: number | Date | string;\n}\n\n/**\n * @description Minimum length validation options interface\n * @summary Defines options for minimum length validation\n * @interface MinLengthValidatorOptions\n * @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN_LENGTH]: number;\n}\n\n/**\n * @description Maximum value validation options interface\n * @summary Defines options for maximum value validation\n * @interface MaxValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX]: number | Date | string;\n}\n\n/**\n * @description Maximum length validation options interface\n * @summary Defines options for maximum length validation\n * @interface MaxLengthValidatorOptions\n * @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX_LENGTH]: number;\n}\n\n/**\n * @description List validation options interface\n * @summary Defines options for list validation\n * @interface ListValidatorOptions\n * @property {string[]} clazz - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface ListValidatorOptions extends ValidatorOptions {\n  clazz: string[];\n}\n\n/**\n * @description Date validation options interface\n * @summary Defines options for date validation\n * @interface DateValidatorOptions\n * @property {string} [ValidationKeys.FORMAT] - The expected date format pattern\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface DateValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.FORMAT]?: string;\n}\n"]}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdmFsaWRhdGlvbi90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBLDZDQUF5RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlY29yYXRvck1ldGFkYXRhIH0gZnJvbSBcIkBkZWNhZi10cy9yZWZsZWN0aW9uXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gXCIuLi9tb2RlbFwiO1xuaW1wb3J0IHsgVmFsaWRhdGlvbktleXMsIFZhbGlkYXRvciB9IGZyb20gXCIuL1ZhbGlkYXRvcnNcIjtcbmltcG9ydCB7IElSZWdpc3RyeSB9IGZyb20gXCIuLi91dGlsc1wiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IFR5cGUgZm9yIHZhbGlkYXRpb24gZGVjb3JhdG9yIG1ldGFkYXRhXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uLlJlZmxlY3Rpb25cbiAqIEBjYXRlZ29yeSBSZWZsZWN0aW9uXG4gKi9cbmV4cG9ydCB0eXBlIFZhbGlkYXRpb25NZXRhZGF0YSA9IHtcbiAgW2luZGV4ZXI6IHN0cmluZ106IGFueTtcbiAgYXJncz86IGFueVtdO1xuICBtZXNzYWdlOiBzdHJpbmc7XG4gIHR5cGVzPzogc3RyaW5nW107XG59O1xuXG4vKipcbiAqIEBzdW1tYXJ5IFR5cGUgZm9yIGEgdmFsaWRhdG9yIHByb3BlcnR5IGRlY29yYXRvciBkZWZpbml0aW9uXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uLlZhbGlkYXRpb25cbiAqIEBjYXRlZ29yeSBWYWxpZGF0aW9uXG4gKi9cbmV4cG9ydCB0eXBlIFZhbGlkYXRpb25Qcm9wZXJ0eURlY29yYXRvckRlZmluaXRpb24gPSB7XG4gIHByb3A6IHN0cmluZyB8IHN5bWJvbDtcbiAgZGVjb3JhdG9yczogVmFsaWRhdGlvbkRlY29yYXRvckRlZmluaXRpb25bXTtcbn07XG5cbi8qKlxuICogQHN1bW1hcnkgVHlwZSBmb3IgYSB2YWxpZGF0b3IgZGVjb3JhdG9yIGRlZmluaXRpb25cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uVmFsaWRhdGlvblxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgVmFsaWRhdGlvbkRlY29yYXRvckRlZmluaXRpb24gPSBEZWNvcmF0b3JNZXRhZGF0YSAmIHtcbiAgcHJvcHM6IFZhbGlkYXRpb25FbGVtZW50RGVmaW5pdGlvbjtcbn07XG5cbi8qKlxuICogQHN1bW1hcnkgVHlwZSBmb3IgYSB2YWxpZGF0b3IgZWxlbWVudCBtZXRhZGF0YVxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvbi5WYWxpZGF0aW9uXG4gKiBAY2F0ZWdvcnkgVmFsaWRhdGlvblxuICovXG5leHBvcnQgdHlwZSBWYWxpZGF0aW9uRWxlbWVudERlZmluaXRpb24gPSB7XG4gIFtpbmRleGVyOiBzdHJpbmddOiBhbnk7XG5cbiAgdmFsdWU/OiBzdHJpbmcgfCBudW1iZXI7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgdHlwZXM/OiBzdHJpbmdbXTtcbn07XG5cbi8qKlxuICogQHN1bW1hcnkgVHlwZSBmb3IgYSBtb2RlbCBlcnJvcnNcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uVmFsaWRhdGlvblxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgTW9kZWxFcnJvcnMgPSBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+PjtcblxuLyoqXG4gKiBAc3VtbWFyeSBVdGlsIHR5cGUgZm9yIHtAbGluayBWYWxpZGF0b3J9IGNvbmZpZ3VyYXRpb25cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uVmFsaWRhdGlvblxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgVmFsaWRhdG9yRGVmaW5pdGlvbiA9IHtcbiAgdmFsaWRhdG9yOiBDb25zdHJ1Y3RvcjxWYWxpZGF0b3I+O1xuICB2YWxpZGF0aW9uS2V5OiBzdHJpbmc7XG4gIHNhdmU6IGJvb2xlYW47XG59O1xuXG4vKipcbiAqIEBzdW1tYXJ5IEJhc2UgQVBJIGZvciBhIHtAbGluayBWYWxpZGF0b3J9IHJlZ2lzdHJ5XG4gKlxuICogQGludGVyZmFjZSBWYWxpZGF0b3JSZWdpc3RyeVxuICogQGV4dGVuZHMgSVJlZ2lzdHJ5XG4gKlxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJVmFsaWRhdG9yUmVnaXN0cnk8VCBleHRlbmRzIFZhbGlkYXRvcj4gZXh0ZW5kcyBJUmVnaXN0cnk8VD4ge1xuICAvKipcbiAgICogQHN1bW1hcnkgcmV0cmlldmVzIHRoZSBjdXN0b20ga2V5c1xuICAgKiBAbWV0aG9kXG4gICAqL1xuICBnZXRDdXN0b21LZXlzKCk6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG5cbiAgLyoqXG4gICAqIEBzdW1tYXJ5IFJldHJpZXZlcyB0aGUgUmVnaXN0ZXJlZCB2YWxpZGF0b3Iga2V5c1xuICAgKiBAcmV0dXJuIHtzdHJpbmdbXX0gdGhlIHJlZ2lzdGVyZWQgdmFsaWRhdG9ycyBrZXlzXG4gICAqIEBtZXRob2RcbiAgICovXG4gIGdldEtleXMoKTogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIEBzdW1tYXJ5IFJlZ2lzdGVycyB0aGUgcHJvdmlkZWQgdmFsaWRhdG9ycyBvbnRvIHRoZSByZWdpc3RyeVxuICAgKlxuICAgKiBAdHlwZWRlZiBUIGV4dGVuZHMgVmFsaWRhdG9yXG4gICAqIEBwYXJhbSB7VFtdIHwgVmFsaWRhdG9yRGVmaW5pdGlvbltdfSB2YWxpZGF0b3JcbiAgICogQG1ldGhvZFxuICAgKi9cbiAgcmVnaXN0ZXI8VCBleHRlbmRzIFZhbGlkYXRvcj4oXG4gICAgLi4udmFsaWRhdG9yOiAoVCB8IFZhbGlkYXRvckRlZmluaXRpb24pW11cbiAgKTogdm9pZDtcblxuICAvKipcbiAgICogQHN1bW1hcnkgUmV0cmlldmVzIHRoZSBWYWxpZGF0b3IgY29uc3RydWN0b3IgaWYgcmVnaXN0ZXJlZFxuICAgKlxuICAgKiBAdHlwZWRlZiBUIGV4dGVuZHMgVmFsaWRhdG9yXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgb25lIG9mIHRoZSB7QGxpbmsgVmFsaWRhdGlvbktleXN9XG4gICAqIEByZXR1cm4ge1ZhbGlkYXRvciB8IHVuZGVmaW5lZH0gdGhlIHJlZ2lzdGVyZWQgVmFsaWRhdG9yIG9yIHVuZGVmaW5lZCBpZiB0aGVyZSBpcyBub25vIG1hdGNoaW5nIHRoZSBwcm92aWRlZCBrZXlcbiAgICogQG1ldGhvZFxuICAgKi9cbiAgZ2V0PFQgZXh0ZW5kcyBWYWxpZGF0b3I+KGtleTogc3RyaW5nKTogVCB8IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0IHR5cGUgVmFsaWRhdG9yT3B0aW9ucyA9IHtcbiAgbWVzc2FnZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgVVJMVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICB0eXBlczogc3RyaW5nIHwgc3RyaW5nW10gfCB7IG5hbWU6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFR5cGVWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIHR5cGVzOiBzdHJpbmcgfCBzdHJpbmdbXSB8IHsgbmFtZTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3RlcFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLlNURVBdOiBudW1iZXIgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGF0dGVyblZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLlBBVFRFUk5dPzogUmVnRXhwIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1pblZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLk1JTl06IG51bWJlciB8IERhdGUgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWluTGVuZ3RoVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuTUlOX0xFTkdUSF06IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNYXhWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5NQVhdOiBudW1iZXIgfCBEYXRlIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1heExlbmd0aFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLk1BWF9MRU5HVEhdOiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgY2xheno6IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERhdGVWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5GT1JNQVRdPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVxdWFsc1ZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLkVRVUFMU106IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEaWZmVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuRElGRl06IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMZXNzVGhhblZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLkxFU1NfVEhBTl06IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMZXNzVGhhbk9yRXF1YWxWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5MRVNTX1RIQU5fT1JfRVFVQUxdOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JlYXRlclRoYW5WYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5HUkVBVEVSX1RIQU5dOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JlYXRlclRoYW5PckVxdWFsVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuR1JFQVRFUl9USEFOX09SX0VRVUFMXTogc3RyaW5nO1xufVxuIl19
|
|
@@ -3,17 +3,9 @@ import { Constructor } from "../model";
|
|
|
3
3
|
import { ValidationKeys, Validator } from "./Validators";
|
|
4
4
|
import { IRegistry } from "../utils";
|
|
5
5
|
/**
|
|
6
|
-
* @
|
|
7
|
-
* @
|
|
8
|
-
*
|
|
9
|
-
*
|
|
10
|
-
* @property {any[]} [args] - Optional arguments for the validator
|
|
11
|
-
* @property {string} message - Error message to display when validation fails
|
|
12
|
-
* @property {string[]} [types] - Array of type names that the property can have
|
|
13
|
-
*
|
|
14
|
-
* @typedef {Object} ValidationMetadata
|
|
15
|
-
* @memberOf module:decorator-validation
|
|
16
|
-
* @category Validation
|
|
6
|
+
* @summary Type for validation decorator metadata
|
|
7
|
+
* @memberOf module:decorator-validation.Reflection
|
|
8
|
+
* @category Reflection
|
|
17
9
|
*/
|
|
18
10
|
export type ValidationMetadata = {
|
|
19
11
|
[indexer: string]: any;
|
|
@@ -22,15 +14,8 @@ export type ValidationMetadata = {
|
|
|
22
14
|
types?: string[];
|
|
23
15
|
};
|
|
24
16
|
/**
|
|
25
|
-
* @
|
|
26
|
-
* @
|
|
27
|
-
* This type is used to track which decorators are applied to a specific property during validation.
|
|
28
|
-
*
|
|
29
|
-
* @property {string|symbol} prop - The property name or symbol that the decorators are applied to
|
|
30
|
-
* @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property
|
|
31
|
-
*
|
|
32
|
-
* @typedef {Object} ValidationPropertyDecoratorDefinition
|
|
33
|
-
* @memberOf module:decorator-validation
|
|
17
|
+
* @summary Type for a validator property decorator definition
|
|
18
|
+
* @memberOf module:decorator-validation.Validation
|
|
34
19
|
* @category Validation
|
|
35
20
|
*/
|
|
36
21
|
export type ValidationPropertyDecoratorDefinition = {
|
|
@@ -38,14 +23,8 @@ export type ValidationPropertyDecoratorDefinition = {
|
|
|
38
23
|
decorators: ValidationDecoratorDefinition[];
|
|
39
24
|
};
|
|
40
25
|
/**
|
|
41
|
-
* @
|
|
42
|
-
* @
|
|
43
|
-
* This type represents the metadata for a single validation decorator applied to a property.
|
|
44
|
-
*
|
|
45
|
-
* @property {ValidationElementDefinition} props - The validation element properties and configuration
|
|
46
|
-
*
|
|
47
|
-
* @typedef {Object} ValidationDecoratorDefinition
|
|
48
|
-
* @memberOf module:decorator-validation
|
|
26
|
+
* @summary Type for a validator decorator definition
|
|
27
|
+
* @memberOf module:decorator-validation.Validation
|
|
49
28
|
* @category Validation
|
|
50
29
|
*/
|
|
51
30
|
export type ValidationDecoratorDefinition = DecoratorMetadata & {
|
|
@@ -53,7 +32,7 @@ export type ValidationDecoratorDefinition = DecoratorMetadata & {
|
|
|
53
32
|
};
|
|
54
33
|
/**
|
|
55
34
|
* @summary Type for a validator element metadata
|
|
56
|
-
* @memberOf module:decorator-validation
|
|
35
|
+
* @memberOf module:decorator-validation.Validation
|
|
57
36
|
* @category Validation
|
|
58
37
|
*/
|
|
59
38
|
export type ValidationElementDefinition = {
|
|
@@ -64,13 +43,13 @@ export type ValidationElementDefinition = {
|
|
|
64
43
|
};
|
|
65
44
|
/**
|
|
66
45
|
* @summary Type for a model errors
|
|
67
|
-
* @memberOf module:decorator-validation
|
|
46
|
+
* @memberOf module:decorator-validation.Validation
|
|
68
47
|
* @category Validation
|
|
69
48
|
*/
|
|
70
49
|
export type ModelErrors = Record<string, Record<string, string | undefined>>;
|
|
71
50
|
/**
|
|
72
51
|
* @summary Util type for {@link Validator} configuration
|
|
73
|
-
* @memberOf module:decorator-validation
|
|
52
|
+
* @memberOf module:decorator-validation.Validation
|
|
74
53
|
* @category Validation
|
|
75
54
|
*/
|
|
76
55
|
export type ValidatorDefinition = {
|
|
@@ -79,174 +58,95 @@ export type ValidatorDefinition = {
|
|
|
79
58
|
save: boolean;
|
|
80
59
|
};
|
|
81
60
|
/**
|
|
82
|
-
* @
|
|
83
|
-
*
|
|
84
|
-
*
|
|
85
|
-
*
|
|
61
|
+
* @summary Base API for a {@link Validator} registry
|
|
62
|
+
*
|
|
63
|
+
* @interface ValidatorRegistry
|
|
64
|
+
* @extends IRegistry
|
|
86
65
|
*
|
|
87
|
-
* @interface IValidatorRegistry
|
|
88
|
-
* @template T Type of validator, must extend Validator
|
|
89
|
-
* @extends IRegistry<T>
|
|
90
|
-
* @memberOf module:decorator-validation
|
|
91
66
|
* @category Validation
|
|
92
67
|
*/
|
|
93
68
|
export interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {
|
|
94
69
|
/**
|
|
95
|
-
* @
|
|
96
|
-
* @
|
|
97
|
-
* This allows for aliasing validation keys for specific use cases.
|
|
98
|
-
*
|
|
99
|
-
* @return {Record<string, string>} Object mapping custom keys to standard validation keys
|
|
70
|
+
* @summary retrieves the custom keys
|
|
71
|
+
* @method
|
|
100
72
|
*/
|
|
101
73
|
getCustomKeys(): Record<string, string>;
|
|
102
74
|
/**
|
|
103
|
-
* @
|
|
104
|
-
* @
|
|
105
|
-
*
|
|
106
|
-
* @return {string[]} Array of registered validator keys
|
|
75
|
+
* @summary Retrieves the Registered validator keys
|
|
76
|
+
* @return {string[]} the registered validators keys
|
|
77
|
+
* @method
|
|
107
78
|
*/
|
|
108
79
|
getKeys(): string[];
|
|
109
80
|
/**
|
|
110
|
-
* @
|
|
111
|
-
* @summary Adds validators to the registry, making them available for validation operations.
|
|
112
|
-
* Validators can be provided as instances or as validator definitions.
|
|
81
|
+
* @summary Registers the provided validators onto the registry
|
|
113
82
|
*
|
|
114
|
-
* @
|
|
115
|
-
* @
|
|
83
|
+
* @typedef T extends Validator
|
|
84
|
+
* @param {T[] | ValidatorDefinition[]} validator
|
|
85
|
+
* @method
|
|
116
86
|
*/
|
|
117
87
|
register<T extends Validator>(...validator: (T | ValidatorDefinition)[]): void;
|
|
118
88
|
/**
|
|
119
|
-
* @
|
|
120
|
-
* @summary Looks up a validator in the registry using its validation key.
|
|
121
|
-
* Returns the validator if found, or undefined if no validator is registered for the key.
|
|
89
|
+
* @summary Retrieves the Validator constructor if registered
|
|
122
90
|
*
|
|
123
|
-
* @
|
|
124
|
-
* @
|
|
91
|
+
* @typedef T extends Validator
|
|
92
|
+
* @param {string} key one of the {@link ValidationKeys}
|
|
93
|
+
* @return {Validator | undefined} the registered Validator or undefined if there is nono matching the provided key
|
|
94
|
+
* @method
|
|
125
95
|
*/
|
|
126
96
|
get<T extends Validator>(key: string): T | undefined;
|
|
127
97
|
}
|
|
128
|
-
/**
|
|
129
|
-
* @description Base options type for all validators
|
|
130
|
-
* @summary Defines the common properties available to all validators
|
|
131
|
-
* @typedef ValidatorOptions
|
|
132
|
-
* @property {string} [message] - Custom error message to display when validation fails
|
|
133
|
-
* @memberOf module:decorator-validation
|
|
134
|
-
* @category Validation
|
|
135
|
-
*/
|
|
136
98
|
export type ValidatorOptions = {
|
|
137
99
|
message?: string;
|
|
138
100
|
};
|
|
139
|
-
/**
|
|
140
|
-
* @description URL validation options interface
|
|
141
|
-
* @summary Defines options for URL validation, including allowed URL types
|
|
142
|
-
* @interface URLValidatorOptions
|
|
143
|
-
* @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns
|
|
144
|
-
* @memberOf module:decorator-validation
|
|
145
|
-
* @category Validation
|
|
146
|
-
*/
|
|
147
101
|
export interface URLValidatorOptions extends ValidatorOptions {
|
|
148
102
|
types: string | string[] | {
|
|
149
103
|
name: string;
|
|
150
104
|
};
|
|
151
105
|
}
|
|
152
|
-
/**
|
|
153
|
-
* @description Type validation options interface
|
|
154
|
-
* @summary Defines options for type validation, specifying allowed types
|
|
155
|
-
* @interface TypeValidatorOptions
|
|
156
|
-
* @property {(string|string[]|{ name: string })} types - Specifies the allowed data types
|
|
157
|
-
* @memberOf module:decorator-validation
|
|
158
|
-
* @category Validation
|
|
159
|
-
*/
|
|
160
106
|
export interface TypeValidatorOptions extends ValidatorOptions {
|
|
161
107
|
types: string | string[] | {
|
|
162
108
|
name: string;
|
|
163
109
|
};
|
|
164
110
|
}
|
|
165
|
-
/**
|
|
166
|
-
* @description Step validation options interface
|
|
167
|
-
* @summary Defines options for step validation, specifying the step increment
|
|
168
|
-
* @interface StepValidatorOptions
|
|
169
|
-
* @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation
|
|
170
|
-
* @memberOf module:decorator-validation
|
|
171
|
-
* @category Validation
|
|
172
|
-
*/
|
|
173
111
|
export interface StepValidatorOptions extends ValidatorOptions {
|
|
174
112
|
[ValidationKeys.STEP]: number | string;
|
|
175
113
|
}
|
|
176
|
-
/**
|
|
177
|
-
* @description Pattern validation options interface
|
|
178
|
-
* @summary Defines options for pattern validation using regular expressions
|
|
179
|
-
* @interface PatternValidatorOptions
|
|
180
|
-
* @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against
|
|
181
|
-
* @memberOf module:decorator-validation
|
|
182
|
-
* @category Validation
|
|
183
|
-
*/
|
|
184
114
|
export interface PatternValidatorOptions extends ValidatorOptions {
|
|
185
115
|
[ValidationKeys.PATTERN]?: RegExp | string;
|
|
186
116
|
}
|
|
187
|
-
/**
|
|
188
|
-
* @description Minimum value validation options interface
|
|
189
|
-
* @summary Defines options for minimum value validation
|
|
190
|
-
* @interface MinValidatorOptions
|
|
191
|
-
* @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value
|
|
192
|
-
* @memberOf module:decorator-validation
|
|
193
|
-
* @category Validation
|
|
194
|
-
*/
|
|
195
117
|
export interface MinValidatorOptions extends ValidatorOptions {
|
|
196
118
|
[ValidationKeys.MIN]: number | Date | string;
|
|
197
119
|
}
|
|
198
|
-
/**
|
|
199
|
-
* @description Minimum length validation options interface
|
|
200
|
-
* @summary Defines options for minimum length validation
|
|
201
|
-
* @interface MinLengthValidatorOptions
|
|
202
|
-
* @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length
|
|
203
|
-
* @memberOf module:decorator-validation
|
|
204
|
-
* @category Validation
|
|
205
|
-
*/
|
|
206
120
|
export interface MinLengthValidatorOptions extends ValidatorOptions {
|
|
207
121
|
[ValidationKeys.MIN_LENGTH]: number;
|
|
208
122
|
}
|
|
209
|
-
/**
|
|
210
|
-
* @description Maximum value validation options interface
|
|
211
|
-
* @summary Defines options for maximum value validation
|
|
212
|
-
* @interface MaxValidatorOptions
|
|
213
|
-
* @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value
|
|
214
|
-
* @memberOf module:decorator-validation
|
|
215
|
-
* @category Validation
|
|
216
|
-
*/
|
|
217
123
|
export interface MaxValidatorOptions extends ValidatorOptions {
|
|
218
124
|
[ValidationKeys.MAX]: number | Date | string;
|
|
219
125
|
}
|
|
220
|
-
/**
|
|
221
|
-
* @description Maximum length validation options interface
|
|
222
|
-
* @summary Defines options for maximum length validation
|
|
223
|
-
* @interface MaxLengthValidatorOptions
|
|
224
|
-
* @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length
|
|
225
|
-
* @memberOf module:decorator-validation
|
|
226
|
-
* @category Validation
|
|
227
|
-
*/
|
|
228
126
|
export interface MaxLengthValidatorOptions extends ValidatorOptions {
|
|
229
127
|
[ValidationKeys.MAX_LENGTH]: number;
|
|
230
128
|
}
|
|
231
|
-
/**
|
|
232
|
-
* @description List validation options interface
|
|
233
|
-
* @summary Defines options for list validation
|
|
234
|
-
* @interface ListValidatorOptions
|
|
235
|
-
* @property {string[]} clazz - Array of allowed class names or types
|
|
236
|
-
* @memberOf module:decorator-validation
|
|
237
|
-
* @category Validation
|
|
238
|
-
*/
|
|
239
129
|
export interface ListValidatorOptions extends ValidatorOptions {
|
|
240
130
|
clazz: string[];
|
|
241
131
|
}
|
|
242
|
-
/**
|
|
243
|
-
* @description Date validation options interface
|
|
244
|
-
* @summary Defines options for date validation
|
|
245
|
-
* @interface DateValidatorOptions
|
|
246
|
-
* @property {string} [ValidationKeys.FORMAT] - The expected date format pattern
|
|
247
|
-
* @memberOf module:decorator-validation
|
|
248
|
-
* @category Validation
|
|
249
|
-
*/
|
|
250
132
|
export interface DateValidatorOptions extends ValidatorOptions {
|
|
251
133
|
[ValidationKeys.FORMAT]?: string;
|
|
252
134
|
}
|
|
135
|
+
export interface EqualsValidatorOptions extends ValidatorOptions {
|
|
136
|
+
[ValidationKeys.EQUALS]: string;
|
|
137
|
+
}
|
|
138
|
+
export interface DiffValidatorOptions extends ValidatorOptions {
|
|
139
|
+
[ValidationKeys.DIFF]: string;
|
|
140
|
+
}
|
|
141
|
+
export interface LessThanValidatorOptions extends ValidatorOptions {
|
|
142
|
+
[ValidationKeys.LESS_THAN]: string;
|
|
143
|
+
}
|
|
144
|
+
export interface LessThanOrEqualValidatorOptions extends ValidatorOptions {
|
|
145
|
+
[ValidationKeys.LESS_THAN_OR_EQUAL]: string;
|
|
146
|
+
}
|
|
147
|
+
export interface GreaterThanValidatorOptions extends ValidatorOptions {
|
|
148
|
+
[ValidationKeys.GREATER_THAN]: string;
|
|
149
|
+
}
|
|
150
|
+
export interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {
|
|
151
|
+
[ValidationKeys.GREATER_THAN_OR_EQUAL]: string;
|
|
152
|
+
}
|