@decaf-ts/db-decorators 0.2.0 → 0.3.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 (110) hide show
  1. package/README.md +4 -4
  2. package/dist/db-decorators.bundle.min.js +1 -1
  3. package/dist/esm/db-decorators.bundle.min.esm.js +1 -1
  4. package/lib/esm/identity/decorators.d.ts +1 -1
  5. package/lib/esm/identity/decorators.js +10 -1
  6. package/lib/esm/identity/index.js +4 -1
  7. package/lib/esm/identity/utils.d.ts +6 -9
  8. package/lib/esm/identity/utils.js +63 -1
  9. package/lib/esm/index.js +35 -1
  10. package/lib/esm/interfaces/BulkCrudOperator.js +3 -0
  11. package/lib/esm/interfaces/CrudOperator.js +3 -0
  12. package/lib/esm/interfaces/IRepository.d.ts +2 -3
  13. package/lib/esm/interfaces/IRepository.js +3 -0
  14. package/lib/esm/interfaces/index.js +5 -1
  15. package/lib/esm/model/constants.d.ts +1 -1
  16. package/lib/esm/model/constants.js +39 -1
  17. package/lib/esm/model/decorators.d.ts +5 -7
  18. package/lib/esm/model/decorators.js +69 -1
  19. package/lib/esm/model/index.d.ts +2 -1
  20. package/lib/esm/model/index.js +6 -1
  21. package/lib/esm/model/model.d.ts +8 -0
  22. package/lib/esm/model/model.js +14 -0
  23. package/lib/esm/model/validation.d.ts +1 -2
  24. package/lib/esm/model/validation.js +122 -1
  25. package/lib/esm/operations/Operations.d.ts +3 -4
  26. package/lib/esm/operations/Operations.js +35 -1
  27. package/lib/esm/operations/OperationsRegistry.d.ts +2 -3
  28. package/lib/esm/operations/OperationsRegistry.js +65 -1
  29. package/lib/esm/operations/constants.d.ts +1 -1
  30. package/lib/esm/operations/constants.js +39 -1
  31. package/lib/esm/operations/decorators.js +226 -1
  32. package/lib/esm/operations/index.js +7 -1
  33. package/lib/esm/operations/types.d.ts +4 -5
  34. package/lib/esm/operations/types.js +3 -0
  35. package/lib/esm/repository/BaseRepository.d.ts +2 -3
  36. package/lib/esm/repository/BaseRepository.js +158 -1
  37. package/lib/esm/repository/DataCache.js +32 -1
  38. package/lib/esm/repository/Repository.d.ts +3 -2
  39. package/lib/esm/repository/Repository.js +89 -2
  40. package/lib/esm/repository/errors.js +88 -1
  41. package/lib/esm/repository/index.js +8 -1
  42. package/lib/esm/repository/utils.d.ts +3 -4
  43. package/lib/esm/repository/utils.js +167 -1
  44. package/lib/esm/repository/wrappers.js +90 -1
  45. package/lib/esm/validation/constants.js +33 -1
  46. package/lib/esm/validation/decorators.d.ts +6 -8
  47. package/lib/esm/validation/decorators.js +223 -1
  48. package/lib/esm/validation/index.js +5 -1
  49. package/lib/esm/validation/validators/ReadOnlyValidator.js +52 -1
  50. package/lib/esm/validation/validators/TimestampValidator.js +49 -1
  51. package/lib/esm/validation/validators/UpdateValidator.js +20 -1
  52. package/lib/esm/validation/validators/index.js +5 -1
  53. package/lib/identity/decorators.cjs +13 -1
  54. package/lib/identity/decorators.d.ts +1 -1
  55. package/lib/identity/index.cjs +20 -1
  56. package/lib/identity/utils.cjs +67 -1
  57. package/lib/identity/utils.d.ts +6 -9
  58. package/lib/index.cjs +51 -1
  59. package/lib/interfaces/BulkCrudOperator.cjs +4 -1
  60. package/lib/interfaces/CrudOperator.cjs +4 -1
  61. package/lib/interfaces/IRepository.cjs +4 -1
  62. package/lib/interfaces/IRepository.d.ts +2 -3
  63. package/lib/interfaces/index.cjs +21 -1
  64. package/lib/model/constants.cjs +42 -1
  65. package/lib/model/constants.d.ts +1 -1
  66. package/lib/model/decorators.cjs +76 -1
  67. package/lib/model/decorators.d.ts +5 -7
  68. package/lib/model/index.cjs +22 -1
  69. package/lib/model/index.d.ts +2 -1
  70. package/lib/model/model.cjs +16 -0
  71. package/lib/model/model.d.ts +8 -0
  72. package/lib/model/validation.cjs +125 -1
  73. package/lib/model/validation.d.ts +1 -2
  74. package/lib/operations/Operations.cjs +39 -1
  75. package/lib/operations/Operations.d.ts +3 -4
  76. package/lib/operations/OperationsRegistry.cjs +69 -1
  77. package/lib/operations/OperationsRegistry.d.ts +2 -3
  78. package/lib/operations/constants.cjs +42 -1
  79. package/lib/operations/constants.d.ts +1 -1
  80. package/lib/operations/decorators.cjs +241 -1
  81. package/lib/operations/index.cjs +23 -1
  82. package/lib/operations/types.cjs +4 -1
  83. package/lib/operations/types.d.ts +4 -5
  84. package/lib/repository/BaseRepository.cjs +162 -1
  85. package/lib/repository/BaseRepository.d.ts +2 -3
  86. package/lib/repository/DataCache.cjs +36 -1
  87. package/lib/repository/Repository.cjs +93 -2
  88. package/lib/repository/Repository.d.ts +3 -2
  89. package/lib/repository/errors.cjs +97 -1
  90. package/lib/repository/index.cjs +24 -1
  91. package/lib/repository/utils.cjs +174 -1
  92. package/lib/repository/utils.d.ts +3 -4
  93. package/lib/repository/wrappers.cjs +95 -1
  94. package/lib/validation/constants.cjs +36 -1
  95. package/lib/validation/decorators.cjs +232 -1
  96. package/lib/validation/decorators.d.ts +6 -8
  97. package/lib/validation/index.cjs +21 -1
  98. package/lib/validation/validators/ReadOnlyValidator.cjs +55 -1
  99. package/lib/validation/validators/TimestampValidator.cjs +52 -1
  100. package/lib/validation/validators/UpdateValidator.cjs +24 -1
  101. package/lib/validation/validators/index.cjs +21 -1
  102. package/package.json +22 -18
  103. package/lib/esm/model/DBModel.d.ts +0 -25
  104. package/lib/esm/model/DBModel.js +0 -1
  105. package/lib/esm/validation/comparison.d.ts +0 -1
  106. package/lib/esm/validation/comparison.js +0 -1
  107. package/lib/model/DBModel.cjs +0 -1
  108. package/lib/model/DBModel.d.ts +0 -25
  109. package/lib/validation/comparison.cjs +0 -1
  110. package/lib/validation/comparison.d.ts +0 -1
@@ -1,13 +1,11 @@
1
- import { DBModel } from "./DBModel";
2
1
  import { IRepository } from "../interfaces/IRepository";
3
2
  /**
4
3
  *
5
4
  * @param {str} str
6
5
  * @memberOf db-decorators.model
7
6
  */
8
- export declare function getDBKey(str: string): string;
9
- export declare function hashOnCreateUpdate<T extends DBModel, V extends IRepository<T>, Y = any>(this: V, data: Y, key: string, model: T, oldModel?: T): void;
10
- export declare function hash(): <TFunction extends Function, Y>(target: object | TFunction, propertyKey?: string | symbol | undefined, descriptor?: TypedPropertyDescriptor<Y> | undefined) => void;
7
+ export declare function hashOnCreateUpdate<M extends Model, R extends IRepository<M>, Y = any>(this: R, data: Y, key: string, model: M, oldModel?: M): void;
8
+ export declare function hash(): (target: object, propertyKey?: any, descriptor?: any) => void;
11
9
  export type ComposedFromMetadata = {
12
10
  args: string[];
13
11
  separator: string;
@@ -16,6 +14,6 @@ export type ComposedFromMetadata = {
16
14
  prefix?: string;
17
15
  suffix?: string;
18
16
  };
19
- export declare function composedFromCreateUpdate<T extends DBModel, V extends IRepository<T>>(this: V, data: ComposedFromMetadata, key: string, model: T): void;
20
- export declare function composedFromKeys(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): <TFunction extends Function, Y>(target: object | TFunction, propertyKey?: string | symbol | undefined, descriptor?: TypedPropertyDescriptor<Y> | undefined) => void;
21
- export declare function composed(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): <TFunction extends Function, Y>(target: object | TFunction, propertyKey?: string | symbol | undefined, descriptor?: TypedPropertyDescriptor<Y> | undefined) => void;
17
+ export declare function composedFromCreateUpdate<T extends Model, V extends IRepository<T>>(this: V, data: ComposedFromMetadata, key: string, model: T): void;
18
+ export declare function composedFromKeys(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: any, descriptor?: any) => void;
19
+ export declare function composed(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: any, descriptor?: any) => void;
@@ -1 +1,22 @@
1
- "use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(e,t,r,o){void 0===o&&(o=r);var i=Object.getOwnPropertyDescriptor(t,r);i&&("get"in i?t.__esModule:!i.writable&&!i.configurable)||(i={enumerable:!0,get:function(){return t[r]}}),Object.defineProperty(e,o,i)}:function(e,t,r,o){e[o=void 0===o?r:o]=t[r]}),__exportStar=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||__createBinding(t,e,r)};Object.defineProperty(exports,"__esModule",{value:!0}),__exportStar(require("./constants.cjs"),exports),__exportStar(require("./DBModel.cjs"),exports),__exportStar(require("./decorators.cjs"),exports);
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("./validation.cjs"), exports);
18
+ __exportStar(require("./constants.cjs"), exports);
19
+ __exportStar(require("./decorators.cjs"), exports);
20
+ __exportStar(require("./model.cjs"), exports);
21
+
22
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCO0FBQzdCLDhDQUE0QjtBQUM1QiwrQ0FBNkI7QUFDN0IsMENBQXdCIiwiZmlsZSI6Im1vZGVsL2luZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdGlvblwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuIl19
@@ -1,3 +1,4 @@
1
+ export * from "./validation";
1
2
  export * from "./constants";
2
- export * from "./DBModel";
3
3
  export * from "./decorators";
4
+ export * from "./model";
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
4
+ const validation_1 = require("./validation.cjs");
5
+ decorator_validation_1.Model.prototype.hasErrors = function (previousVersion, ...exclusions) {
6
+ if (previousVersion && !(previousVersion instanceof decorator_validation_1.Model)) {
7
+ exclusions.unshift(previousVersion);
8
+ previousVersion = undefined;
9
+ }
10
+ const errs = (0, decorator_validation_1.validate)(this, ...exclusions);
11
+ if (errs || !previousVersion)
12
+ return errs;
13
+ return (0, validation_1.validateCompare)(previousVersion, this, ...exclusions);
14
+ };
15
+
16
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9tb2RlbC9tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHlFQVN3QztBQUN4Qyw2Q0FBK0M7QUFFL0MsNEJBQUssQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFHLFVBRTFCLGVBQXlCLEVBQ3pCLEdBQUcsVUFBaUI7SUFFcEIsSUFBSSxlQUFlLElBQUksQ0FBQyxDQUFDLGVBQWUsWUFBWSw0QkFBSyxDQUFDLEVBQUUsQ0FBQztRQUMzRCxVQUFVLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQ3BDLGVBQWUsR0FBRyxTQUFTLENBQUM7SUFDOUIsQ0FBQztJQUVELE1BQU0sSUFBSSxHQUFHLElBQUEsK0JBQVEsRUFBQyxJQUFJLEVBQUUsR0FBRyxVQUFVLENBQUMsQ0FBQztJQUMzQyxJQUFJLElBQUksSUFBSSxDQUFDLGVBQWU7UUFBRSxPQUFPLElBQUksQ0FBQztJQUUxQyxPQUFPLElBQUEsNEJBQWUsRUFBQyxlQUFlLEVBQUUsSUFBSSxFQUFFLEdBQUcsVUFBVSxDQUFDLENBQUM7QUFDL0QsQ0FBQyxDQUFDIiwiZmlsZSI6Im1vZGVsL21vZGVsLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcGFyYWJsZSxcbiAgSGFzaGFibGUsXG4gIE1vZGVsQXJnLFxuICBNb2RlbEVycm9yRGVmaW5pdGlvbixcbiAgU2VyaWFsaXphYmxlLFxuICBWYWxpZGF0YWJsZSxcbiAgTW9kZWwsXG4gIHZhbGlkYXRlLFxufSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyB2YWxpZGF0ZUNvbXBhcmUgfSBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG5cbk1vZGVsLnByb3RvdHlwZS5oYXNFcnJvcnMgPSBmdW5jdGlvbiA8TSBleHRlbmRzIE1vZGVsPihcbiAgdGhpczogTSxcbiAgcHJldmlvdXNWZXJzaW9uPzogTSB8IGFueSxcbiAgLi4uZXhjbHVzaW9uczogYW55W11cbik6IE1vZGVsRXJyb3JEZWZpbml0aW9uIHwgdW5kZWZpbmVkIHtcbiAgaWYgKHByZXZpb3VzVmVyc2lvbiAmJiAhKHByZXZpb3VzVmVyc2lvbiBpbnN0YW5jZW9mIE1vZGVsKSkge1xuICAgIGV4Y2x1c2lvbnMudW5zaGlmdChwcmV2aW91c1ZlcnNpb24pO1xuICAgIHByZXZpb3VzVmVyc2lvbiA9IHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IGVycnMgPSB2YWxpZGF0ZSh0aGlzLCAuLi5leGNsdXNpb25zKTtcbiAgaWYgKGVycnMgfHwgIXByZXZpb3VzVmVyc2lvbikgcmV0dXJuIGVycnM7XG5cbiAgcmV0dXJuIHZhbGlkYXRlQ29tcGFyZShwcmV2aW91c1ZlcnNpb24sIHRoaXMsIC4uLmV4Y2x1c2lvbnMpO1xufTtcblxuZGVjbGFyZSBnbG9iYWwge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gIC8vIEB0cy1leHBlY3QtZXJyb3JcbiAgZXhwb3J0IGRlY2xhcmUgYWJzdHJhY3QgY2xhc3MgTW9kZWxcbiAgICBpbXBsZW1lbnRzIFZhbGlkYXRhYmxlLCBTZXJpYWxpemFibGUsIEhhc2hhYmxlLCBDb21wYXJhYmxlPE1vZGVsPlxuICB7XG4gICAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKGFyZz86IE1vZGVsQXJnPE1vZGVsPik7XG5cbiAgICBoYXNFcnJvcnMoLi4uZXhjbHVzaW9uczogYW55W10pOiBNb2RlbEVycm9yRGVmaW5pdGlvbiB8IHVuZGVmaW5lZDtcbiAgICBoYXNFcnJvcnMoXG4gICAgICBwcmV2aW91c1ZlcnNpb24/OiBNb2RlbCB8IGFueSxcbiAgICAgIC4uLmV4Y2x1c2lvbnM6IGFueVtdXG4gICAgKTogTW9kZWxFcnJvckRlZmluaXRpb24gfCB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,8 @@
1
+ import { Comparable, Hashable, ModelArg, ModelErrorDefinition, Serializable, Validatable } from "@decaf-ts/decorator-validation";
2
+ declare global {
3
+ export abstract class Model implements Validatable, Serializable, Hashable, Comparable<Model> {
4
+ protected constructor(arg?: ModelArg<Model>);
5
+ hasErrors(...exclusions: any[]): ModelErrorDefinition | undefined;
6
+ hasErrors(previousVersion?: Model | any, ...exclusions: any[]): ModelErrorDefinition | undefined;
7
+ }
8
+ }
@@ -1 +1,125 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.validateCompare=void 0;const decorator_validation_1=require("@decaf-ts/decorator-validation"),reflection_1=require("@decaf-ts/reflection"),validation_1=require("../validation/index.cjs"),identity_1=require("../identity/index.cjs");function validateCompare(r,a,...e){var o=[];for(const p in a)a.hasOwnProperty(p)&&-1===e.indexOf(p)&&o.push((0,reflection_1.getPropertyDecorators)(validation_1.UpdateValidationKeys.REFLECT,a,p));let t=void 0;for(const f of o){var{prop:i,decorators:d}=f;if(d.shift(),d&&d.length){let e=void 0;for(const v of d){var n=decorator_validation_1.Validation.get(v.key);n?(n=n.updateHasErrors(a[i.toString()],r[i.toString()],...Object.values(v.props)))&&((e=e||{})[v.key]=n):console.error(`Could not find Matching validator for ${v.key} for property `+String(f.prop))}e&&((t=t||{})[f.prop.toString()]=e)}}for(const y of Object.keys(a).filter(e=>!t||!t[e])){let o;var s=(0,reflection_1.getPropertyDecorators)(decorator_validation_1.ValidationKeys.REFLECT,a,y).decorators,l=(0,reflection_1.getPropertyDecorators)(decorator_validation_1.ValidationKeys.REFLECT,a,y).decorators.filter(e=>-1!==[decorator_validation_1.ModelKeys.TYPE,decorator_validation_1.ValidationKeys.TYPE].indexOf(e.key));if(l&&l.length){var l=l.pop(),l=l.props.name?[l.props.name]:Array.isArray(l.props.customTypes)?l.props.customTypes:[l.props.customTypes],c=Object.values(decorator_validation_1.ReservedModels).map(e=>e.toLowerCase());for(const _ of l){if(-1===c.indexOf(_.toLowerCase()))switch(_){case Array.name:case Set.name:if(s.length)if(s.find(e=>e.key===decorator_validation_1.ValidationKeys.LIST)){let e,t;switch(_){case Array.name:e=a[y],t=r[y];break;case Set.name:e=a[y].values(),t=r[y].values();break;default:throw new Error("Invalid attribute type "+_)}(o=e.map(e=>{const o=(0,identity_1.findModelId)(e,!0);var r;return o?(r=t.find(e=>o===(0,identity_1.findModelId)(e,!0)))?e.hasErrors(r):void 0:"Failed to find model id"}).filter(e=>!!e))?.length||(o=void 0)}break;default:try{a[y]&&r[y]&&(o=a[y].hasErrors(r[y]))}catch(e){console.warn((0,decorator_validation_1.sf)("Model should be validatable but its not"))}}o&&((t=t||{})[y]=o)}}}return t?new decorator_validation_1.ModelErrorDefinition(t):void 0}exports.validateCompare=validateCompare;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validateCompare = validateCompare;
4
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
5
+ const reflection_1 = require("@decaf-ts/reflection");
6
+ const validation_1 = require("../validation/index.cjs");
7
+ const identity_1 = require("../identity/index.cjs");
8
+ /**
9
+ * @summary Validates the update of a model
10
+ *
11
+ * @param {T} oldModel
12
+ * @param {T} newModel
13
+ * @param {string[]} [exceptions]
14
+ *
15
+ * @function validateCompare
16
+ * @return {ModelErrorDefinition | undefined}
17
+ *
18
+ * @memberOf module:db-decorators.Model
19
+ */
20
+ function validateCompare(oldModel, newModel, ...exceptions) {
21
+ const decoratedProperties = [];
22
+ for (const prop in newModel)
23
+ if (Object.prototype.hasOwnProperty.call(newModel, prop) &&
24
+ exceptions.indexOf(prop) === -1)
25
+ decoratedProperties.push((0, reflection_1.getPropertyDecorators)(validation_1.UpdateValidationKeys.REFLECT, newModel, prop));
26
+ let result = undefined;
27
+ for (const decoratedProperty of decoratedProperties) {
28
+ const { prop, decorators } = decoratedProperty;
29
+ decorators.shift(); // remove the design:type decorator, since the type will already be checked
30
+ if (!decorators || !decorators.length)
31
+ continue;
32
+ let errs = undefined;
33
+ for (const decorator of decorators) {
34
+ const validator = decorator_validation_1.Validation.get(decorator.key);
35
+ if (!validator) {
36
+ console.error(`Could not find Matching validator for ${decorator.key} for property ${String(decoratedProperty.prop)}`);
37
+ continue;
38
+ }
39
+ const err = validator.updateHasErrors(newModel[prop.toString()], oldModel[prop.toString()], ...Object.values(decorator.props));
40
+ if (err) {
41
+ errs = errs || {};
42
+ errs[decorator.key] = err;
43
+ }
44
+ }
45
+ if (errs) {
46
+ result = result || {};
47
+ result[decoratedProperty.prop.toString()] = errs;
48
+ }
49
+ }
50
+ // tests nested classes
51
+ for (const prop of Object.keys(newModel).filter((k) => !result || !result[k])) {
52
+ let err;
53
+ // if a nested Model
54
+ const allDecorators = (0, reflection_1.getPropertyDecorators)(decorator_validation_1.ValidationKeys.REFLECT, newModel, prop).decorators;
55
+ const decorators = (0, reflection_1.getPropertyDecorators)(decorator_validation_1.ValidationKeys.REFLECT, newModel, prop).decorators.filter((d) => [decorator_validation_1.ModelKeys.TYPE, decorator_validation_1.ValidationKeys.TYPE].indexOf(d.key) !== -1);
56
+ if (!decorators || !decorators.length)
57
+ continue;
58
+ const dec = decorators.pop();
59
+ const clazz = dec.props.name
60
+ ? [dec.props.name]
61
+ : Array.isArray(dec.props.customTypes)
62
+ ? dec.props.customTypes
63
+ : [dec.props.customTypes];
64
+ const reserved = Object.values(decorator_validation_1.ReservedModels).map((v) => v.toLowerCase());
65
+ for (const c of clazz) {
66
+ if (reserved.indexOf(c.toLowerCase()) === -1) {
67
+ switch (c) {
68
+ case Array.name:
69
+ case Set.name:
70
+ if (allDecorators.length) {
71
+ const listDec = allDecorators.find((d) => d.key === decorator_validation_1.ValidationKeys.LIST);
72
+ if (listDec) {
73
+ let currentList, oldList;
74
+ switch (c) {
75
+ case Array.name:
76
+ currentList = newModel[prop];
77
+ oldList = oldModel[prop];
78
+ break;
79
+ case Set.name:
80
+ currentList = newModel[prop].values();
81
+ oldList = oldModel[prop].values();
82
+ break;
83
+ default:
84
+ throw new Error(`Invalid attribute type ${c}`);
85
+ }
86
+ err = currentList
87
+ .map((v) => {
88
+ const id = (0, identity_1.findModelId)(v, true);
89
+ if (!id)
90
+ return "Failed to find model id";
91
+ const oldModel = oldList.find((el) => id === (0, identity_1.findModelId)(el, true));
92
+ if (!oldModel)
93
+ return; // nothing to compare with
94
+ return v.hasErrors(oldModel);
95
+ })
96
+ .filter((e) => !!e);
97
+ if (!err?.length) {
98
+ // if the result is an empty list...
99
+ err = undefined;
100
+ }
101
+ }
102
+ }
103
+ break;
104
+ default:
105
+ try {
106
+ if (newModel[prop] &&
107
+ oldModel[prop])
108
+ err = newModel[prop].hasErrors(oldModel[prop]);
109
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
110
+ }
111
+ catch (e) {
112
+ console.warn((0, decorator_validation_1.sf)("Model should be validatable but its not"));
113
+ }
114
+ }
115
+ }
116
+ if (err) {
117
+ result = result || {};
118
+ result[prop] = err;
119
+ }
120
+ }
121
+ }
122
+ return result ? new decorator_validation_1.ModelErrorDefinition(result) : undefined;
123
+ }
124
+
125
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/model/validation.ts"],"names":[],"mappings":"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","file":"model/validation.js","sourcesContent":["import {\n  ModelErrorDefinition,\n  ModelErrors,\n  ModelKeys,\n  ReservedModels,\n  sf,\n  Validatable,\n  Validation,\n  ValidationKeys,\n  ValidationPropertyDecoratorDefinition,\n} from \"@decaf-ts/decorator-validation\";\nimport { DecoratorMetadata, getPropertyDecorators } from \"@decaf-ts/reflection\";\nimport { UpdateValidationKeys, UpdateValidator } from \"../validation\";\nimport { findModelId } from \"../identity\";\n\n/**\n * @summary Validates the update of a model\n *\n * @param {T} oldModel\n * @param {T} newModel\n * @param {string[]} [exceptions]\n *\n * @function validateCompare\n * @return {ModelErrorDefinition | undefined}\n *\n * @memberOf module:db-decorators.Model\n */\nexport function validateCompare<T extends Model>(\n  oldModel: T,\n  newModel: T,\n  ...exceptions: string[]\n): ModelErrorDefinition | undefined {\n  const decoratedProperties: ValidationPropertyDecoratorDefinition[] = [];\n  for (const prop in newModel)\n    if (\n      Object.prototype.hasOwnProperty.call(newModel, prop) &&\n      exceptions.indexOf(prop) === -1\n    )\n      decoratedProperties.push(\n        getPropertyDecorators(\n          UpdateValidationKeys.REFLECT,\n          newModel,\n          prop\n        ) as ValidationPropertyDecoratorDefinition\n      );\n\n  let result: ModelErrors | undefined = undefined;\n\n  for (const decoratedProperty of decoratedProperties) {\n    const { prop, decorators } = decoratedProperty;\n\n    decorators.shift(); // remove the design:type decorator, since the type will already be checked\n\n    if (!decorators || !decorators.length) continue;\n    let errs: Record<string, string | undefined> | undefined = undefined;\n\n    for (const decorator of decorators) {\n      const validator: UpdateValidator = Validation.get(\n        decorator.key\n      ) as UpdateValidator;\n      if (!validator) {\n        console.error(\n          `Could not find Matching validator for ${decorator.key} for property ${String(decoratedProperty.prop)}`\n        );\n        continue;\n      }\n\n      const err: string | undefined = validator.updateHasErrors(\n        (newModel as any)[prop.toString()],\n        (oldModel as any)[prop.toString()],\n        ...Object.values(decorator.props)\n      );\n\n      if (err) {\n        errs = errs || {};\n        errs[decorator.key] = err;\n      }\n    }\n\n    if (errs) {\n      result = result || {};\n      result[decoratedProperty.prop.toString()] = errs;\n    }\n  }\n  // tests nested classes\n  for (const prop of Object.keys(newModel).filter(\n    (k) => !result || !result[k]\n  )) {\n    let err: string | undefined;\n    // if a nested Model\n    const allDecorators = getPropertyDecorators(\n      ValidationKeys.REFLECT,\n      newModel,\n      prop\n    ).decorators;\n    const decorators = getPropertyDecorators(\n      ValidationKeys.REFLECT,\n      newModel,\n      prop\n    ).decorators.filter(\n      (d) => [ModelKeys.TYPE, ValidationKeys.TYPE].indexOf(d.key) !== -1\n    );\n    if (!decorators || !decorators.length) continue;\n    const dec = decorators.pop() as DecoratorMetadata;\n    const clazz = dec.props.name\n      ? [dec.props.name]\n      : Array.isArray(dec.props.customTypes)\n        ? dec.props.customTypes\n        : [dec.props.customTypes];\n    const reserved = Object.values(ReservedModels).map((v) =>\n      v.toLowerCase()\n    ) as string[];\n\n    for (const c of clazz) {\n      if (reserved.indexOf(c.toLowerCase()) === -1) {\n        switch (c) {\n          case Array.name:\n          case Set.name:\n            if (allDecorators.length) {\n              const listDec = allDecorators.find(\n                (d) => d.key === ValidationKeys.LIST\n              );\n              if (listDec) {\n                let currentList, oldList;\n\n                switch (c) {\n                  case Array.name:\n                    currentList = (newModel as Record<string, any>)[prop];\n                    oldList = (oldModel as Record<string, any>)[prop];\n                    break;\n                  case Set.name:\n                    currentList = (newModel as Record<string, any>)[\n                      prop\n                    ].values();\n                    oldList = (oldModel as Record<string, any>)[prop].values();\n                    break;\n                  default:\n                    throw new Error(`Invalid attribute type ${c}`);\n                }\n\n                err = currentList\n                  .map((v: Validatable) => {\n                    const id = findModelId(v as any, true);\n                    if (!id) return \"Failed to find model id\";\n                    const oldModel = oldList.find(\n                      (el: any) => id === findModelId(el, true)\n                    );\n\n                    if (!oldModel) return; // nothing to compare with\n                    return v.hasErrors(oldModel);\n                  })\n                  .filter((e: any) => !!e) as any;\n\n                if (!err?.length) {\n                  // if the result is an empty list...\n                  err = undefined;\n                }\n              }\n            }\n            break;\n          default:\n            try {\n              if (\n                (newModel as Record<string, any>)[prop] &&\n                (oldModel as Record<string, any>)[prop]\n              )\n                err = (newModel as Record<string, any>)[prop].hasErrors(\n                  (oldModel as Record<string, any>)[prop]\n                );\n              // eslint-disable-next-line @typescript-eslint/no-unused-vars\n            } catch (e: any) {\n              console.warn(sf(\"Model should be validatable but its not\"));\n            }\n        }\n      }\n      if (err) {\n        result = result || {};\n        result[prop] = err as any;\n      }\n    }\n  }\n  return result ? new ModelErrorDefinition(result) : undefined;\n}\n"]}
@@ -1,5 +1,4 @@
1
1
  import { ModelErrorDefinition } from "@decaf-ts/decorator-validation";
2
- import { DBModel } from "./DBModel";
3
2
  /**
4
3
  * @summary Validates the update of a model
5
4
  *
@@ -12,4 +11,4 @@ import { DBModel } from "./DBModel";
12
11
  *
13
12
  * @memberOf module:db-decorators.Model
14
13
  */
15
- export declare function validateCompare<T extends DBModel>(oldModel: T, newModel: T, ...exceptions: string[]): ModelErrorDefinition | undefined;
14
+ export declare function validateCompare<T extends Model>(oldModel: T, newModel: T, ...exceptions: string[]): ModelErrorDefinition | undefined;
@@ -1 +1,39 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.Operations=void 0;const decorator_validation_1=require("@decaf-ts/decorator-validation"),OperationsRegistry_1=require("./OperationsRegistry.cjs"),constants_1=require("./constants.cjs");class Operations{constructor(){}static getHandlerName(e){return e.name||(console.warn("Handler name not defined. A name will be generated, but this is not desirable. please avoid using anonymous functions"),decorator_validation_1.Hashing.hash(e.toString()))}static genKey(e){return constants_1.OperationKeys.REFLECT+e}static get(e,t,r){return Operations.registry.get(e,t,r)}static getOpRegistry(){return Operations.registry||(Operations.registry=new OperationsRegistry_1.OperationsRegistry),Operations.registry}static register(e,t,r,s){Operations.getOpRegistry().register(e,t,r,s)}}exports.Operations=Operations;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Operations = void 0;
4
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
5
+ const OperationsRegistry_1 = require("./OperationsRegistry.cjs");
6
+ const constants_1 = require("./constants.cjs");
7
+ /**
8
+ * @summary Static class holding common Operation Functionality
9
+ *
10
+ * @class Operations
11
+ *
12
+ * @category Operations
13
+ */
14
+ class Operations {
15
+ constructor() { }
16
+ static getHandlerName(handler) {
17
+ if (handler.name)
18
+ return handler.name;
19
+ console.warn("Handler name not defined. A name will be generated, but this is not desirable. please avoid using anonymous functions");
20
+ return decorator_validation_1.Hashing.hash(handler.toString());
21
+ }
22
+ static key(str) {
23
+ return constants_1.OperationKeys.REFLECT + str;
24
+ }
25
+ static get(targetName, propKey, operation) {
26
+ return Operations.registry.get(targetName, propKey, operation);
27
+ }
28
+ static getOpRegistry() {
29
+ if (!Operations.registry)
30
+ Operations.registry = new OperationsRegistry_1.OperationsRegistry();
31
+ return Operations.registry;
32
+ }
33
+ static register(handler, operation, target, propKey) {
34
+ Operations.getOpRegistry().register(handler, operation, target, propKey);
35
+ }
36
+ }
37
+ exports.Operations = Operations;
38
+
39
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9vcGVyYXRpb25zL09wZXJhdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseUVBQXlEO0FBRXpELDZEQUEwRDtBQUMxRCwyQ0FBNEM7QUFFNUM7Ozs7OztHQU1HO0FBQ0gsTUFBYSxVQUFVO0lBR3JCLGdCQUF1QixDQUFDO0lBRXhCLE1BQU0sQ0FBQyxjQUFjLENBQUMsT0FBd0M7UUFDNUQsSUFBSSxPQUFPLENBQUMsSUFBSTtZQUFFLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQztRQUV0QyxPQUFPLENBQUMsSUFBSSxDQUNWLHVIQUF1SCxDQUN4SCxDQUFDO1FBQ0YsT0FBTyw4QkFBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFXO1FBQ3BCLE9BQU8seUJBQWEsQ0FBQyxPQUFPLEdBQUcsR0FBRyxDQUFDO0lBQ3JDLENBQUM7SUFFRCxNQUFNLENBQUMsR0FBRyxDQUNSLFVBQXdDLEVBQ3hDLE9BQWUsRUFDZixTQUFpQjtRQUVqQixPQUFPLFVBQVUsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQVUsRUFBRSxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDakUsQ0FBQztJQUVPLE1BQU0sQ0FBQyxhQUFhO1FBQzFCLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUTtZQUFFLFVBQVUsQ0FBQyxRQUFRLEdBQUcsSUFBSSx1Q0FBa0IsRUFBRSxDQUFDO1FBQ3pFLE9BQU8sVUFBVSxDQUFDLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRUQsTUFBTSxDQUFDLFFBQVEsQ0FDYixPQUFzQyxFQUN0QyxTQUF3QixFQUN4QixNQUFTLEVBQ1QsT0FBd0I7UUFFeEIsVUFBVSxDQUFDLGFBQWEsRUFBRSxDQUFDLFFBQVEsQ0FDakMsT0FBYyxFQUNkLFNBQVMsRUFDVCxNQUFNLEVBQ04sT0FBTyxDQUNSLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUE1Q0QsZ0NBNENDIiwiZmlsZSI6Im9wZXJhdGlvbnMvT3BlcmF0aW9ucy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhc2hpbmcgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBPcGVyYXRpb25IYW5kbGVyIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IE9wZXJhdGlvbnNSZWdpc3RyeSB9IGZyb20gXCIuL09wZXJhdGlvbnNSZWdpc3RyeVwiO1xuaW1wb3J0IHsgT3BlcmF0aW9uS2V5cyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IFN0YXRpYyBjbGFzcyBob2xkaW5nIGNvbW1vbiBPcGVyYXRpb24gRnVuY3Rpb25hbGl0eVxuICpcbiAqIEBjbGFzcyBPcGVyYXRpb25zXG4gKlxuICogQGNhdGVnb3J5IE9wZXJhdGlvbnNcbiAqL1xuZXhwb3J0IGNsYXNzIE9wZXJhdGlvbnMge1xuICBwcml2YXRlIHN0YXRpYyByZWdpc3RyeTogT3BlcmF0aW9uc1JlZ2lzdHJ5O1xuXG4gIHByaXZhdGUgY29uc3RydWN0b3IoKSB7fVxuXG4gIHN0YXRpYyBnZXRIYW5kbGVyTmFtZShoYW5kbGVyOiBPcGVyYXRpb25IYW5kbGVyPGFueSwgYW55LCBhbnk+KSB7XG4gICAgaWYgKGhhbmRsZXIubmFtZSkgcmV0dXJuIGhhbmRsZXIubmFtZTtcblxuICAgIGNvbnNvbGUud2FybihcbiAgICAgIFwiSGFuZGxlciBuYW1lIG5vdCBkZWZpbmVkLiBBIG5hbWUgd2lsbCBiZSBnZW5lcmF0ZWQsIGJ1dCB0aGlzIGlzIG5vdCBkZXNpcmFibGUuIHBsZWFzZSBhdm9pZCB1c2luZyBhbm9ueW1vdXMgZnVuY3Rpb25zXCJcbiAgICApO1xuICAgIHJldHVybiBIYXNoaW5nLmhhc2goaGFuZGxlci50b1N0cmluZygpKTtcbiAgfVxuXG4gIHN0YXRpYyBrZXkoc3RyOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gT3BlcmF0aW9uS2V5cy5SRUZMRUNUICsgc3RyO1xuICB9XG5cbiAgc3RhdGljIGdldChcbiAgICB0YXJnZXROYW1lOiBzdHJpbmcgfCBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIHByb3BLZXk6IHN0cmluZyxcbiAgICBvcGVyYXRpb246IHN0cmluZ1xuICApIHtcbiAgICByZXR1cm4gT3BlcmF0aW9ucy5yZWdpc3RyeS5nZXQodGFyZ2V0TmFtZSwgcHJvcEtleSwgb3BlcmF0aW9uKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIGdldE9wUmVnaXN0cnkoKSB7XG4gICAgaWYgKCFPcGVyYXRpb25zLnJlZ2lzdHJ5KSBPcGVyYXRpb25zLnJlZ2lzdHJ5ID0gbmV3IE9wZXJhdGlvbnNSZWdpc3RyeSgpO1xuICAgIHJldHVybiBPcGVyYXRpb25zLnJlZ2lzdHJ5O1xuICB9XG5cbiAgc3RhdGljIHJlZ2lzdGVyPFYgZXh0ZW5kcyBNb2RlbD4oXG4gICAgaGFuZGxlcjogT3BlcmF0aW9uSGFuZGxlcjxWLCBhbnksIGFueT4sXG4gICAgb3BlcmF0aW9uOiBPcGVyYXRpb25LZXlzLFxuICAgIHRhcmdldDogVixcbiAgICBwcm9wS2V5OiBzdHJpbmcgfCBzeW1ib2xcbiAgKSB7XG4gICAgT3BlcmF0aW9ucy5nZXRPcFJlZ2lzdHJ5KCkucmVnaXN0ZXIoXG4gICAgICBoYW5kbGVyIGFzIGFueSxcbiAgICAgIG9wZXJhdGlvbixcbiAgICAgIHRhcmdldCxcbiAgICAgIHByb3BLZXlcbiAgICApO1xuICB9XG59XG4iXX0=
@@ -1,5 +1,4 @@
1
1
  import { OperationHandler } from "./types";
2
- import { DBModel } from "../model/DBModel";
3
2
  import { OperationKeys } from "./constants";
4
3
  /**
5
4
  * @summary Static class holding common Operation Functionality
@@ -12,8 +11,8 @@ export declare class Operations {
12
11
  private static registry;
13
12
  private constructor();
14
13
  static getHandlerName(handler: OperationHandler<any, any, any>): any;
15
- static genKey(str: string): string;
16
- static get(targetName: string | Record<string, any>, propKey: string, operation: string): OperationHandler<DBModel, import("..").IRepository<DBModel>, unknown>[] | undefined;
14
+ static key(str: string): string;
15
+ static get(targetName: string | Record<string, any>, propKey: string, operation: string): OperationHandler<Model, import("..").IRepository<Model>, unknown>[] | undefined;
17
16
  private static getOpRegistry;
18
- static register<V extends DBModel>(handler: OperationHandler<V, any, any>, operation: OperationKeys, target: V, propKey: string | symbol): void;
17
+ static register<V extends Model>(handler: OperationHandler<V, any, any>, operation: OperationKeys, target: V, propKey: string | symbol): void;
19
18
  }
@@ -1 +1,69 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.OperationsRegistry=void 0;const Operations_1=require("./Operations.cjs");class OperationsRegistry{constructor(){this.cache={}}get(e,t,r,s){s=s||[];let c;try{c="string"==typeof e?e:e.constructor.name,s.unshift(...Object.values(this.cache[c][t][r]||[]))}catch(t){if("string"==typeof e||e===Object.prototype||Object.getPrototypeOf(e)===Object.prototype)return s}let o=Object.getPrototypeOf(e);return o.constructor.name===c&&(o=Object.getPrototypeOf(o)),this.get(o,t,r,s)}register(t,e,r,s){var r=r.constructor.name,c=Operations_1.Operations.getHandlerName(t);this.cache[r]||(this.cache[r]={}),this.cache[r][s]||(this.cache[r][s]={}),this.cache[r][s][e]||(this.cache[r][s][e]={}),this.cache[r][s][e][c]||(this.cache[r][s][e][c]=t)}}exports.OperationsRegistry=OperationsRegistry;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OperationsRegistry = void 0;
4
+ const Operations_1 = require("./Operations.cjs");
5
+ /**
6
+ * @summary Holds the registered operation handlers
7
+ *
8
+ * @class OperationsRegistry
9
+ * @implements IRegistry<OperationHandler<any>>
10
+ *
11
+ * @see OperationHandler
12
+ *
13
+ * @category Operations
14
+ */
15
+ class OperationsRegistry {
16
+ constructor() {
17
+ this.cache = {};
18
+ }
19
+ /**
20
+ * @summary retrieves an {@link OperationHandler} if it exists
21
+ * @param {string} target
22
+ * @param {string} propKey
23
+ * @param {string} operation
24
+ * @param accum
25
+ * @return {OperationHandler | undefined}
26
+ */
27
+ get(target, propKey, operation, accum) {
28
+ accum = accum || [];
29
+ let name;
30
+ try {
31
+ name = typeof target === "string" ? target : target.constructor.name;
32
+ accum.unshift(...Object.values(this.cache[name][propKey][operation] || []));
33
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
34
+ }
35
+ catch (e) {
36
+ if (typeof target === "string" ||
37
+ target === Object.prototype ||
38
+ Object.getPrototypeOf(target) === Object.prototype)
39
+ return accum;
40
+ }
41
+ let proto = Object.getPrototypeOf(target);
42
+ if (proto.constructor.name === name)
43
+ proto = Object.getPrototypeOf(proto);
44
+ return this.get(proto, propKey, operation, accum);
45
+ }
46
+ /**
47
+ * @summary Registers an {@link OperationHandler}
48
+ * @param {OperationHandler} handler
49
+ * @param {string} operation
50
+ * @param {{}} target
51
+ * @param {string | symbol} propKey
52
+ */
53
+ register(handler, operation, target, propKey) {
54
+ const name = target.constructor.name;
55
+ const handlerName = Operations_1.Operations.getHandlerName(handler);
56
+ if (!this.cache[name])
57
+ this.cache[name] = {};
58
+ if (!this.cache[name][propKey])
59
+ this.cache[name][propKey] = {};
60
+ if (!this.cache[name][propKey][operation])
61
+ this.cache[name][propKey][operation] = {};
62
+ if (this.cache[name][propKey][operation][handlerName])
63
+ return;
64
+ this.cache[name][propKey][operation][handlerName] = handler;
65
+ }
66
+ }
67
+ exports.OperationsRegistry = OperationsRegistry;
68
+
69
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9vcGVyYXRpb25zL09wZXJhdGlvbnNSZWdpc3RyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFHQSw2Q0FBMEM7QUFFMUM7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBYSxrQkFBa0I7SUFBL0I7UUFDbUIsVUFBSyxHQU1sQixFQUFFLENBQUM7SUE4RFQsQ0FBQztJQTVEQzs7Ozs7OztPQU9HO0lBQ0gsR0FBRyxDQUNELE1BQW9DLEVBQ3BDLE9BQWUsRUFDZixTQUFpQixFQUNqQixLQUFtQztRQUVuQyxLQUFLLEdBQUcsS0FBSyxJQUFJLEVBQUUsQ0FBQztRQUNwQixJQUFJLElBQUksQ0FBQztRQUNULElBQUksQ0FBQztZQUNILElBQUksR0FBRyxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7WUFDckUsS0FBSyxDQUFDLE9BQU8sQ0FDWCxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FDN0QsQ0FBQztZQUNGLDZEQUE2RDtRQUMvRCxDQUFDO1FBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNYLElBQ0UsT0FBTyxNQUFNLEtBQUssUUFBUTtnQkFDMUIsTUFBTSxLQUFLLE1BQU0sQ0FBQyxTQUFTO2dCQUMzQixNQUFNLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxLQUFLLE1BQU0sQ0FBQyxTQUFTO2dCQUVsRCxPQUFPLEtBQUssQ0FBQztRQUNqQixDQUFDO1FBRUQsSUFBSSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMxQyxJQUFJLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxLQUFLLElBQUk7WUFBRSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUxRSxPQUFPLElBQUksQ0FBQyxHQUFHLENBQVUsS0FBSyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILFFBQVEsQ0FDTixPQUFrQyxFQUNsQyxTQUF3QixFQUN4QixNQUFTLEVBQ1QsT0FBd0I7UUFFeEIsTUFBTSxJQUFJLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDckMsTUFBTSxXQUFXLEdBQUcsdUJBQVUsQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFdkQsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO1lBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDN0MsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDO1lBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDL0QsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQ3ZDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzVDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxXQUFXLENBQUM7WUFBRSxPQUFPO1FBQzlELElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBVyxDQUFDLEdBQUcsT0FBTyxDQUFDO0lBQzlELENBQUM7Q0FDRjtBQXJFRCxnREFxRUMiLCJmaWxlIjoib3BlcmF0aW9ucy9PcGVyYXRpb25zUmVnaXN0cnkuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPcGVyYXRpb25IYW5kbGVyIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IE9wZXJhdGlvbktleXMgfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IElSZXBvc2l0b3J5IH0gZnJvbSBcIi4uL2ludGVyZmFjZXMvSVJlcG9zaXRvcnlcIjtcbmltcG9ydCB7IE9wZXJhdGlvbnMgfSBmcm9tIFwiLi9PcGVyYXRpb25zXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgSG9sZHMgdGhlIHJlZ2lzdGVyZWQgb3BlcmF0aW9uIGhhbmRsZXJzXG4gKlxuICogQGNsYXNzIE9wZXJhdGlvbnNSZWdpc3RyeVxuICogQGltcGxlbWVudHMgSVJlZ2lzdHJ5PE9wZXJhdGlvbkhhbmRsZXI8YW55Pj5cbiAqXG4gKiBAc2VlIE9wZXJhdGlvbkhhbmRsZXJcbiAqXG4gKiBAY2F0ZWdvcnkgT3BlcmF0aW9uc1xuICovXG5leHBvcnQgY2xhc3MgT3BlcmF0aW9uc1JlZ2lzdHJ5IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjYWNoZTogUmVjb3JkPFxuICAgIHN0cmluZyxcbiAgICBSZWNvcmQ8XG4gICAgICBzdHJpbmcgfCBzeW1ib2wsXG4gICAgICBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCBPcGVyYXRpb25IYW5kbGVyPGFueSwgYW55LCBhbnk+Pj5cbiAgICA+XG4gID4gPSB7fTtcblxuICAvKipcbiAgICogQHN1bW1hcnkgcmV0cmlldmVzIGFuIHtAbGluayBPcGVyYXRpb25IYW5kbGVyfSBpZiBpdCBleGlzdHNcbiAgICogQHBhcmFtIHtzdHJpbmd9IHRhcmdldFxuICAgKiBAcGFyYW0ge3N0cmluZ30gcHJvcEtleVxuICAgKiBAcGFyYW0ge3N0cmluZ30gb3BlcmF0aW9uXG4gICAqIEBwYXJhbSBhY2N1bVxuICAgKiBAcmV0dXJuIHtPcGVyYXRpb25IYW5kbGVyIHwgdW5kZWZpbmVkfVxuICAgKi9cbiAgZ2V0PFQgZXh0ZW5kcyBNb2RlbCwgViBleHRlbmRzIElSZXBvc2l0b3J5PFQ+LCBZPihcbiAgICB0YXJnZXQ6IHN0cmluZyB8IFJlY29yZDxzdHJpbmcsIGFueT4sXG4gICAgcHJvcEtleTogc3RyaW5nLFxuICAgIG9wZXJhdGlvbjogc3RyaW5nLFxuICAgIGFjY3VtPzogT3BlcmF0aW9uSGFuZGxlcjxULCBWLCBZPltdXG4gICk6IE9wZXJhdGlvbkhhbmRsZXI8VCwgViwgWT5bXSB8IHVuZGVmaW5lZCB7XG4gICAgYWNjdW0gPSBhY2N1bSB8fCBbXTtcbiAgICBsZXQgbmFtZTtcbiAgICB0cnkge1xuICAgICAgbmFtZSA9IHR5cGVvZiB0YXJnZXQgPT09IFwic3RyaW5nXCIgPyB0YXJnZXQgOiB0YXJnZXQuY29uc3RydWN0b3IubmFtZTtcbiAgICAgIGFjY3VtLnVuc2hpZnQoXG4gICAgICAgIC4uLk9iamVjdC52YWx1ZXModGhpcy5jYWNoZVtuYW1lXVtwcm9wS2V5XVtvcGVyYXRpb25dIHx8IFtdKVxuICAgICAgKTtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW51c2VkLXZhcnNcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBpZiAoXG4gICAgICAgIHR5cGVvZiB0YXJnZXQgPT09IFwic3RyaW5nXCIgfHxcbiAgICAgICAgdGFyZ2V0ID09PSBPYmplY3QucHJvdG90eXBlIHx8XG4gICAgICAgIE9iamVjdC5nZXRQcm90b3R5cGVPZih0YXJnZXQpID09PSBPYmplY3QucHJvdG90eXBlXG4gICAgICApXG4gICAgICAgIHJldHVybiBhY2N1bTtcbiAgICB9XG5cbiAgICBsZXQgcHJvdG8gPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YodGFyZ2V0KTtcbiAgICBpZiAocHJvdG8uY29uc3RydWN0b3IubmFtZSA9PT0gbmFtZSkgcHJvdG8gPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YocHJvdG8pO1xuXG4gICAgcmV0dXJuIHRoaXMuZ2V0PFQsIFYsIFk+KHByb3RvLCBwcm9wS2V5LCBvcGVyYXRpb24sIGFjY3VtKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAc3VtbWFyeSBSZWdpc3RlcnMgYW4ge0BsaW5rIE9wZXJhdGlvbkhhbmRsZXJ9XG4gICAqIEBwYXJhbSB7T3BlcmF0aW9uSGFuZGxlcn0gaGFuZGxlclxuICAgKiBAcGFyYW0ge3N0cmluZ30gb3BlcmF0aW9uXG4gICAqIEBwYXJhbSB7e319IHRhcmdldFxuICAgKiBAcGFyYW0ge3N0cmluZyB8IHN5bWJvbH0gcHJvcEtleVxuICAgKi9cbiAgcmVnaXN0ZXI8VCBleHRlbmRzIE1vZGVsLCBWIGV4dGVuZHMgSVJlcG9zaXRvcnk8VD4sIFk+KFxuICAgIGhhbmRsZXI6IE9wZXJhdGlvbkhhbmRsZXI8VCwgViwgWT4sXG4gICAgb3BlcmF0aW9uOiBPcGVyYXRpb25LZXlzLFxuICAgIHRhcmdldDogVCxcbiAgICBwcm9wS2V5OiBzdHJpbmcgfCBzeW1ib2xcbiAgKTogdm9pZCB7XG4gICAgY29uc3QgbmFtZSA9IHRhcmdldC5jb25zdHJ1Y3Rvci5uYW1lO1xuICAgIGNvbnN0IGhhbmRsZXJOYW1lID0gT3BlcmF0aW9ucy5nZXRIYW5kbGVyTmFtZShoYW5kbGVyKTtcblxuICAgIGlmICghdGhpcy5jYWNoZVtuYW1lXSkgdGhpcy5jYWNoZVtuYW1lXSA9IHt9O1xuICAgIGlmICghdGhpcy5jYWNoZVtuYW1lXVtwcm9wS2V5XSkgdGhpcy5jYWNoZVtuYW1lXVtwcm9wS2V5XSA9IHt9O1xuICAgIGlmICghdGhpcy5jYWNoZVtuYW1lXVtwcm9wS2V5XVtvcGVyYXRpb25dKVxuICAgICAgdGhpcy5jYWNoZVtuYW1lXVtwcm9wS2V5XVtvcGVyYXRpb25dID0ge307XG4gICAgaWYgKHRoaXMuY2FjaGVbbmFtZV1bcHJvcEtleV1bb3BlcmF0aW9uXVtoYW5kbGVyTmFtZV0pIHJldHVybjtcbiAgICB0aGlzLmNhY2hlW25hbWVdW3Byb3BLZXldW29wZXJhdGlvbl1baGFuZGxlck5hbWVdID0gaGFuZGxlcjtcbiAgfVxufVxuIl19
@@ -1,5 +1,4 @@
1
1
  import { OperationHandler } from "./types";
2
- import { DBModel } from "../model/DBModel";
3
2
  import { OperationKeys } from "./constants";
4
3
  import { IRepository } from "../interfaces/IRepository";
5
4
  /**
@@ -22,7 +21,7 @@ export declare class OperationsRegistry {
22
21
  * @param accum
23
22
  * @return {OperationHandler | undefined}
24
23
  */
25
- get<T extends DBModel, V extends IRepository<T>, Y>(target: string | Record<string, any>, propKey: string, operation: string, accum?: OperationHandler<T, V, Y>[]): OperationHandler<T, V, Y>[] | undefined;
24
+ get<T extends Model, V extends IRepository<T>, Y>(target: string | Record<string, any>, propKey: string, operation: string, accum?: OperationHandler<T, V, Y>[]): OperationHandler<T, V, Y>[] | undefined;
26
25
  /**
27
26
  * @summary Registers an {@link OperationHandler}
28
27
  * @param {OperationHandler} handler
@@ -30,5 +29,5 @@ export declare class OperationsRegistry {
30
29
  * @param {{}} target
31
30
  * @param {string | symbol} propKey
32
31
  */
33
- register<T extends DBModel, V extends IRepository<T>, Y>(handler: OperationHandler<T, V, Y>, operation: OperationKeys, target: T, propKey: string | symbol): void;
32
+ register<T extends Model, V extends IRepository<T>, Y>(handler: OperationHandler<T, V, Y>, operation: OperationKeys, target: T, propKey: string | symbol): void;
34
33
  }
@@ -1 +1,42 @@
1
- "use strict";var OperationKeys;Object.defineProperty(exports,"__esModule",{value:!0}),exports.DBOperations=exports.OperationKeys=void 0,function(e){e.REFLECT="operations.db.",e.CREATE="create",e.READ="read",e.UPDATE="update",e.DELETE="delete",e.ON="on.",e.AFTER="after."}(OperationKeys||(exports.OperationKeys=OperationKeys={})),exports.DBOperations={CREATE:[OperationKeys.CREATE],READ:[OperationKeys.READ],UPDATE:[OperationKeys.UPDATE],DELETE:[OperationKeys.DELETE],CREATE_UPDATE:[OperationKeys.CREATE,OperationKeys.UPDATE],READ_CREATE:[OperationKeys.READ,OperationKeys.CREATE],ALL:[OperationKeys.CREATE,OperationKeys.READ,OperationKeys.UPDATE,OperationKeys.DELETE]};
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DBOperations = exports.OperationKeys = void 0;
4
+ /**
5
+ * @summary Set of constants to define db CRUD operations and their equivalent 'on' and 'after' phases
6
+ * @const OperationKeys
7
+ *
8
+ * @memberOf module:db-decorators.Operations
9
+ */
10
+ var OperationKeys;
11
+ (function (OperationKeys) {
12
+ OperationKeys["REFLECT"] = "decaf.model.db.operations.";
13
+ OperationKeys["CREATE"] = "create";
14
+ OperationKeys["READ"] = "read";
15
+ OperationKeys["UPDATE"] = "update";
16
+ OperationKeys["DELETE"] = "delete";
17
+ OperationKeys["ON"] = "on.";
18
+ OperationKeys["AFTER"] = "after.";
19
+ })(OperationKeys || (exports.OperationKeys = OperationKeys = {}));
20
+ /**
21
+ * @summary Maps out groups of CRUD operations for easier mapping of decorators
22
+ *
23
+ * @constant DBOperations
24
+ *
25
+ * @memberOf module:db-decorators.Operations
26
+ */
27
+ exports.DBOperations = {
28
+ CREATE: [OperationKeys.CREATE],
29
+ READ: [OperationKeys.READ],
30
+ UPDATE: [OperationKeys.UPDATE],
31
+ DELETE: [OperationKeys.DELETE],
32
+ CREATE_UPDATE: [OperationKeys.CREATE, OperationKeys.UPDATE],
33
+ READ_CREATE: [OperationKeys.READ, OperationKeys.CREATE],
34
+ ALL: [
35
+ OperationKeys.CREATE,
36
+ OperationKeys.READ,
37
+ OperationKeys.UPDATE,
38
+ OperationKeys.DELETE,
39
+ ],
40
+ };
41
+
42
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9vcGVyYXRpb25zL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7Ozs7R0FLRztBQUNILElBQVksYUFRWDtBQVJELFdBQVksYUFBYTtJQUN2Qix1REFBc0MsQ0FBQTtJQUN0QyxrQ0FBaUIsQ0FBQTtJQUNqQiw4QkFBYSxDQUFBO0lBQ2Isa0NBQWlCLENBQUE7SUFDakIsa0NBQWlCLENBQUE7SUFDakIsMkJBQVUsQ0FBQTtJQUNWLGlDQUFnQixDQUFBO0FBQ2xCLENBQUMsRUFSVyxhQUFhLDZCQUFiLGFBQWEsUUFReEI7QUFFRDs7Ozs7O0dBTUc7QUFDVSxRQUFBLFlBQVksR0FBb0M7SUFDM0QsTUFBTSxFQUFFLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztJQUM5QixJQUFJLEVBQUUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDO0lBQzFCLE1BQU0sRUFBRSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDOUIsTUFBTSxFQUFFLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQztJQUM5QixhQUFhLEVBQUUsQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQyxNQUFNLENBQUM7SUFDM0QsV0FBVyxFQUFFLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxhQUFhLENBQUMsTUFBTSxDQUFDO0lBQ3ZELEdBQUcsRUFBRTtRQUNILGFBQWEsQ0FBQyxNQUFNO1FBQ3BCLGFBQWEsQ0FBQyxJQUFJO1FBQ2xCLGFBQWEsQ0FBQyxNQUFNO1FBQ3BCLGFBQWEsQ0FBQyxNQUFNO0tBQ3JCO0NBQ0YsQ0FBQyIsImZpbGUiOiJvcGVyYXRpb25zL2NvbnN0YW50cy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHN1bW1hcnkgU2V0IG9mIGNvbnN0YW50cyB0byBkZWZpbmUgZGIgQ1JVRCBvcGVyYXRpb25zIGFuZCB0aGVpciBlcXVpdmFsZW50ICdvbicgYW5kICdhZnRlcicgcGhhc2VzXG4gKiBAY29uc3QgT3BlcmF0aW9uS2V5c1xuICpcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9ycy5PcGVyYXRpb25zXG4gKi9cbmV4cG9ydCBlbnVtIE9wZXJhdGlvbktleXMge1xuICBSRUZMRUNUID0gXCJkZWNhZi5tb2RlbC5kYi5vcGVyYXRpb25zLlwiLFxuICBDUkVBVEUgPSBcImNyZWF0ZVwiLFxuICBSRUFEID0gXCJyZWFkXCIsXG4gIFVQREFURSA9IFwidXBkYXRlXCIsXG4gIERFTEVURSA9IFwiZGVsZXRlXCIsXG4gIE9OID0gXCJvbi5cIixcbiAgQUZURVIgPSBcImFmdGVyLlwiLFxufVxuXG4vKipcbiAqIEBzdW1tYXJ5IE1hcHMgb3V0IGdyb3VwcyBvZiBDUlVEIG9wZXJhdGlvbnMgZm9yIGVhc2llciBtYXBwaW5nIG9mIGRlY29yYXRvcnNcbiAqXG4gKiBAY29uc3RhbnQgREJPcGVyYXRpb25zXG4gKlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzLk9wZXJhdGlvbnNcbiAqL1xuZXhwb3J0IGNvbnN0IERCT3BlcmF0aW9uczogUmVjb3JkPHN0cmluZywgT3BlcmF0aW9uS2V5c1tdPiA9IHtcbiAgQ1JFQVRFOiBbT3BlcmF0aW9uS2V5cy5DUkVBVEVdLFxuICBSRUFEOiBbT3BlcmF0aW9uS2V5cy5SRUFEXSxcbiAgVVBEQVRFOiBbT3BlcmF0aW9uS2V5cy5VUERBVEVdLFxuICBERUxFVEU6IFtPcGVyYXRpb25LZXlzLkRFTEVURV0sXG4gIENSRUFURV9VUERBVEU6IFtPcGVyYXRpb25LZXlzLkNSRUFURSwgT3BlcmF0aW9uS2V5cy5VUERBVEVdLFxuICBSRUFEX0NSRUFURTogW09wZXJhdGlvbktleXMuUkVBRCwgT3BlcmF0aW9uS2V5cy5DUkVBVEVdLFxuICBBTEw6IFtcbiAgICBPcGVyYXRpb25LZXlzLkNSRUFURSxcbiAgICBPcGVyYXRpb25LZXlzLlJFQUQsXG4gICAgT3BlcmF0aW9uS2V5cy5VUERBVEUsXG4gICAgT3BlcmF0aW9uS2V5cy5ERUxFVEUsXG4gIF0sXG59O1xuIl19
@@ -5,7 +5,7 @@
5
5
  * @memberOf module:db-decorators.Operations
6
6
  */
7
7
  export declare enum OperationKeys {
8
- REFLECT = "operations.db.",
8
+ REFLECT = "decaf.model.db.operations.",
9
9
  CREATE = "create",
10
10
  READ = "read",
11
11
  UPDATE = "update",