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