@decaf-ts/decorator-validation 1.1.1 → 1.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decorator-validation.bundle.min.js +1 -1
- package/dist/esm/decorator-validation.bundle.min.esm.js +1 -1
- package/lib/esm/index.d.ts +1 -2
- package/lib/esm/index.js +2 -3
- package/lib/esm/model/Model.js +2 -4
- package/lib/esm/model/Registry.js +2 -2
- package/lib/esm/model/construction.js +3 -2
- package/lib/esm/model/index.d.ts +1 -0
- package/lib/esm/model/index.js +2 -1
- package/lib/esm/model/utils.d.ts +9 -0
- package/lib/esm/model/utils.js +16 -0
- package/lib/esm/utils/index.d.ts +0 -1
- package/lib/esm/utils/index.js +1 -2
- package/lib/esm/validation/Validators/TypeValidator.js +2 -2
- package/lib/esm/validation/Validators/Validator.js +2 -2
- package/lib/esm/validation/Validators/decorators.js +2 -2
- package/lib/esm/validation/decorators.d.ts +10 -10
- package/lib/esm/validation/decorators.js +2 -2
- package/lib/esm/validation/types.d.ts +2 -14
- package/lib/esm/validation/types.js +1 -1
- package/lib/index.cjs +2 -3
- package/lib/index.d.ts +1 -2
- package/lib/model/Model.cjs +5 -7
- package/lib/model/Registry.cjs +2 -2
- package/lib/model/construction.cjs +4 -3
- package/lib/model/index.cjs +2 -1
- package/lib/model/index.d.ts +1 -0
- package/lib/model/utils.cjs +19 -0
- package/lib/model/utils.d.ts +9 -0
- package/lib/utils/index.cjs +1 -2
- package/lib/utils/index.d.ts +0 -1
- package/lib/validation/Validators/TypeValidator.cjs +5 -5
- package/lib/validation/Validators/Validator.cjs +3 -3
- package/lib/validation/Validators/decorators.cjs +2 -2
- package/lib/validation/decorators.cjs +12 -12
- package/lib/validation/decorators.d.ts +10 -10
- package/lib/validation/types.cjs +1 -1
- package/lib/validation/types.d.ts +2 -14
- package/package.json +2 -1
- package/lib/esm/reflection/decorators.d.ts +0 -27
- package/lib/esm/reflection/decorators.js +0 -51
- package/lib/esm/reflection/index.d.ts +0 -2
- package/lib/esm/reflection/index.js +0 -4
- package/lib/esm/reflection/utils.d.ts +0 -113
- package/lib/esm/reflection/utils.js +0 -239
- package/lib/esm/utils/equality.d.ts +0 -14
- package/lib/esm/utils/equality.js +0 -34
- package/lib/reflection/decorators.cjs +0 -55
- package/lib/reflection/decorators.d.ts +0 -27
- package/lib/reflection/index.cjs +0 -20
- package/lib/reflection/index.d.ts +0 -2
- package/lib/reflection/utils.cjs +0 -251
- package/lib/reflection/utils.d.ts +0 -113
- package/lib/utils/equality.cjs +0 -37
- package/lib/utils/equality.d.ts +0 -14
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { Model } from "../model/Model";
|
|
2
|
-
import "reflect-metadata";
|
|
3
|
-
import { DecoratorMetadata } from "../validation";
|
|
4
|
-
/**
|
|
5
|
-
* @summary Util function to retrieve the decorators for the provided Property
|
|
6
|
-
*
|
|
7
|
-
* @param {string} annotationPrefix
|
|
8
|
-
* @param {any} target
|
|
9
|
-
* @param {string | symbol} propertyName
|
|
10
|
-
* @param {boolean} [ignoreType] defaults to false. decides if the {@link ModelKeys.TYPE} is ignored or not
|
|
11
|
-
* @param {boolean} [recursive] defaults to true. decides if it should climb the prototypal tree searching for more decorators on that property
|
|
12
|
-
* @param {DecoratorMetadata[]} [accumulator] used when recursive is true, to cache decorators while it climbs the prototypal tree
|
|
13
|
-
*
|
|
14
|
-
* @function getPropertyDecorators
|
|
15
|
-
* @memberOf module:decorator-validation.Reflection
|
|
16
|
-
* @category Reflection
|
|
17
|
-
*/
|
|
18
|
-
export declare function getPropertyDecorators(annotationPrefix: string, target: any, propertyName: string | symbol, ignoreType?: boolean, recursive?: boolean, accumulator?: DecoratorMetadata[]): {
|
|
19
|
-
prop: string;
|
|
20
|
-
decorators: DecoratorMetadata[];
|
|
21
|
-
};
|
|
22
|
-
/**
|
|
23
|
-
* @summary gets the prop type from the decorator
|
|
24
|
-
* @param {any} model
|
|
25
|
-
* @param {string | symbol} propKey
|
|
26
|
-
* @return {string | undefined}
|
|
27
|
-
*
|
|
28
|
-
* @function geTypeFromDecorators
|
|
29
|
-
*
|
|
30
|
-
* @memberOf module:decorator-validation.Reflection
|
|
31
|
-
*/
|
|
32
|
-
export declare function getTypeFromDecorator(model: any, propKey: string | symbol): string | undefined;
|
|
33
|
-
/**
|
|
34
|
-
* @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes}
|
|
35
|
-
*
|
|
36
|
-
* @param {T} model
|
|
37
|
-
* @param {string[]} prefixes
|
|
38
|
-
*
|
|
39
|
-
* @function getAllPropertyDecorators
|
|
40
|
-
*
|
|
41
|
-
* @memberOf module:db-decorators.Reflection
|
|
42
|
-
*/
|
|
43
|
-
export declare const getAllPropertyDecorators: <T extends Model>(model: T, ...prefixes: string[]) => Record<string, any> | undefined;
|
|
44
|
-
/**
|
|
45
|
-
* @summary Retrieves all properties of an object
|
|
46
|
-
* @description
|
|
47
|
-
* - and of all its prototypes if {@param climbTree} until it reaches {@param stopAt} (or ends the prototype chain)
|
|
48
|
-
*
|
|
49
|
-
* @param obj
|
|
50
|
-
* @param {boolean} [climbTree] default to true
|
|
51
|
-
* @param {string} [stopAt] defaults to 'Object'
|
|
52
|
-
*
|
|
53
|
-
* @function getAllProperties
|
|
54
|
-
*
|
|
55
|
-
* @memberOf module:decorator-validation.Model
|
|
56
|
-
*/
|
|
57
|
-
export declare function getAllProperties(obj: Record<any, any>, climbTree?: boolean, stopAt?: string): string[];
|
|
58
|
-
/**
|
|
59
|
-
* @summary Util function to retrieve the Class decorators
|
|
60
|
-
*
|
|
61
|
-
* @function getClassDecorators
|
|
62
|
-
* @memberOf module:decorator-validation.Reflection
|
|
63
|
-
* @category Reflection
|
|
64
|
-
*/
|
|
65
|
-
export declare function getClassDecorators(annotationPrefix: string, target: any): {
|
|
66
|
-
key: string;
|
|
67
|
-
props: any;
|
|
68
|
-
}[];
|
|
69
|
-
/**
|
|
70
|
-
* @summary Util function to check a type according to a typeName
|
|
71
|
-
*
|
|
72
|
-
* @param {any} value
|
|
73
|
-
* @param {string} acceptedType
|
|
74
|
-
* @return {boolean} true for a match, false otherwise
|
|
75
|
-
*
|
|
76
|
-
* @function checkType
|
|
77
|
-
* @memberOf module:decorator-validation.Validation
|
|
78
|
-
* @category Validation
|
|
79
|
-
*/
|
|
80
|
-
export declare function checkType(value: any, acceptedType: string): any;
|
|
81
|
-
/**
|
|
82
|
-
* @summary Util function to check a type according multiple possibilities
|
|
83
|
-
* @param {any} value
|
|
84
|
-
* @param {string[]} acceptedTypes
|
|
85
|
-
* @return {boolean} true if any is a match, false otherwise
|
|
86
|
-
*
|
|
87
|
-
* @function checkTypes
|
|
88
|
-
* @memberOf module:decorator-validation.Validation
|
|
89
|
-
* @category Validation
|
|
90
|
-
*/
|
|
91
|
-
export declare function checkTypes(value: any, acceptedTypes: string[]): boolean;
|
|
92
|
-
/**
|
|
93
|
-
* @summary The model type
|
|
94
|
-
*
|
|
95
|
-
* @param {any} value
|
|
96
|
-
* @param {string | string[] | {name: string}} types
|
|
97
|
-
*
|
|
98
|
-
* @function evaluateDesignTypes
|
|
99
|
-
* @memberOf module:decorator-validation.Validation
|
|
100
|
-
* @category Validation
|
|
101
|
-
*/
|
|
102
|
-
export declare function evaluateDesignTypes(value: any, types: string | string[] | {
|
|
103
|
-
name: string;
|
|
104
|
-
}): any;
|
|
105
|
-
/**
|
|
106
|
-
* @summary For Serialization/deserialization purposes.
|
|
107
|
-
* @description Reads the {@link ModelKeys.ANCHOR} property of a {@link Model} to discover the class to instantiate
|
|
108
|
-
*
|
|
109
|
-
* @function isModel
|
|
110
|
-
* @memberOf module:decorator-validation.Validation
|
|
111
|
-
* @category Validation
|
|
112
|
-
*/
|
|
113
|
-
export declare function isModel(target: Record<string, any>): boolean;
|
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
import { ModelKeys } from "../utils/constants";
|
|
2
|
-
import { sf } from "../utils/strings";
|
|
3
|
-
import { isEqual } from "../utils/equality";
|
|
4
|
-
import "reflect-metadata";
|
|
5
|
-
/**
|
|
6
|
-
* @summary Util function to retrieve the decorators for the provided Property
|
|
7
|
-
*
|
|
8
|
-
* @param {string} annotationPrefix
|
|
9
|
-
* @param {any} target
|
|
10
|
-
* @param {string | symbol} propertyName
|
|
11
|
-
* @param {boolean} [ignoreType] defaults to false. decides if the {@link ModelKeys.TYPE} is ignored or not
|
|
12
|
-
* @param {boolean} [recursive] defaults to true. decides if it should climb the prototypal tree searching for more decorators on that property
|
|
13
|
-
* @param {DecoratorMetadata[]} [accumulator] used when recursive is true, to cache decorators while it climbs the prototypal tree
|
|
14
|
-
*
|
|
15
|
-
* @function getPropertyDecorators
|
|
16
|
-
* @memberOf module:decorator-validation.Reflection
|
|
17
|
-
* @category Reflection
|
|
18
|
-
*/
|
|
19
|
-
export function getPropertyDecorators(annotationPrefix, target, propertyName, ignoreType = false, recursive = true, accumulator) {
|
|
20
|
-
const getPropertyDecoratorsForModel = function (annotationPrefix, target, propertyName, ignoreType = false, accumulator) {
|
|
21
|
-
// get info about keys that used in current property
|
|
22
|
-
const keys = Reflect.getMetadataKeys(target, propertyName);
|
|
23
|
-
const decorators = keys
|
|
24
|
-
// filter your custom decorators
|
|
25
|
-
.filter((key) => {
|
|
26
|
-
if (ignoreType)
|
|
27
|
-
return key.toString().startsWith(annotationPrefix);
|
|
28
|
-
return (key === ModelKeys.TYPE || key.toString().startsWith(annotationPrefix));
|
|
29
|
-
})
|
|
30
|
-
.reduce((values, key) => {
|
|
31
|
-
// get metadata value.
|
|
32
|
-
const currValues = {
|
|
33
|
-
key: key !== ModelKeys.TYPE
|
|
34
|
-
? key.substring(annotationPrefix.length)
|
|
35
|
-
: key,
|
|
36
|
-
props: Reflect.getMetadata(key, target, propertyName),
|
|
37
|
-
};
|
|
38
|
-
return values.concat(currValues);
|
|
39
|
-
}, accumulator || []);
|
|
40
|
-
return {
|
|
41
|
-
prop: propertyName.toString(),
|
|
42
|
-
decorators: decorators,
|
|
43
|
-
};
|
|
44
|
-
};
|
|
45
|
-
const result = getPropertyDecoratorsForModel(annotationPrefix, target, propertyName, ignoreType, accumulator);
|
|
46
|
-
const trim = function (items) {
|
|
47
|
-
const cache = {};
|
|
48
|
-
return items.filter((item) => {
|
|
49
|
-
if (item.key in cache) {
|
|
50
|
-
if (!isEqual(item.props, cache[item.key]))
|
|
51
|
-
console.log(sf("Found a similar decorator for the {0} property of a {1} model but with different attributes. The original one will be kept", item.key, target.constructor.name));
|
|
52
|
-
return false;
|
|
53
|
-
}
|
|
54
|
-
cache[item.key.toString()] = item.props;
|
|
55
|
-
return true;
|
|
56
|
-
});
|
|
57
|
-
};
|
|
58
|
-
if (!recursive || Object.getPrototypeOf(target) === Object.prototype) {
|
|
59
|
-
return {
|
|
60
|
-
prop: result.prop,
|
|
61
|
-
decorators: trim(result.decorators),
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
// We choose to ignore type here, because in inheritance the expected type is from the lowest child class
|
|
65
|
-
return getPropertyDecorators(annotationPrefix, Object.getPrototypeOf(target.constructor), propertyName, true, recursive, result.decorators);
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* @summary gets the prop type from the decorator
|
|
69
|
-
* @param {any} model
|
|
70
|
-
* @param {string | symbol} propKey
|
|
71
|
-
* @return {string | undefined}
|
|
72
|
-
*
|
|
73
|
-
* @function geTypeFromDecorators
|
|
74
|
-
*
|
|
75
|
-
* @memberOf module:decorator-validation.Reflection
|
|
76
|
-
*/
|
|
77
|
-
export function getTypeFromDecorator(model, propKey) {
|
|
78
|
-
const decorators = getPropertyDecorators(ModelKeys.REFLECT, model, propKey, false);
|
|
79
|
-
if (!decorators || !decorators.decorators)
|
|
80
|
-
return;
|
|
81
|
-
// TODO handle @type decorators. for now we stick with design:type
|
|
82
|
-
const typeDecorator = decorators.decorators.shift();
|
|
83
|
-
const name = typeDecorator.props ? typeDecorator.props.name : undefined;
|
|
84
|
-
return name !== "Function" ? name : undefined;
|
|
85
|
-
}
|
|
86
|
-
/**
|
|
87
|
-
* @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes}
|
|
88
|
-
*
|
|
89
|
-
* @param {T} model
|
|
90
|
-
* @param {string[]} prefixes
|
|
91
|
-
*
|
|
92
|
-
* @function getAllPropertyDecorators
|
|
93
|
-
*
|
|
94
|
-
* @memberOf module:db-decorators.Reflection
|
|
95
|
-
*/
|
|
96
|
-
export const getAllPropertyDecorators = function (model, ...prefixes) {
|
|
97
|
-
if (!prefixes || !prefixes.length)
|
|
98
|
-
return;
|
|
99
|
-
const pushOrCreate = function (accum, key, decorators) {
|
|
100
|
-
if (!decorators || !decorators.length)
|
|
101
|
-
return;
|
|
102
|
-
if (!accum[key])
|
|
103
|
-
accum[key] = [];
|
|
104
|
-
accum[key].push(...decorators);
|
|
105
|
-
};
|
|
106
|
-
return Object.getOwnPropertyNames(model).reduce((accum, propKey) => {
|
|
107
|
-
prefixes.forEach((p, index) => {
|
|
108
|
-
const decorators = getPropertyDecorators(p, model, propKey, index !== 0);
|
|
109
|
-
if (!accum)
|
|
110
|
-
accum = {};
|
|
111
|
-
pushOrCreate(accum, propKey, decorators.decorators);
|
|
112
|
-
});
|
|
113
|
-
return accum;
|
|
114
|
-
}, undefined);
|
|
115
|
-
};
|
|
116
|
-
/**
|
|
117
|
-
* @summary Retrieves all properties of an object
|
|
118
|
-
* @description
|
|
119
|
-
* - and of all its prototypes if {@param climbTree} until it reaches {@param stopAt} (or ends the prototype chain)
|
|
120
|
-
*
|
|
121
|
-
* @param obj
|
|
122
|
-
* @param {boolean} [climbTree] default to true
|
|
123
|
-
* @param {string} [stopAt] defaults to 'Object'
|
|
124
|
-
*
|
|
125
|
-
* @function getAllProperties
|
|
126
|
-
*
|
|
127
|
-
* @memberOf module:decorator-validation.Model
|
|
128
|
-
*/
|
|
129
|
-
export function getAllProperties(obj, climbTree = true, stopAt = "Object") {
|
|
130
|
-
const allProps = [];
|
|
131
|
-
let curr = obj;
|
|
132
|
-
const keepAtIt = function () {
|
|
133
|
-
if (!climbTree)
|
|
134
|
-
return;
|
|
135
|
-
const prototype = Object.getPrototypeOf(curr);
|
|
136
|
-
if (!prototype || prototype.constructor.name === stopAt)
|
|
137
|
-
return;
|
|
138
|
-
curr = prototype;
|
|
139
|
-
return curr;
|
|
140
|
-
};
|
|
141
|
-
do {
|
|
142
|
-
const props = Object.getOwnPropertyNames(curr);
|
|
143
|
-
props.forEach(function (prop) {
|
|
144
|
-
if (allProps.indexOf(prop) === -1)
|
|
145
|
-
allProps.push(prop);
|
|
146
|
-
});
|
|
147
|
-
} while (keepAtIt());
|
|
148
|
-
return allProps;
|
|
149
|
-
}
|
|
150
|
-
/**
|
|
151
|
-
* @summary Util function to retrieve the Class decorators
|
|
152
|
-
*
|
|
153
|
-
* @function getClassDecorators
|
|
154
|
-
* @memberOf module:decorator-validation.Reflection
|
|
155
|
-
* @category Reflection
|
|
156
|
-
*/
|
|
157
|
-
export function getClassDecorators(annotationPrefix, target) {
|
|
158
|
-
const keys = Reflect.getOwnMetadataKeys(target.constructor);
|
|
159
|
-
return keys
|
|
160
|
-
.filter((key) => key.toString().startsWith(annotationPrefix))
|
|
161
|
-
.reduce((values, key) => {
|
|
162
|
-
// get metadata value
|
|
163
|
-
const currValues = {
|
|
164
|
-
key: key.substring(annotationPrefix.length),
|
|
165
|
-
props: Reflect.getMetadata(key, target.constructor),
|
|
166
|
-
};
|
|
167
|
-
return values.concat(currValues);
|
|
168
|
-
}, []);
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* @summary Util function to check a type according to a typeName
|
|
172
|
-
*
|
|
173
|
-
* @param {any} value
|
|
174
|
-
* @param {string} acceptedType
|
|
175
|
-
* @return {boolean} true for a match, false otherwise
|
|
176
|
-
*
|
|
177
|
-
* @function checkType
|
|
178
|
-
* @memberOf module:decorator-validation.Validation
|
|
179
|
-
* @category Validation
|
|
180
|
-
*/
|
|
181
|
-
export function checkType(value, acceptedType) {
|
|
182
|
-
if (typeof value === acceptedType)
|
|
183
|
-
return true;
|
|
184
|
-
return (value.constructor &&
|
|
185
|
-
value.constructor.name.toLowerCase() === acceptedType.toLowerCase());
|
|
186
|
-
}
|
|
187
|
-
/**
|
|
188
|
-
* @summary Util function to check a type according multiple possibilities
|
|
189
|
-
* @param {any} value
|
|
190
|
-
* @param {string[]} acceptedTypes
|
|
191
|
-
* @return {boolean} true if any is a match, false otherwise
|
|
192
|
-
*
|
|
193
|
-
* @function checkTypes
|
|
194
|
-
* @memberOf module:decorator-validation.Validation
|
|
195
|
-
* @category Validation
|
|
196
|
-
*/
|
|
197
|
-
export function checkTypes(value, acceptedTypes) {
|
|
198
|
-
return !acceptedTypes.every((t) => !checkType(value, t));
|
|
199
|
-
}
|
|
200
|
-
/**
|
|
201
|
-
* @summary The model type
|
|
202
|
-
*
|
|
203
|
-
* @param {any} value
|
|
204
|
-
* @param {string | string[] | {name: string}} types
|
|
205
|
-
*
|
|
206
|
-
* @function evaluateDesignTypes
|
|
207
|
-
* @memberOf module:decorator-validation.Validation
|
|
208
|
-
* @category Validation
|
|
209
|
-
*/
|
|
210
|
-
export function evaluateDesignTypes(value, types) {
|
|
211
|
-
switch (typeof types) {
|
|
212
|
-
case "string":
|
|
213
|
-
return checkType(value, types);
|
|
214
|
-
case "object":
|
|
215
|
-
if (Array.isArray(types))
|
|
216
|
-
return checkTypes(value, types);
|
|
217
|
-
return true;
|
|
218
|
-
case "function":
|
|
219
|
-
if (types.name && types.name !== "Object")
|
|
220
|
-
return checkType(value, types.name);
|
|
221
|
-
return true;
|
|
222
|
-
default:
|
|
223
|
-
return true;
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
/**
|
|
227
|
-
* @summary For Serialization/deserialization purposes.
|
|
228
|
-
* @description Reads the {@link ModelKeys.ANCHOR} property of a {@link Model} to discover the class to instantiate
|
|
229
|
-
*
|
|
230
|
-
* @function isModel
|
|
231
|
-
* @memberOf module:decorator-validation.Validation
|
|
232
|
-
* @category Validation
|
|
233
|
-
*/
|
|
234
|
-
export function isModel(target) {
|
|
235
|
-
return (!!target[ModelKeys.ANCHOR] ||
|
|
236
|
-
!!getClassDecorators(ModelKeys.REFLECT, target).find((dec) => dec.key === ModelKeys.MODEL && dec.props && dec.props.class));
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/reflection/utils.ts"],"names":[],"mappings":"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","file":"reflection/utils.js","sourcesContent":["import { Model } from \"../model/Model\";\nimport { ModelKeys } from \"../utils/constants\";\nimport { sf } from \"../utils/strings\";\nimport { isEqual } from \"../utils/equality\";\nimport \"reflect-metadata\";\nimport { DecoratorMetadata } from \"../validation\";\n\n/**\n * @summary Util function to retrieve the decorators for the provided Property\n *\n * @param {string} annotationPrefix\n * @param {any} target\n * @param {string | symbol} propertyName\n * @param {boolean} [ignoreType] defaults to false. decides if the {@link ModelKeys.TYPE} is ignored or not\n * @param {boolean} [recursive] defaults to true. decides if it should climb the prototypal tree searching for more decorators on that property\n * @param {DecoratorMetadata[]} [accumulator] used when recursive is true, to cache decorators while it climbs the prototypal tree\n *\n * @function getPropertyDecorators\n * @memberOf module:decorator-validation.Reflection\n * @category Reflection\n */\nexport function getPropertyDecorators(\n  annotationPrefix: string,\n  target: any,\n  propertyName: string | symbol,\n  ignoreType: boolean = false,\n  recursive = true,\n  accumulator?: DecoratorMetadata[],\n): { prop: string; decorators: DecoratorMetadata[] } {\n  const getPropertyDecoratorsForModel = function (\n    annotationPrefix: string,\n    target: any,\n    propertyName: string | symbol,\n    ignoreType: boolean = false,\n    accumulator?: DecoratorMetadata[],\n  ): { prop: string; decorators: DecoratorMetadata[] } {\n    // get info about keys that used in current property\n    const keys: any[] = Reflect.getMetadataKeys(target, propertyName);\n    const decorators: DecoratorMetadata[] = keys\n      // filter your custom decorators\n      .filter((key) => {\n        if (ignoreType) return key.toString().startsWith(annotationPrefix);\n        return (\n          key === ModelKeys.TYPE || key.toString().startsWith(annotationPrefix)\n        );\n      })\n      .reduce((values, key) => {\n        // get metadata value.\n        const currValues = {\n          key:\n            key !== ModelKeys.TYPE\n              ? key.substring(annotationPrefix.length)\n              : key,\n          props: Reflect.getMetadata(key, target, propertyName),\n        };\n        return values.concat(currValues);\n      }, accumulator || []);\n\n    return {\n      prop: propertyName.toString(),\n      decorators: decorators,\n    };\n  };\n\n  const result: { prop: string; decorators: DecoratorMetadata[] } =\n    getPropertyDecoratorsForModel(\n      annotationPrefix,\n      target,\n      propertyName,\n      ignoreType,\n      accumulator,\n    );\n\n  const trim = function (items: DecoratorMetadata[]) {\n    const cache: Record<string, DecoratorMetadata> = {};\n    return items.filter((item: DecoratorMetadata) => {\n      if (item.key in cache) {\n        if (!isEqual(item.props, cache[item.key]))\n          console.log(\n            sf(\n              \"Found a similar decorator for the {0} property of a {1} model but with different attributes. The original one will be kept\",\n              item.key,\n              target.constructor.name,\n            ),\n          );\n        return false;\n      }\n\n      cache[item.key.toString()] = item.props as DecoratorMetadata;\n      return true;\n    });\n  };\n\n  if (!recursive || Object.getPrototypeOf(target) === Object.prototype) {\n    return {\n      prop: result.prop,\n      decorators: trim(result.decorators),\n    };\n  }\n\n  // We choose to ignore type here, because in inheritance the expected type is from the lowest child class\n  return getPropertyDecorators(\n    annotationPrefix,\n    Object.getPrototypeOf(target.constructor),\n    propertyName,\n    true,\n    recursive,\n    result.decorators,\n  );\n}\n\n/**\n * @summary gets the prop type from the decorator\n * @param {any} model\n * @param {string | symbol} propKey\n * @return {string | undefined}\n *\n * @function geTypeFromDecorators\n *\n * @memberOf module:decorator-validation.Reflection\n */\nexport function getTypeFromDecorator(\n  model: any,\n  propKey: string | symbol,\n): string | undefined {\n  const decorators: { prop: string | symbol; decorators: any[] } =\n    getPropertyDecorators(ModelKeys.REFLECT, model, propKey, false);\n  if (!decorators || !decorators.decorators) return;\n\n  // TODO handle @type decorators. for now we stick with design:type\n  const typeDecorator = decorators.decorators.shift();\n  const name = typeDecorator.props ? typeDecorator.props.name : undefined;\n  return name !== \"Function\" ? name : undefined;\n}\n\n/**\n * @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes}\n *\n * @param {T} model\n * @param {string[]} prefixes\n *\n * @function getAllPropertyDecorators\n *\n * @memberOf module:db-decorators.Reflection\n */\nexport const getAllPropertyDecorators = function <T extends Model>(\n  model: T,\n  ...prefixes: string[]\n): Record<string, any> | undefined {\n  if (!prefixes || !prefixes.length) return;\n\n  const pushOrCreate = function (\n    accum: Record<string, Record<string, any>>,\n    key: string,\n    decorators: any[],\n  ) {\n    if (!decorators || !decorators.length) return;\n    if (!accum[key]) accum[key] = [];\n    accum[key].push(...decorators);\n  };\n\n  return Object.getOwnPropertyNames(model).reduce(\n    (accum: Record<string, any> | undefined, propKey) => {\n      prefixes.forEach((p, index) => {\n        const decorators: { prop: string | symbol; decorators: any[] } =\n          getPropertyDecorators(p, model, propKey, index !== 0);\n        if (!accum) accum = {};\n        pushOrCreate(accum, propKey, decorators.decorators);\n      });\n      return accum;\n    },\n    undefined,\n  );\n};\n\n/**\n * @summary Retrieves all properties of an object\n * @description\n *  - and of all its prototypes if {@param climbTree} until it reaches {@param stopAt} (or ends the prototype chain)\n *\n * @param obj\n * @param {boolean} [climbTree] default to true\n * @param {string} [stopAt] defaults to 'Object'\n *\n * @function getAllProperties\n *\n * @memberOf module:decorator-validation.Model\n */\nexport function getAllProperties(\n  obj: Record<any, any>,\n  climbTree = true,\n  stopAt = \"Object\",\n) {\n  const allProps: string[] = [];\n  let curr: Record<any, any> = obj;\n\n  const keepAtIt = function () {\n    if (!climbTree) return;\n    const prototype = Object.getPrototypeOf(curr);\n    if (!prototype || prototype.constructor.name === stopAt) return;\n    curr = prototype;\n    return curr;\n  };\n\n  do {\n    const props = Object.getOwnPropertyNames(curr);\n    props.forEach(function (prop) {\n      if (allProps.indexOf(prop) === -1) allProps.push(prop);\n    });\n  } while (keepAtIt());\n  return allProps;\n}\n\n/**\n * @summary Util function to retrieve the Class decorators\n *\n * @function getClassDecorators\n * @memberOf module:decorator-validation.Reflection\n * @category Reflection\n */\nexport function getClassDecorators(\n  annotationPrefix: string,\n  target: any,\n): { key: string; props: any }[] {\n  const keys: any[] = Reflect.getOwnMetadataKeys(target.constructor);\n\n  return keys\n    .filter((key) => key.toString().startsWith(annotationPrefix))\n    .reduce((values, key) => {\n      // get metadata value\n      const currValues = {\n        key: key.substring(annotationPrefix.length),\n        props: Reflect.getMetadata(key, target.constructor),\n      };\n      return values.concat(currValues);\n    }, []);\n}\n\n/**\n * @summary Util function to check a type according to a typeName\n *\n * @param {any} value\n * @param {string} acceptedType\n * @return {boolean} true for a match, false otherwise\n *\n * @function checkType\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport function checkType(value: any, acceptedType: string) {\n  if (typeof value === acceptedType) return true;\n  return (\n    value.constructor &&\n    value.constructor.name.toLowerCase() === acceptedType.toLowerCase()\n  );\n}\n\n/**\n * @summary Util function to check a type according multiple possibilities\n * @param {any} value\n * @param {string[]} acceptedTypes\n * @return {boolean} true if any is a match, false otherwise\n *\n * @function checkTypes\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport function checkTypes(value: any, acceptedTypes: string[]) {\n  return !acceptedTypes.every((t) => !checkType(value, t));\n}\n\n/**\n * @summary The model type\n *\n * @param {any} value\n * @param {string | string[] | {name: string}} types\n *\n * @function evaluateDesignTypes\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport function evaluateDesignTypes(\n  value: any,\n  types: string | string[] | { name: string },\n) {\n  switch (typeof types) {\n    case \"string\":\n      return checkType(value, types);\n    case \"object\":\n      if (Array.isArray(types)) return checkTypes(value, types);\n      return true;\n    case \"function\":\n      if (types.name && types.name !== \"Object\")\n        return checkType(value, types.name);\n      return true;\n    default:\n      return true;\n  }\n}\n\n/**\n * @summary For Serialization/deserialization purposes.\n * @description Reads the {@link ModelKeys.ANCHOR} property of a {@link Model} to discover the class to instantiate\n *\n * @function isModel\n * @memberOf module:decorator-validation.Validation\n * @category Validation\n */\nexport function isModel(target: Record<string, any>) {\n  return (\n    !!target[ModelKeys.ANCHOR] ||\n    !!getClassDecorators(ModelKeys.REFLECT, target).find(\n      (dec) => dec.key === ModelKeys.MODEL && dec.props && dec.props.class,\n    )\n  );\n}\n"]}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @summary Deep Object Comparison
|
|
3
|
-
* @description algorithm from {@link https://stackoverflow.com/questions/30476150/javascript-deep-comparison-recursively-objects-and-properties}
|
|
4
|
-
* but with optional ignored properties
|
|
5
|
-
*
|
|
6
|
-
* @param {any} a
|
|
7
|
-
* @param {any} b
|
|
8
|
-
* @param {string} [propsToIgnore]
|
|
9
|
-
*
|
|
10
|
-
* @function isEqual
|
|
11
|
-
* @memberOf module:decorator-validation.Utils.Equality
|
|
12
|
-
* @category Validation
|
|
13
|
-
*/
|
|
14
|
-
export declare function isEqual(a: any, b: any, ...propsToIgnore: string[]): boolean;
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @summary Deep Object Comparison
|
|
3
|
-
* @description algorithm from {@link https://stackoverflow.com/questions/30476150/javascript-deep-comparison-recursively-objects-and-properties}
|
|
4
|
-
* but with optional ignored properties
|
|
5
|
-
*
|
|
6
|
-
* @param {any} a
|
|
7
|
-
* @param {any} b
|
|
8
|
-
* @param {string} [propsToIgnore]
|
|
9
|
-
*
|
|
10
|
-
* @function isEqual
|
|
11
|
-
* @memberOf module:decorator-validation.Utils.Equality
|
|
12
|
-
* @category Validation
|
|
13
|
-
*/
|
|
14
|
-
export function isEqual(a, b, ...propsToIgnore) {
|
|
15
|
-
if (a === b)
|
|
16
|
-
return true;
|
|
17
|
-
if (a instanceof Date && b instanceof Date)
|
|
18
|
-
return a.getTime() === b.getTime();
|
|
19
|
-
if (!a || !b || (typeof a !== "object" && typeof b !== "object"))
|
|
20
|
-
return a === b;
|
|
21
|
-
if (a === null || a === undefined || b === null || b === undefined)
|
|
22
|
-
return false;
|
|
23
|
-
if (typeof a !== typeof b)
|
|
24
|
-
return false;
|
|
25
|
-
if (a.prototype !== b.prototype)
|
|
26
|
-
return false;
|
|
27
|
-
const keys = Object.keys(a).filter((k) => propsToIgnore.indexOf(k) === -1);
|
|
28
|
-
if (keys.length !==
|
|
29
|
-
Object.keys(b).filter((k) => propsToIgnore.indexOf(k) === -1).length)
|
|
30
|
-
return false;
|
|
31
|
-
return keys.every((k) => propsToIgnore.indexOf(k) !== -1 || isEqual(a[k], b[k], ...propsToIgnore));
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy91dGlscy9lcXVhbGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7O0dBWUc7QUFDSCxNQUFNLFVBQVUsT0FBTyxDQUFDLENBQU0sRUFBRSxDQUFNLEVBQUUsR0FBRyxhQUF1QjtJQUNoRSxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQUUsT0FBTyxJQUFJLENBQUM7SUFDekIsSUFBSSxDQUFDLFlBQVksSUFBSSxJQUFJLENBQUMsWUFBWSxJQUFJO1FBQ3hDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNyQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssUUFBUSxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsQ0FBQztRQUM5RCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakIsSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsS0FBSyxTQUFTLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssU0FBUztRQUNoRSxPQUFPLEtBQUssQ0FBQztJQUNmLElBQUksT0FBTyxDQUFDLEtBQUssT0FBTyxDQUFDO1FBQUUsT0FBTyxLQUFLLENBQUM7SUFDeEMsSUFBSSxDQUFDLENBQUMsU0FBUyxLQUFLLENBQUMsQ0FBQyxTQUFTO1FBQUUsT0FBTyxLQUFLLENBQUM7SUFDOUMsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzRSxJQUNFLElBQUksQ0FBQyxNQUFNO1FBQ1gsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNO1FBRXBFLE9BQU8sS0FBSyxDQUFDO0lBQ2YsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUNmLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FDSixhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsYUFBYSxDQUFDLENBQzNFLENBQUM7QUFDSixDQUFDIiwiZmlsZSI6InV0aWxzL2VxdWFsaXR5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAc3VtbWFyeSBEZWVwIE9iamVjdCBDb21wYXJpc29uXG4gKiBAZGVzY3JpcHRpb24gYWxnb3JpdGhtIGZyb20ge0BsaW5rIGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zLzMwNDc2MTUwL2phdmFzY3JpcHQtZGVlcC1jb21wYXJpc29uLXJlY3Vyc2l2ZWx5LW9iamVjdHMtYW5kLXByb3BlcnRpZXN9XG4gKiBidXQgd2l0aCBvcHRpb25hbCBpZ25vcmVkIHByb3BlcnRpZXNcbiAqXG4gKiBAcGFyYW0ge2FueX0gYVxuICogQHBhcmFtIHthbnl9IGJcbiAqIEBwYXJhbSB7c3RyaW5nfSBbcHJvcHNUb0lnbm9yZV1cbiAqXG4gKiBAZnVuY3Rpb24gaXNFcXVhbFxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvbi5VdGlscy5FcXVhbGl0eVxuICogQGNhdGVnb3J5IFZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzRXF1YWwoYTogYW55LCBiOiBhbnksIC4uLnByb3BzVG9JZ25vcmU6IHN0cmluZ1tdKTogYm9vbGVhbiB7XG4gIGlmIChhID09PSBiKSByZXR1cm4gdHJ1ZTtcbiAgaWYgKGEgaW5zdGFuY2VvZiBEYXRlICYmIGIgaW5zdGFuY2VvZiBEYXRlKVxuICAgIHJldHVybiBhLmdldFRpbWUoKSA9PT0gYi5nZXRUaW1lKCk7XG4gIGlmICghYSB8fCAhYiB8fCAodHlwZW9mIGEgIT09IFwib2JqZWN0XCIgJiYgdHlwZW9mIGIgIT09IFwib2JqZWN0XCIpKVxuICAgIHJldHVybiBhID09PSBiO1xuICBpZiAoYSA9PT0gbnVsbCB8fCBhID09PSB1bmRlZmluZWQgfHwgYiA9PT0gbnVsbCB8fCBiID09PSB1bmRlZmluZWQpXG4gICAgcmV0dXJuIGZhbHNlO1xuICBpZiAodHlwZW9mIGEgIT09IHR5cGVvZiBiKSByZXR1cm4gZmFsc2U7XG4gIGlmIChhLnByb3RvdHlwZSAhPT0gYi5wcm90b3R5cGUpIHJldHVybiBmYWxzZTtcbiAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKGEpLmZpbHRlcigoaykgPT4gcHJvcHNUb0lnbm9yZS5pbmRleE9mKGspID09PSAtMSk7XG4gIGlmIChcbiAgICBrZXlzLmxlbmd0aCAhPT1cbiAgICBPYmplY3Qua2V5cyhiKS5maWx0ZXIoKGspID0+IHByb3BzVG9JZ25vcmUuaW5kZXhPZihrKSA9PT0gLTEpLmxlbmd0aFxuICApXG4gICAgcmV0dXJuIGZhbHNlO1xuICByZXR1cm4ga2V5cy5ldmVyeShcbiAgICAoaykgPT5cbiAgICAgIHByb3BzVG9JZ25vcmUuaW5kZXhPZihrKSAhPT0gLTEgfHwgaXNFcXVhbChhW2tdLCBiW2tdLCAuLi5wcm9wc1RvSWdub3JlKSxcbiAgKTtcbn1cbiJdfQ==
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.metadata = metadata;
|
|
4
|
-
exports.apply = apply;
|
|
5
|
-
require("reflect-metadata");
|
|
6
|
-
/**
|
|
7
|
-
* @summary Decorator that assigns metadata to the class/method using the
|
|
8
|
-
* specified `key`.
|
|
9
|
-
*
|
|
10
|
-
* @param {string} key a value defining the key under which the metadata is stored
|
|
11
|
-
* @param {any} value metadata to be associated with `key`
|
|
12
|
-
*
|
|
13
|
-
* @function metadata
|
|
14
|
-
*
|
|
15
|
-
* @memberOf module:decorator-validation.Reflections
|
|
16
|
-
* @category Decorators
|
|
17
|
-
*/
|
|
18
|
-
function metadata(key, value) {
|
|
19
|
-
return (target, propertyKey, descriptor) => {
|
|
20
|
-
if (descriptor) {
|
|
21
|
-
Reflect.defineMetadata(key, value, descriptor.value); // method
|
|
22
|
-
}
|
|
23
|
-
else if (propertyKey) {
|
|
24
|
-
Reflect.defineMetadata(key, value, target, propertyKey); // property
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
Reflect.defineMetadata(key, value, target); // class
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* @summary Decorator that assigns metadata to the class/method using the
|
|
33
|
-
* specified `key`.
|
|
34
|
-
*
|
|
35
|
-
* @param {Array<ClassDecorator | MethodDecorator | PropertyDecorator>} decorators a value defining the key under which the metadata is stored
|
|
36
|
-
*
|
|
37
|
-
* @function apply
|
|
38
|
-
*
|
|
39
|
-
* @memberOf module:decorator-validation.Reflections
|
|
40
|
-
* @category Decorators
|
|
41
|
-
*/
|
|
42
|
-
function apply(...decorators) {
|
|
43
|
-
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
44
|
-
return (target, propertyKey, descriptor) => {
|
|
45
|
-
for (const decorator of decorators) {
|
|
46
|
-
if (target instanceof Function && !descriptor) {
|
|
47
|
-
decorator(target);
|
|
48
|
-
continue;
|
|
49
|
-
}
|
|
50
|
-
decorator(target, propertyKey, descriptor);
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZWZsZWN0aW9uL2RlY29yYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFtQkEsNEJBY0M7QUFhRCxzQkFxQkM7QUFuRUQsNEJBQTBCO0FBTzFCOzs7Ozs7Ozs7OztHQVdHO0FBQ0gsU0FBZ0IsUUFBUSxDQUFJLEdBQVcsRUFBRSxLQUFRO0lBQy9DLE9BQU8sQ0FDTCxNQUFjLEVBQ2QsV0FBNkIsRUFDN0IsVUFBK0IsRUFDL0IsRUFBRTtRQUNGLElBQUksVUFBVSxFQUFFLENBQUM7WUFDZixPQUFPLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsU0FBUztRQUNqRSxDQUFDO2FBQU0sSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUN2QixPQUFPLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsV0FBVztRQUN0RSxDQUFDO2FBQU0sQ0FBQztZQUNOLE9BQU8sQ0FBQyxjQUFjLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLFFBQVE7UUFDdEQsQ0FBQztJQUNILENBQUMsQ0FBQztBQUNKLENBQUM7QUFFRDs7Ozs7Ozs7OztHQVVHO0FBQ0gsU0FBZ0IsS0FBSyxDQUNuQixHQUFHLFVBQXVFO0lBRTFFLHdEQUF3RDtJQUN4RCxPQUFPLENBQ0wsTUFBMEIsRUFDMUIsV0FBNkIsRUFDN0IsVUFBdUMsRUFDdkMsRUFBRTtRQUNGLEtBQUssTUFBTSxTQUFTLElBQUksVUFBVSxFQUFFLENBQUM7WUFDbkMsSUFBSSxNQUFNLFlBQVksUUFBUSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7Z0JBQzdDLFNBQTRCLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ3RDLFNBQVM7WUFDWCxDQUFDO1lBQ0EsU0FBaUQsQ0FDaEQsTUFBTSxFQUNOLFdBQThCLEVBQzlCLFVBQXdDLENBQ3pDLENBQUM7UUFDSixDQUFDO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsImZpbGUiOiJyZWZsZWN0aW9uL2RlY29yYXRvcnMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCJyZWZsZWN0LW1ldGFkYXRhXCI7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbmV4cG9ydCB0eXBlIEN1c3RvbURlY29yYXRvcjxWPiA9IE1ldGhvZERlY29yYXRvciAmXG4gIENsYXNzRGVjb3JhdG9yICZcbiAgUHJvcGVydHlEZWNvcmF0b3I7XG5cbi8qKlxuICogQHN1bW1hcnkgRGVjb3JhdG9yIHRoYXQgYXNzaWducyBtZXRhZGF0YSB0byB0aGUgY2xhc3MvbWV0aG9kIHVzaW5nIHRoZVxuICogc3BlY2lmaWVkIGBrZXlgLlxuICpcbiAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgYSB2YWx1ZSBkZWZpbmluZyB0aGUga2V5IHVuZGVyIHdoaWNoIHRoZSBtZXRhZGF0YSBpcyBzdG9yZWRcbiAqIEBwYXJhbSB7YW55fSB2YWx1ZSBtZXRhZGF0YSB0byBiZSBhc3NvY2lhdGVkIHdpdGggYGtleWBcbiAqXG4gKiBAZnVuY3Rpb24gbWV0YWRhdGFcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uLlJlZmxlY3Rpb25zXG4gKiBAY2F0ZWdvcnkgRGVjb3JhdG9yc1xuICovXG5leHBvcnQgZnVuY3Rpb24gbWV0YWRhdGE8Vj4oa2V5OiBzdHJpbmcsIHZhbHVlOiBWKTogQ3VzdG9tRGVjb3JhdG9yPFY+IHtcbiAgcmV0dXJuIChcbiAgICB0YXJnZXQ6IG9iamVjdCxcbiAgICBwcm9wZXJ0eUtleT86IHN0cmluZyB8IHN5bWJvbCxcbiAgICBkZXNjcmlwdG9yPzogUHJvcGVydHlEZXNjcmlwdG9yLFxuICApID0+IHtcbiAgICBpZiAoZGVzY3JpcHRvcikge1xuICAgICAgUmVmbGVjdC5kZWZpbmVNZXRhZGF0YShrZXksIHZhbHVlLCBkZXNjcmlwdG9yLnZhbHVlKTsgLy8gbWV0aG9kXG4gICAgfSBlbHNlIGlmIChwcm9wZXJ0eUtleSkge1xuICAgICAgUmVmbGVjdC5kZWZpbmVNZXRhZGF0YShrZXksIHZhbHVlLCB0YXJnZXQsIHByb3BlcnR5S2V5KTsgLy8gcHJvcGVydHlcbiAgICB9IGVsc2Uge1xuICAgICAgUmVmbGVjdC5kZWZpbmVNZXRhZGF0YShrZXksIHZhbHVlLCB0YXJnZXQpOyAvLyBjbGFzc1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBAc3VtbWFyeSBEZWNvcmF0b3IgdGhhdCBhc3NpZ25zIG1ldGFkYXRhIHRvIHRoZSBjbGFzcy9tZXRob2QgdXNpbmcgdGhlXG4gKiBzcGVjaWZpZWQgYGtleWAuXG4gKlxuICogQHBhcmFtIHtBcnJheTxDbGFzc0RlY29yYXRvciB8IE1ldGhvZERlY29yYXRvciB8IFByb3BlcnR5RGVjb3JhdG9yPn0gZGVjb3JhdG9ycyBhIHZhbHVlIGRlZmluaW5nIHRoZSBrZXkgdW5kZXIgd2hpY2ggdGhlIG1ldGFkYXRhIGlzIHN0b3JlZFxuICpcbiAqIEBmdW5jdGlvbiBhcHBseVxuICpcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb24uUmVmbGVjdGlvbnNcbiAqIEBjYXRlZ29yeSBEZWNvcmF0b3JzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhcHBseShcbiAgLi4uZGVjb3JhdG9yczogQXJyYXk8Q2xhc3NEZWNvcmF0b3IgfCBNZXRob2REZWNvcmF0b3IgfCBQcm9wZXJ0eURlY29yYXRvcj5cbikge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICByZXR1cm4gPFRGdW5jdGlvbiBleHRlbmRzIEZ1bmN0aW9uLCBZPihcbiAgICB0YXJnZXQ6IFRGdW5jdGlvbiB8IG9iamVjdCxcbiAgICBwcm9wZXJ0eUtleT86IHN0cmluZyB8IHN5bWJvbCxcbiAgICBkZXNjcmlwdG9yPzogVHlwZWRQcm9wZXJ0eURlc2NyaXB0b3I8WT4sXG4gICkgPT4ge1xuICAgIGZvciAoY29uc3QgZGVjb3JhdG9yIG9mIGRlY29yYXRvcnMpIHtcbiAgICAgIGlmICh0YXJnZXQgaW5zdGFuY2VvZiBGdW5jdGlvbiAmJiAhZGVzY3JpcHRvcikge1xuICAgICAgICAoZGVjb3JhdG9yIGFzIENsYXNzRGVjb3JhdG9yKSh0YXJnZXQpO1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cbiAgICAgIChkZWNvcmF0b3IgYXMgTWV0aG9kRGVjb3JhdG9yIHwgUHJvcGVydHlEZWNvcmF0b3IpKFxuICAgICAgICB0YXJnZXQsXG4gICAgICAgIHByb3BlcnR5S2V5IGFzIHN0cmluZyB8IHN5bWJvbCxcbiAgICAgICAgZGVzY3JpcHRvciBhcyBUeXBlZFByb3BlcnR5RGVzY3JpcHRvcjxZPixcbiAgICAgICk7XG4gICAgfVxuICB9O1xufVxuIl19
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import "reflect-metadata";
|
|
2
|
-
export type CustomDecorator<V> = MethodDecorator & ClassDecorator & PropertyDecorator;
|
|
3
|
-
/**
|
|
4
|
-
* @summary Decorator that assigns metadata to the class/method using the
|
|
5
|
-
* specified `key`.
|
|
6
|
-
*
|
|
7
|
-
* @param {string} key a value defining the key under which the metadata is stored
|
|
8
|
-
* @param {any} value metadata to be associated with `key`
|
|
9
|
-
*
|
|
10
|
-
* @function metadata
|
|
11
|
-
*
|
|
12
|
-
* @memberOf module:decorator-validation.Reflections
|
|
13
|
-
* @category Decorators
|
|
14
|
-
*/
|
|
15
|
-
export declare function metadata<V>(key: string, value: V): CustomDecorator<V>;
|
|
16
|
-
/**
|
|
17
|
-
* @summary Decorator that assigns metadata to the class/method using the
|
|
18
|
-
* specified `key`.
|
|
19
|
-
*
|
|
20
|
-
* @param {Array<ClassDecorator | MethodDecorator | PropertyDecorator>} decorators a value defining the key under which the metadata is stored
|
|
21
|
-
*
|
|
22
|
-
* @function apply
|
|
23
|
-
*
|
|
24
|
-
* @memberOf module:decorator-validation.Reflections
|
|
25
|
-
* @category Decorators
|
|
26
|
-
*/
|
|
27
|
-
export declare function apply(...decorators: Array<ClassDecorator | MethodDecorator | PropertyDecorator>): <TFunction extends Function, Y>(target: TFunction | object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
|
package/lib/reflection/index.cjs
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./decorators.cjs"), exports);
|
|
18
|
-
__exportStar(require("./utils.cjs"), exports);
|
|
19
|
-
|
|
20
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9yZWZsZWN0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrQ0FBNkI7QUFDN0IsMENBQXdCIiwiZmlsZSI6InJlZmxlY3Rpb24vaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuIl19
|