@decaf-ts/decorator-validation 1.6.5 → 1.7.1

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.
Files changed (149) hide show
  1. package/dist/decorator-validation.cjs +1202 -386
  2. package/dist/decorator-validation.esm.cjs +1158 -341
  3. package/lib/constants/index.cjs +1 -1
  4. package/lib/esm/index.d.ts +5 -37
  5. package/lib/esm/index.js +6 -38
  6. package/lib/esm/model/Model.d.ts +107 -35
  7. package/lib/esm/model/Model.js +110 -45
  8. package/lib/esm/model/constants.d.ts +3 -3
  9. package/lib/esm/model/constants.js +4 -4
  10. package/lib/esm/model/construction.d.ts +3 -3
  11. package/lib/esm/model/construction.js +4 -4
  12. package/lib/esm/model/decorators.d.ts +3 -3
  13. package/lib/esm/model/decorators.js +5 -3
  14. package/lib/esm/model/index.d.ts +1 -0
  15. package/lib/esm/model/index.js +2 -1
  16. package/lib/esm/model/types.d.ts +30 -11
  17. package/lib/esm/model/types.js +1 -1
  18. package/lib/esm/model/utils.d.ts +3 -0
  19. package/lib/esm/model/utils.js +11 -0
  20. package/lib/esm/model/validation.d.ts +5 -5
  21. package/lib/esm/model/validation.js +8 -9
  22. package/lib/esm/utils/Decoration.d.ts +123 -0
  23. package/lib/esm/utils/Decoration.js +192 -0
  24. package/lib/esm/utils/constants.d.ts +27 -9
  25. package/lib/esm/utils/constants.js +28 -10
  26. package/lib/esm/utils/dates.d.ts +26 -16
  27. package/lib/esm/utils/dates.js +27 -17
  28. package/lib/esm/utils/decorators.d.ts +41 -0
  29. package/lib/esm/utils/decorators.js +42 -1
  30. package/lib/esm/utils/hashing.d.ts +50 -6
  31. package/lib/esm/utils/hashing.js +49 -5
  32. package/lib/esm/utils/index.d.ts +1 -0
  33. package/lib/esm/utils/index.js +2 -1
  34. package/lib/esm/utils/registry.d.ts +3 -3
  35. package/lib/esm/utils/registry.js +1 -1
  36. package/lib/esm/utils/serialization.d.ts +1 -1
  37. package/lib/esm/utils/serialization.js +4 -3
  38. package/lib/esm/utils/strings.d.ts +4 -4
  39. package/lib/esm/utils/strings.js +5 -5
  40. package/lib/esm/utils/types.d.ts +123 -16
  41. package/lib/esm/utils/types.js +1 -1
  42. package/lib/esm/validation/Validators/DateValidator.d.ts +40 -8
  43. package/lib/esm/validation/Validators/DateValidator.js +41 -9
  44. package/lib/esm/validation/Validators/EmailValidator.d.ts +39 -7
  45. package/lib/esm/validation/Validators/EmailValidator.js +40 -8
  46. package/lib/esm/validation/Validators/ListValidator.d.ts +44 -6
  47. package/lib/esm/validation/Validators/ListValidator.js +45 -7
  48. package/lib/esm/validation/Validators/MaxValidator.d.ts +52 -6
  49. package/lib/esm/validation/Validators/MaxValidator.js +53 -7
  50. package/lib/esm/validation/Validators/MinValidator.d.ts +52 -6
  51. package/lib/esm/validation/Validators/MinValidator.js +53 -7
  52. package/lib/esm/validation/Validators/PasswordValidator.js +1 -1
  53. package/lib/esm/validation/Validators/PatternValidator.d.ts +75 -9
  54. package/lib/esm/validation/Validators/PatternValidator.js +76 -10
  55. package/lib/esm/validation/Validators/RequiredValidator.d.ts +52 -6
  56. package/lib/esm/validation/Validators/RequiredValidator.js +53 -7
  57. package/lib/esm/validation/Validators/TypeValidator.d.ts +60 -6
  58. package/lib/esm/validation/Validators/TypeValidator.js +69 -7
  59. package/lib/esm/validation/Validators/URLValidator.d.ts +41 -7
  60. package/lib/esm/validation/Validators/URLValidator.js +42 -8
  61. package/lib/esm/validation/Validators/Validator.d.ts +76 -16
  62. package/lib/esm/validation/Validators/Validator.js +68 -11
  63. package/lib/esm/validation/Validators/ValidatorRegistry.d.ts +1 -7
  64. package/lib/esm/validation/Validators/ValidatorRegistry.js +4 -11
  65. package/lib/esm/validation/decorators.d.ts +50 -40
  66. package/lib/esm/validation/decorators.js +102 -53
  67. package/lib/esm/validation/types.d.ts +146 -28
  68. package/lib/esm/validation/types.js +1 -1
  69. package/lib/index.cjs +7 -39
  70. package/lib/index.d.ts +5 -37
  71. package/lib/model/Model.cjs +114 -51
  72. package/lib/model/Model.d.ts +107 -35
  73. package/lib/model/constants.cjs +4 -4
  74. package/lib/model/constants.d.ts +3 -3
  75. package/lib/model/construction.cjs +4 -4
  76. package/lib/model/construction.d.ts +3 -3
  77. package/lib/model/decorators.cjs +6 -4
  78. package/lib/model/decorators.d.ts +3 -3
  79. package/lib/model/index.cjs +2 -1
  80. package/lib/model/index.d.ts +1 -0
  81. package/lib/model/types.cjs +1 -1
  82. package/lib/model/types.d.ts +30 -11
  83. package/lib/model/utils.cjs +15 -0
  84. package/lib/model/utils.d.ts +3 -0
  85. package/lib/model/validation.cjs +11 -12
  86. package/lib/model/validation.d.ts +5 -5
  87. package/lib/utils/Decoration.cjs +196 -0
  88. package/lib/utils/Decoration.d.ts +123 -0
  89. package/lib/utils/constants.cjs +29 -11
  90. package/lib/utils/constants.d.ts +27 -9
  91. package/lib/utils/dates.cjs +28 -18
  92. package/lib/utils/dates.d.ts +26 -16
  93. package/lib/utils/decorators.cjs +42 -1
  94. package/lib/utils/decorators.d.ts +41 -0
  95. package/lib/utils/hashing.cjs +49 -5
  96. package/lib/utils/hashing.d.ts +50 -6
  97. package/lib/utils/index.cjs +2 -1
  98. package/lib/utils/index.d.ts +1 -0
  99. package/lib/utils/registry.cjs +1 -1
  100. package/lib/utils/registry.d.ts +3 -3
  101. package/lib/utils/serialization.cjs +5 -4
  102. package/lib/utils/serialization.d.ts +1 -1
  103. package/lib/utils/strings.cjs +5 -5
  104. package/lib/utils/strings.d.ts +4 -4
  105. package/lib/utils/types.cjs +1 -1
  106. package/lib/utils/types.d.ts +123 -16
  107. package/lib/validation/Validation.cjs +1 -1
  108. package/lib/validation/Validators/DateValidator.cjs +41 -9
  109. package/lib/validation/Validators/DateValidator.d.ts +40 -8
  110. package/lib/validation/Validators/DiffValidator.cjs +1 -1
  111. package/lib/validation/Validators/EmailValidator.cjs +40 -8
  112. package/lib/validation/Validators/EmailValidator.d.ts +39 -7
  113. package/lib/validation/Validators/EqualsValidator.cjs +1 -1
  114. package/lib/validation/Validators/GreaterThanOrEqualValidator.cjs +1 -1
  115. package/lib/validation/Validators/GreaterThanValidator.cjs +1 -1
  116. package/lib/validation/Validators/LessThanOrEqualValidator.cjs +1 -1
  117. package/lib/validation/Validators/LessThanValidator.cjs +1 -1
  118. package/lib/validation/Validators/ListValidator.cjs +45 -7
  119. package/lib/validation/Validators/ListValidator.d.ts +44 -6
  120. package/lib/validation/Validators/MaxLengthValidator.cjs +1 -1
  121. package/lib/validation/Validators/MaxValidator.cjs +53 -7
  122. package/lib/validation/Validators/MaxValidator.d.ts +52 -6
  123. package/lib/validation/Validators/MinLengthValidator.cjs +1 -1
  124. package/lib/validation/Validators/MinValidator.cjs +53 -7
  125. package/lib/validation/Validators/MinValidator.d.ts +52 -6
  126. package/lib/validation/Validators/PasswordValidator.cjs +1 -1
  127. package/lib/validation/Validators/PatternValidator.cjs +76 -10
  128. package/lib/validation/Validators/PatternValidator.d.ts +75 -9
  129. package/lib/validation/Validators/RequiredValidator.cjs +53 -7
  130. package/lib/validation/Validators/RequiredValidator.d.ts +52 -6
  131. package/lib/validation/Validators/StepValidator.cjs +1 -1
  132. package/lib/validation/Validators/TypeValidator.cjs +71 -9
  133. package/lib/validation/Validators/TypeValidator.d.ts +60 -6
  134. package/lib/validation/Validators/URLValidator.cjs +42 -8
  135. package/lib/validation/Validators/URLValidator.d.ts +41 -7
  136. package/lib/validation/Validators/Validator.cjs +69 -12
  137. package/lib/validation/Validators/Validator.d.ts +76 -16
  138. package/lib/validation/Validators/ValidatorRegistry.cjs +4 -12
  139. package/lib/validation/Validators/ValidatorRegistry.d.ts +1 -7
  140. package/lib/validation/Validators/constants.cjs +2 -2
  141. package/lib/validation/Validators/decorators.cjs +2 -2
  142. package/lib/validation/Validators/index.cjs +1 -1
  143. package/lib/validation/Validators/utils.cjs +3 -3
  144. package/lib/validation/decorators.cjs +105 -56
  145. package/lib/validation/decorators.d.ts +50 -40
  146. package/lib/validation/index.cjs +1 -1
  147. package/lib/validation/types.cjs +1 -1
  148. package/lib/validation/types.d.ts +146 -28
  149. package/package.json +2 -1
@@ -3,9 +3,17 @@ import { Constructor } from "../model";
3
3
  import { ValidationKeys, Validator } from "./Validators";
4
4
  import { IRegistry } from "../utils";
5
5
  /**
6
- * @summary Type for validation decorator metadata
7
- * @memberOf module:decorator-validation.Reflection
8
- * @category Reflection
6
+ * @description Type definition for metadata used by validation decorators
7
+ * @summary Defines the structure of metadata attached to properties by validation decorators.
8
+ * This metadata is used during validation to determine validation rules and error messages.
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
9
17
  */
10
18
  export type ValidationMetadata = {
11
19
  [indexer: string]: any;
@@ -14,8 +22,15 @@ export type ValidationMetadata = {
14
22
  types?: string[];
15
23
  };
16
24
  /**
17
- * @summary Type for a validator property decorator definition
18
- * @memberOf module:decorator-validation.Validation
25
+ * @description Type definition for property-level validation decorator configuration
26
+ * @summary Defines the structure that associates a property with its validation decorators.
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
19
34
  * @category Validation
20
35
  */
21
36
  export type ValidationPropertyDecoratorDefinition = {
@@ -23,8 +38,14 @@ export type ValidationPropertyDecoratorDefinition = {
23
38
  decorators: ValidationDecoratorDefinition[];
24
39
  };
25
40
  /**
26
- * @summary Type for a validator decorator definition
27
- * @memberOf module:decorator-validation.Validation
41
+ * @description Type definition for individual validation decorator metadata
42
+ * @summary Extends the base DecoratorMetadata type with validation-specific properties.
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
28
49
  * @category Validation
29
50
  */
30
51
  export type ValidationDecoratorDefinition = DecoratorMetadata & {
@@ -32,7 +53,7 @@ export type ValidationDecoratorDefinition = DecoratorMetadata & {
32
53
  };
33
54
  /**
34
55
  * @summary Type for a validator element metadata
35
- * @memberOf module:decorator-validation.Validation
56
+ * @memberOf module:decorator-validation
36
57
  * @category Validation
37
58
  */
38
59
  export type ValidationElementDefinition = {
@@ -43,13 +64,13 @@ export type ValidationElementDefinition = {
43
64
  };
44
65
  /**
45
66
  * @summary Type for a model errors
46
- * @memberOf module:decorator-validation.Validation
67
+ * @memberOf module:decorator-validation
47
68
  * @category Validation
48
69
  */
49
70
  export type ModelErrors = Record<string, Record<string, string | undefined>>;
50
71
  /**
51
72
  * @summary Util type for {@link Validator} configuration
52
- * @memberOf module:decorator-validation.Validation
73
+ * @memberOf module:decorator-validation
53
74
  * @category Validation
54
75
  */
55
76
  export type ValidatorDefinition = {
@@ -58,77 +79,174 @@ export type ValidatorDefinition = {
58
79
  save: boolean;
59
80
  };
60
81
  /**
61
- * @summary Base API for a {@link Validator} registry
62
- *
63
- * @interface ValidatorRegistry
64
- * @extends IRegistry
82
+ * @description Interface for a registry that manages validator instances
83
+ * @summary Defines the contract for a registry that stores and retrieves validators.
84
+ * The registry is responsible for maintaining a collection of validators and providing
85
+ * access to them by key.
65
86
  *
87
+ * @interface IValidatorRegistry
88
+ * @template T Type of validator, must extend Validator
89
+ * @extends IRegistry<T>
90
+ * @memberOf module:decorator-validation
66
91
  * @category Validation
67
92
  */
68
93
  export interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {
69
94
  /**
70
- * @summary retrieves the custom keys
71
- * @method
95
+ * @description Retrieves custom validation keys defined in the registry
96
+ * @summary Returns a mapping of custom validation keys to their corresponding standard keys.
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
72
100
  */
73
101
  getCustomKeys(): Record<string, string>;
74
102
  /**
75
- * @summary Retrieves the Registered validator keys
76
- * @return {string[]} the registered validators keys
77
- * @method
103
+ * @description Gets all registered validator keys
104
+ * @summary Returns an array of all validation keys that have registered validators.
105
+ *
106
+ * @return {string[]} Array of registered validator keys
78
107
  */
79
108
  getKeys(): string[];
80
109
  /**
81
- * @summary Registers the provided validators onto the registry
110
+ * @description Registers one or more validators with the registry
111
+ * @summary Adds validators to the registry, making them available for validation operations.
112
+ * Validators can be provided as instances or as validator definitions.
82
113
  *
83
- * @typedef T extends Validator
84
- * @param {T[] | ValidatorDefinition[]} validator
85
- * @method
114
+ * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register
115
+ * @return {void}
86
116
  */
87
117
  register<T extends Validator>(...validator: (T | ValidatorDefinition)[]): void;
88
118
  /**
89
- * @summary Retrieves the Validator constructor if registered
119
+ * @description Retrieves a validator by its key
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.
90
122
  *
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
123
+ * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}
124
+ * @return {T|undefined} The registered validator or undefined if none matches the provided key
95
125
  */
96
126
  get<T extends Validator>(key: string): T | undefined;
97
127
  }
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
+ */
98
136
  export type ValidatorOptions = {
99
137
  message?: string;
100
138
  };
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
+ */
101
147
  export interface URLValidatorOptions extends ValidatorOptions {
102
148
  types: string | string[] | {
103
149
  name: string;
104
150
  };
105
151
  }
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
+ */
106
160
  export interface TypeValidatorOptions extends ValidatorOptions {
107
161
  types: string | string[] | {
108
162
  name: string;
109
163
  };
110
164
  }
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
+ */
111
173
  export interface StepValidatorOptions extends ValidatorOptions {
112
174
  [ValidationKeys.STEP]: number | string;
113
175
  }
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
+ */
114
184
  export interface PatternValidatorOptions extends ValidatorOptions {
115
185
  [ValidationKeys.PATTERN]?: RegExp | string;
116
186
  }
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
+ */
117
195
  export interface MinValidatorOptions extends ValidatorOptions {
118
196
  [ValidationKeys.MIN]: number | Date | string;
119
197
  }
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
+ */
120
206
  export interface MinLengthValidatorOptions extends ValidatorOptions {
121
207
  [ValidationKeys.MIN_LENGTH]: number;
122
208
  }
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
+ */
123
217
  export interface MaxValidatorOptions extends ValidatorOptions {
124
218
  [ValidationKeys.MAX]: number | Date | string;
125
219
  }
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
+ */
126
228
  export interface MaxLengthValidatorOptions extends ValidatorOptions {
127
229
  [ValidationKeys.MAX_LENGTH]: number;
128
230
  }
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
+ */
129
239
  export interface ListValidatorOptions extends ValidatorOptions {
130
240
  clazz: string[];
131
241
  }
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
+ */
132
250
  export interface DateValidatorOptions extends ValidatorOptions {
133
251
  [ValidationKeys.FORMAT]?: string;
134
252
  }
@@ -1,2 +1,2 @@
1
1
  import { ValidationKeys } from "./Validators";
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdmFsaWRhdGlvbi90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsY0FBYyxFQUFhLE1BQU0sY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVjb3JhdG9yTWV0YWRhdGEgfSBmcm9tIFwiQGRlY2FmLXRzL3JlZmxlY3Rpb25cIjtcbmltcG9ydCB7IENvbnN0cnVjdG9yIH0gZnJvbSBcIi4uL21vZGVsXCI7XG5pbXBvcnQgeyBWYWxpZGF0aW9uS2V5cywgVmFsaWRhdG9yIH0gZnJvbSBcIi4vVmFsaWRhdG9yc1wiO1xuaW1wb3J0IHsgSVJlZ2lzdHJ5IH0gZnJvbSBcIi4uL3V0aWxzXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgVHlwZSBmb3IgdmFsaWRhdGlvbiBkZWNvcmF0b3IgbWV0YWRhdGFcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uUmVmbGVjdGlvblxuICogQGNhdGVnb3J5IFJlZmxlY3Rpb25cbiAqL1xuZXhwb3J0IHR5cGUgVmFsaWRhdGlvbk1ldGFkYXRhID0ge1xuICBbaW5kZXhlcjogc3RyaW5nXTogYW55O1xuICBhcmdzPzogYW55W107XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgdHlwZXM/OiBzdHJpbmdbXTtcbn07XG5cbi8qKlxuICogQHN1bW1hcnkgVHlwZSBmb3IgYSB2YWxpZGF0b3IgcHJvcGVydHkgZGVjb3JhdG9yIGRlZmluaXRpb25cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uVmFsaWRhdGlvblxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IHR5cGUgVmFsaWRhdGlvblByb3BlcnR5RGVjb3JhdG9yRGVmaW5pdGlvbiA9IHtcbiAgcHJvcDogc3RyaW5nIHwgc3ltYm9sO1xuICBkZWNvcmF0b3JzOiBWYWxpZGF0aW9uRGVjb3JhdG9yRGVmaW5pdGlvbltdO1xufTtcblxuLyoqXG4gKiBAc3VtbWFyeSBUeXBlIGZvciBhIHZhbGlkYXRvciBkZWNvcmF0b3IgZGVmaW5pdGlvblxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvbi5WYWxpZGF0aW9uXG4gKiBAY2F0ZWdvcnkgVmFsaWRhdGlvblxuICovXG5leHBvcnQgdHlwZSBWYWxpZGF0aW9uRGVjb3JhdG9yRGVmaW5pdGlvbiA9IERlY29yYXRvck1ldGFkYXRhICYge1xuICBwcm9wczogVmFsaWRhdGlvbkVsZW1lbnREZWZpbml0aW9uO1xufTtcblxuLyoqXG4gKiBAc3VtbWFyeSBUeXBlIGZvciBhIHZhbGlkYXRvciBlbGVtZW50IG1ldGFkYXRhXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uLlZhbGlkYXRpb25cbiAqIEBjYXRlZ29yeSBWYWxpZGF0aW9uXG4gKi9cbmV4cG9ydCB0eXBlIFZhbGlkYXRpb25FbGVtZW50RGVmaW5pdGlvbiA9IHtcbiAgW2luZGV4ZXI6IHN0cmluZ106IGFueTtcblxuICB2YWx1ZT86IHN0cmluZyB8IG51bWJlcjtcbiAgbWVzc2FnZTogc3RyaW5nO1xuICB0eXBlcz86IHN0cmluZ1tdO1xufTtcblxuLyoqXG4gKiBAc3VtbWFyeSBUeXBlIGZvciBhIG1vZGVsIGVycm9yc1xuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvbi5WYWxpZGF0aW9uXG4gKiBAY2F0ZWdvcnkgVmFsaWRhdGlvblxuICovXG5leHBvcnQgdHlwZSBNb2RlbEVycm9ycyA9IFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IHVuZGVmaW5lZD4+O1xuXG4vKipcbiAqIEBzdW1tYXJ5IFV0aWwgdHlwZSBmb3Ige0BsaW5rIFZhbGlkYXRvcn0gY29uZmlndXJhdGlvblxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvbi5WYWxpZGF0aW9uXG4gKiBAY2F0ZWdvcnkgVmFsaWRhdGlvblxuICovXG5leHBvcnQgdHlwZSBWYWxpZGF0b3JEZWZpbml0aW9uID0ge1xuICB2YWxpZGF0b3I6IENvbnN0cnVjdG9yPFZhbGlkYXRvcj47XG4gIHZhbGlkYXRpb25LZXk6IHN0cmluZztcbiAgc2F2ZTogYm9vbGVhbjtcbn07XG5cbi8qKlxuICogQHN1bW1hcnkgQmFzZSBBUEkgZm9yIGEge0BsaW5rIFZhbGlkYXRvcn0gcmVnaXN0cnlcbiAqXG4gKiBAaW50ZXJmYWNlIFZhbGlkYXRvclJlZ2lzdHJ5XG4gKiBAZXh0ZW5kcyBJUmVnaXN0cnlcbiAqXG4gKiBAY2F0ZWdvcnkgVmFsaWRhdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIElWYWxpZGF0b3JSZWdpc3RyeTxUIGV4dGVuZHMgVmFsaWRhdG9yPiBleHRlbmRzIElSZWdpc3RyeTxUPiB7XG4gIC8qKlxuICAgKiBAc3VtbWFyeSByZXRyaWV2ZXMgdGhlIGN1c3RvbSBrZXlzXG4gICAqIEBtZXRob2RcbiAgICovXG4gIGdldEN1c3RvbUtleXMoKTogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcblxuICAvKipcbiAgICogQHN1bW1hcnkgUmV0cmlldmVzIHRoZSBSZWdpc3RlcmVkIHZhbGlkYXRvciBrZXlzXG4gICAqIEByZXR1cm4ge3N0cmluZ1tdfSB0aGUgcmVnaXN0ZXJlZCB2YWxpZGF0b3JzIGtleXNcbiAgICogQG1ldGhvZFxuICAgKi9cbiAgZ2V0S2V5cygpOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogQHN1bW1hcnkgUmVnaXN0ZXJzIHRoZSBwcm92aWRlZCB2YWxpZGF0b3JzIG9udG8gdGhlIHJlZ2lzdHJ5XG4gICAqXG4gICAqIEB0eXBlZGVmIFQgZXh0ZW5kcyBWYWxpZGF0b3JcbiAgICogQHBhcmFtIHtUW10gfCBWYWxpZGF0b3JEZWZpbml0aW9uW119IHZhbGlkYXRvclxuICAgKiBAbWV0aG9kXG4gICAqL1xuICByZWdpc3RlcjxUIGV4dGVuZHMgVmFsaWRhdG9yPihcbiAgICAuLi52YWxpZGF0b3I6IChUIHwgVmFsaWRhdG9yRGVmaW5pdGlvbilbXVxuICApOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBAc3VtbWFyeSBSZXRyaWV2ZXMgdGhlIFZhbGlkYXRvciBjb25zdHJ1Y3RvciBpZiByZWdpc3RlcmVkXG4gICAqXG4gICAqIEB0eXBlZGVmIFQgZXh0ZW5kcyBWYWxpZGF0b3JcbiAgICogQHBhcmFtIHtzdHJpbmd9IGtleSBvbmUgb2YgdGhlIHtAbGluayBWYWxpZGF0aW9uS2V5c31cbiAgICogQHJldHVybiB7VmFsaWRhdG9yIHwgdW5kZWZpbmVkfSB0aGUgcmVnaXN0ZXJlZCBWYWxpZGF0b3Igb3IgdW5kZWZpbmVkIGlmIHRoZXJlIGlzIG5vbm8gbWF0Y2hpbmcgdGhlIHByb3ZpZGVkIGtleVxuICAgKiBAbWV0aG9kXG4gICAqL1xuICBnZXQ8VCBleHRlbmRzIFZhbGlkYXRvcj4oa2V5OiBzdHJpbmcpOiBUIHwgdW5kZWZpbmVkO1xufVxuXG5leHBvcnQgdHlwZSBWYWxpZGF0b3JPcHRpb25zID0ge1xuICBtZXNzYWdlPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBVUkxWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIHR5cGVzOiBzdHJpbmcgfCBzdHJpbmdbXSB8IHsgbmFtZTogc3RyaW5nIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHlwZVZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgdHlwZXM6IHN0cmluZyB8IHN0cmluZ1tdIHwgeyBuYW1lOiBzdHJpbmcgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdGVwVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuU1RFUF06IG51bWJlciB8IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYXR0ZXJuVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuUEFUVEVSTl0/OiBSZWdFeHAgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWluVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuTUlOXTogbnVtYmVyIHwgRGF0ZSB8IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBNaW5MZW5ndGhWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5NSU5fTEVOR1RIXTogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE1heFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLk1BWF06IG51bWJlciB8IERhdGUgfCBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWF4TGVuZ3RoVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuTUFYX0xFTkdUSF06IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMaXN0VmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBjbGF6ejogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRGF0ZVZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLkZPUk1BVF0/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXF1YWxzVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuRVFVQUxTXTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERpZmZWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5ESUZGXTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExlc3NUaGFuVmFsaWRhdG9yT3B0aW9ucyBleHRlbmRzIFZhbGlkYXRvck9wdGlvbnMge1xuICBbVmFsaWRhdGlvbktleXMuTEVTU19USEFOXTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExlc3NUaGFuT3JFcXVhbFZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLkxFU1NfVEhBTl9PUl9FUVVBTF06IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBHcmVhdGVyVGhhblZhbGlkYXRvck9wdGlvbnMgZXh0ZW5kcyBWYWxpZGF0b3JPcHRpb25zIHtcbiAgW1ZhbGlkYXRpb25LZXlzLkdSRUFURVJfVEhBTl06IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBHcmVhdGVyVGhhbk9yRXF1YWxWYWxpZGF0b3JPcHRpb25zIGV4dGVuZHMgVmFsaWRhdG9yT3B0aW9ucyB7XG4gIFtWYWxpZGF0aW9uS2V5cy5HUkVBVEVSX1RIQU5fT1JfRVFVQUxdOiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/validation/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAa,MAAM,cAAc,CAAC","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\nexport interface EqualsValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
package/lib/index.cjs CHANGED
@@ -1,7 +1,4 @@
1
1
  "use strict";
2
- /**
3
- * @module decorator-validation
4
- */
5
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
3
  if (k2 === undefined) k2 = k;
7
4
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -19,43 +16,14 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
19
16
  Object.defineProperty(exports, "__esModule", { value: true });
20
17
  exports.VERSION = void 0;
21
18
  /**
22
- * @summary Model definition functionality
23
- * @description defines the base class and related functionality
24
- *
25
- * @namespace Model
26
- * @memberOf module:decorator-validation
27
- */
28
- /**
29
- * @summary Holds all the supported decorators
30
- * @namespace Decorators
31
- * @memberOf module:decorator-validation
32
- */
33
- /**
34
- * @summary Validation related functionality
35
- * @description Defines the Model validation apis and base classes for validators
36
- *
37
- * @namespace Validation
38
- * @memberOf module:decorator-validation
39
- */
40
- /**
41
- * @namespace Dates
42
- * @memberOf module:decorator-validation
43
- */
44
- /**
45
- * @namespace Hashing
46
- * @memberOf module:decorator-validation
47
- */
48
- /**
49
- * @namespace Serialization
50
- * @memberOf module:decorator-validation
51
- */
52
- /**
53
- * @namespace Format
54
- * @memberOf module:decorator-validation
19
+ * @module decorator-validation
20
+ * @description TypeScript decorator-based validation library
21
+ * @summary This module provides a comprehensive validation framework using TypeScript decorators.
22
+ * It exposes utility functions, validation decorators, and model-related functionality for
23
+ * implementing type-safe, declarative validation in TypeScript applications.
55
24
  */
56
- __exportStar(require("./constants/index.cjs"), exports);
57
25
  __exportStar(require("./utils/index.cjs"), exports);
58
26
  __exportStar(require("./validation/index.cjs"), exports);
59
27
  __exportStar(require("./model/index.cjs"), exports);
60
- exports.VERSION = "1.6.5";
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOztHQUVHOzs7Ozs7Ozs7Ozs7Ozs7OztBQUVIOzs7Ozs7R0FNRztBQUVIOzs7O0dBSUc7QUFFSDs7Ozs7O0dBTUc7QUFFSDs7O0dBR0c7QUFFSDs7O0dBR0c7QUFFSDs7O0dBR0c7QUFFSDs7O0dBR0c7QUFFSCw4Q0FBNEI7QUFDNUIsMENBQXdCO0FBQ3hCLCtDQUE2QjtBQUM3QiwwQ0FBd0I7QUFFWCxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IE1vZGVsIGRlZmluaXRpb24gZnVuY3Rpb25hbGl0eVxuICogQGRlc2NyaXB0aW9uIGRlZmluZXMgdGhlIGJhc2UgY2xhc3MgYW5kIHJlbGF0ZWQgZnVuY3Rpb25hbGl0eVxuICpcbiAqIEBuYW1lc3BhY2UgTW9kZWxcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IEhvbGRzIGFsbCB0aGUgc3VwcG9ydGVkIGRlY29yYXRvcnNcbiAqIEBuYW1lc3BhY2UgRGVjb3JhdG9yc1xuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICovXG5cbi8qKlxuICogQHN1bW1hcnkgVmFsaWRhdGlvbiByZWxhdGVkIGZ1bmN0aW9uYWxpdHlcbiAqIEBkZXNjcmlwdGlvbiBEZWZpbmVzIHRoZSBNb2RlbCB2YWxpZGF0aW9uIGFwaXMgYW5kIGJhc2UgY2xhc3NlcyBmb3IgdmFsaWRhdG9yc1xuICpcbiAqIEBuYW1lc3BhY2UgVmFsaWRhdGlvblxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICovXG5cbi8qKlxuICogQG5hbWVzcGFjZSBEYXRlc1xuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICovXG5cbi8qKlxuICogQG5hbWVzcGFjZSBIYXNoaW5nXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uXG4gKi9cblxuLyoqXG4gKiBAbmFtZXNwYWNlIFNlcmlhbGl6YXRpb25cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuXG4vKipcbiAqIEBuYW1lc3BhY2UgRm9ybWF0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uXG4gKi9cblxuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdGlvblwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kZWxcIjtcblxuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
28
+ exports.VERSION = "1.7.1";
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7Ozs7O0dBTUc7QUFDSCxvREFBd0I7QUFDeEIseURBQTZCO0FBQzdCLG9EQUF3QjtBQUVYLFFBQUEsT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQG1vZHVsZSBkZWNvcmF0b3ItdmFsaWRhdGlvblxuICogQGRlc2NyaXB0aW9uIFR5cGVTY3JpcHQgZGVjb3JhdG9yLWJhc2VkIHZhbGlkYXRpb24gbGlicmFyeVxuICogQHN1bW1hcnkgVGhpcyBtb2R1bGUgcHJvdmlkZXMgYSBjb21wcmVoZW5zaXZlIHZhbGlkYXRpb24gZnJhbWV3b3JrIHVzaW5nIFR5cGVTY3JpcHQgZGVjb3JhdG9ycy5cbiAqIEl0IGV4cG9zZXMgdXRpbGl0eSBmdW5jdGlvbnMsIHZhbGlkYXRpb24gZGVjb3JhdG9ycywgYW5kIG1vZGVsLXJlbGF0ZWQgZnVuY3Rpb25hbGl0eSBmb3JcbiAqIGltcGxlbWVudGluZyB0eXBlLXNhZmUsIGRlY2xhcmF0aXZlIHZhbGlkYXRpb24gaW4gVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnMuXG4gKi9cbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
package/lib/index.d.ts CHANGED
@@ -1,43 +1,11 @@
1
1
  /**
2
2
  * @module decorator-validation
3
+ * @description TypeScript decorator-based validation library
4
+ * @summary This module provides a comprehensive validation framework using TypeScript decorators.
5
+ * It exposes utility functions, validation decorators, and model-related functionality for
6
+ * implementing type-safe, declarative validation in TypeScript applications.
3
7
  */
4
- /**
5
- * @summary Model definition functionality
6
- * @description defines the base class and related functionality
7
- *
8
- * @namespace Model
9
- * @memberOf module:decorator-validation
10
- */
11
- /**
12
- * @summary Holds all the supported decorators
13
- * @namespace Decorators
14
- * @memberOf module:decorator-validation
15
- */
16
- /**
17
- * @summary Validation related functionality
18
- * @description Defines the Model validation apis and base classes for validators
19
- *
20
- * @namespace Validation
21
- * @memberOf module:decorator-validation
22
- */
23
- /**
24
- * @namespace Dates
25
- * @memberOf module:decorator-validation
26
- */
27
- /**
28
- * @namespace Hashing
29
- * @memberOf module:decorator-validation
30
- */
31
- /**
32
- * @namespace Serialization
33
- * @memberOf module:decorator-validation
34
- */
35
- /**
36
- * @namespace Format
37
- * @memberOf module:decorator-validation
38
- */
39
- export * from "./constants";
40
8
  export * from "./utils";
41
9
  export * from "./validation";
42
10
  export * from "./model";
43
- export declare const VERSION = "1.6.5";
11
+ export declare const VERSION = "1.7.1";