@decaf-ts/db-decorators 0.4.34 → 0.5.0

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 (151) hide show
  1. package/dist/db-decorators.cjs +1823 -0
  2. package/dist/db-decorators.esm.cjs +1761 -0
  3. package/lib/esm/identity/decorators.js +1 -2
  4. package/lib/esm/identity/index.js +1 -2
  5. package/lib/esm/identity/utils.js +1 -2
  6. package/lib/esm/index.js +1 -2
  7. package/lib/esm/interfaces/BulkCrudOperator.js +1 -2
  8. package/lib/esm/interfaces/Contextual.js +1 -2
  9. package/lib/esm/interfaces/CrudOperator.js +1 -2
  10. package/lib/esm/interfaces/IRepository.js +1 -2
  11. package/lib/esm/interfaces/index.js +1 -2
  12. package/lib/esm/model/constants.js +1 -2
  13. package/lib/esm/model/decorators.js +1 -2
  14. package/lib/esm/model/index.js +1 -2
  15. package/lib/esm/model/model.js +1 -2
  16. package/lib/esm/model/validation.js +1 -2
  17. package/lib/esm/operations/Operations.js +1 -2
  18. package/lib/esm/operations/OperationsRegistry.js +1 -2
  19. package/lib/esm/operations/constants.js +1 -2
  20. package/lib/esm/operations/decorators.js +1 -2
  21. package/lib/esm/operations/index.js +1 -2
  22. package/lib/esm/operations/types.js +1 -2
  23. package/lib/esm/repository/BaseRepository.js +1 -2
  24. package/lib/esm/repository/Context.js +1 -2
  25. package/lib/esm/repository/DataCache.js +1 -2
  26. package/lib/esm/repository/Repository.js +1 -2
  27. package/lib/esm/repository/errors.js +1 -2
  28. package/lib/esm/repository/index.js +1 -2
  29. package/lib/esm/repository/utils.js +1 -2
  30. package/lib/esm/repository/wrappers.js +1 -2
  31. package/lib/esm/validation/constants.js +1 -2
  32. package/lib/esm/validation/decorators.js +1 -2
  33. package/lib/esm/validation/index.js +1 -2
  34. package/lib/esm/validation/validation.js +1 -2
  35. package/lib/esm/validation/validators/ReadOnlyValidator.js +1 -2
  36. package/lib/esm/validation/validators/TimestampValidator.js +1 -2
  37. package/lib/esm/validation/validators/UpdateValidator.js +1 -2
  38. package/lib/esm/validation/validators/index.js +1 -2
  39. package/lib/identity/decorators.cjs +1 -2
  40. package/lib/identity/decorators.d.ts +1 -0
  41. package/lib/identity/index.cjs +1 -2
  42. package/lib/identity/index.d.ts +2 -0
  43. package/lib/identity/utils.cjs +1 -2
  44. package/lib/identity/utils.d.ts +34 -0
  45. package/lib/index.cjs +1 -2
  46. package/lib/index.d.ts +33 -0
  47. package/lib/interfaces/BulkCrudOperator.cjs +1 -2
  48. package/lib/interfaces/BulkCrudOperator.d.ts +7 -0
  49. package/lib/interfaces/Contextual.cjs +1 -2
  50. package/lib/interfaces/Contextual.d.ts +6 -0
  51. package/lib/interfaces/CrudOperator.cjs +1 -2
  52. package/lib/interfaces/CrudOperator.d.ts +42 -0
  53. package/lib/interfaces/IRepository.cjs +1 -2
  54. package/lib/interfaces/IRepository.d.ts +11 -0
  55. package/lib/interfaces/index.cjs +1 -2
  56. package/lib/interfaces/index.d.ts +4 -0
  57. package/lib/model/constants.cjs +1 -2
  58. package/lib/model/constants.d.ts +37 -0
  59. package/lib/model/decorators.cjs +1 -2
  60. package/lib/model/decorators.d.ts +50 -0
  61. package/lib/model/index.cjs +1 -2
  62. package/lib/model/index.d.ts +4 -0
  63. package/lib/model/model.cjs +1 -2
  64. package/lib/model/model.d.ts +112 -0
  65. package/lib/model/validation.cjs +1 -2
  66. package/lib/model/validation.d.ts +14 -0
  67. package/lib/operations/Operations.cjs +1 -2
  68. package/lib/operations/Operations.d.ts +19 -0
  69. package/lib/operations/OperationsRegistry.cjs +1 -2
  70. package/lib/operations/OperationsRegistry.d.ts +34 -0
  71. package/lib/operations/constants.cjs +1 -2
  72. package/lib/operations/constants.d.ts +24 -0
  73. package/lib/operations/decorators.cjs +1 -2
  74. package/lib/operations/decorators.d.ts +193 -0
  75. package/lib/operations/index.cjs +1 -2
  76. package/lib/operations/index.d.ts +5 -0
  77. package/lib/operations/types.cjs +1 -2
  78. package/lib/operations/types.d.ts +29 -0
  79. package/lib/repository/BaseRepository.cjs +1 -2
  80. package/lib/repository/BaseRepository.d.ts +36 -0
  81. package/lib/repository/Context.cjs +1 -2
  82. package/lib/repository/Context.d.ts +17 -0
  83. package/lib/repository/DataCache.cjs +1 -2
  84. package/lib/repository/DataCache.d.ts +9 -0
  85. package/lib/repository/Repository.cjs +1 -2
  86. package/lib/repository/Repository.d.ts +10 -0
  87. package/lib/repository/errors.cjs +1 -2
  88. package/lib/repository/errors.d.ts +69 -0
  89. package/lib/repository/index.cjs +1 -2
  90. package/lib/repository/index.d.ts +7 -0
  91. package/lib/repository/utils.cjs +1 -2
  92. package/lib/repository/utils.d.ts +62 -0
  93. package/lib/repository/wrappers.cjs +1 -2
  94. package/lib/repository/wrappers.d.ts +38 -0
  95. package/lib/validation/constants.cjs +1 -2
  96. package/lib/validation/constants.d.ts +30 -0
  97. package/lib/validation/decorators.cjs +1 -2
  98. package/lib/validation/decorators.d.ts +58 -0
  99. package/lib/validation/index.cjs +1 -2
  100. package/lib/validation/index.d.ts +4 -0
  101. package/lib/validation/validation.cjs +1 -2
  102. package/lib/validation/validation.d.ts +41 -0
  103. package/lib/validation/validators/ReadOnlyValidator.cjs +1 -2
  104. package/lib/validation/validators/ReadOnlyValidator.d.ts +23 -0
  105. package/lib/validation/validators/TimestampValidator.cjs +1 -2
  106. package/lib/validation/validators/TimestampValidator.d.ts +14 -0
  107. package/lib/validation/validators/UpdateValidator.cjs +1 -2
  108. package/lib/validation/validators/UpdateValidator.d.ts +23 -0
  109. package/lib/validation/validators/index.cjs +1 -2
  110. package/lib/validation/validators/index.d.ts +3 -0
  111. package/package.json +23 -36
  112. package/dist/db-decorators.js +0 -2
  113. package/dist/db-decorators.js.LICENSE.txt +0 -14
  114. package/dist/esm/db-decorators.js +0 -2
  115. package/dist/esm/db-decorators.js.LICENSE.txt +0 -14
  116. /package/{dist/types → lib/esm}/identity/decorators.d.ts +0 -0
  117. /package/{dist/types → lib/esm}/identity/index.d.ts +0 -0
  118. /package/{dist/types → lib/esm}/identity/utils.d.ts +0 -0
  119. /package/{dist/types → lib/esm}/index.d.ts +0 -0
  120. /package/{dist/types → lib/esm}/interfaces/BulkCrudOperator.d.ts +0 -0
  121. /package/{dist/types → lib/esm}/interfaces/Contextual.d.ts +0 -0
  122. /package/{dist/types → lib/esm}/interfaces/CrudOperator.d.ts +0 -0
  123. /package/{dist/types → lib/esm}/interfaces/IRepository.d.ts +0 -0
  124. /package/{dist/types → lib/esm}/interfaces/index.d.ts +0 -0
  125. /package/{dist/types → lib/esm}/model/constants.d.ts +0 -0
  126. /package/{dist/types → lib/esm}/model/decorators.d.ts +0 -0
  127. /package/{dist/types → lib/esm}/model/index.d.ts +0 -0
  128. /package/{dist/types → lib/esm}/model/model.d.ts +0 -0
  129. /package/{dist/types → lib/esm}/model/validation.d.ts +0 -0
  130. /package/{dist/types → lib/esm}/operations/Operations.d.ts +0 -0
  131. /package/{dist/types → lib/esm}/operations/OperationsRegistry.d.ts +0 -0
  132. /package/{dist/types → lib/esm}/operations/constants.d.ts +0 -0
  133. /package/{dist/types → lib/esm}/operations/decorators.d.ts +0 -0
  134. /package/{dist/types → lib/esm}/operations/index.d.ts +0 -0
  135. /package/{dist/types → lib/esm}/operations/types.d.ts +0 -0
  136. /package/{dist/types → lib/esm}/repository/BaseRepository.d.ts +0 -0
  137. /package/{dist/types → lib/esm}/repository/Context.d.ts +0 -0
  138. /package/{dist/types → lib/esm}/repository/DataCache.d.ts +0 -0
  139. /package/{dist/types → lib/esm}/repository/Repository.d.ts +0 -0
  140. /package/{dist/types → lib/esm}/repository/errors.d.ts +0 -0
  141. /package/{dist/types → lib/esm}/repository/index.d.ts +0 -0
  142. /package/{dist/types → lib/esm}/repository/utils.d.ts +0 -0
  143. /package/{dist/types → lib/esm}/repository/wrappers.d.ts +0 -0
  144. /package/{dist/types → lib/esm}/validation/constants.d.ts +0 -0
  145. /package/{dist/types → lib/esm}/validation/decorators.d.ts +0 -0
  146. /package/{dist/types → lib/esm}/validation/index.d.ts +0 -0
  147. /package/{dist/types → lib/esm}/validation/validation.d.ts +0 -0
  148. /package/{dist/types → lib/esm}/validation/validators/ReadOnlyValidator.d.ts +0 -0
  149. /package/{dist/types → lib/esm}/validation/validators/TimestampValidator.d.ts +0 -0
  150. /package/{dist/types → lib/esm}/validation/validators/UpdateValidator.d.ts +0 -0
  151. /package/{dist/types → lib/esm}/validation/validators/index.d.ts +0 -0
@@ -0,0 +1,1823 @@
1
+ (function (global, factory) {
2
+ typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@decaf-ts/decorator-validation'), require('@decaf-ts/reflection')) :
3
+ typeof define === 'function' && define.amd ? define(['exports', '@decaf-ts/decorator-validation', '@decaf-ts/reflection'], factory) :
4
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["db-decorators"] = {}, global.decoratorValidation, global.reflection));
5
+ })(this, (function (exports, decoratorValidation, reflection) { 'use strict';
6
+
7
+ /******************************************************************************
8
+ Copyright (c) Microsoft Corporation.
9
+
10
+ Permission to use, copy, modify, and/or distribute this software for any
11
+ purpose with or without fee is hereby granted.
12
+
13
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
14
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
15
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
16
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
17
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
18
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
19
+ PERFORMANCE OF THIS SOFTWARE.
20
+ ***************************************************************************** */
21
+ /* global Reflect, Promise, SuppressedError, Symbol, Iterator */
22
+
23
+
24
+ function __decorate(decorators, target, key, desc) {
25
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
26
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
27
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
28
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
29
+ }
30
+
31
+ function __metadata(metadataKey, metadataValue) {
32
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
33
+ }
34
+
35
+ typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
36
+ var e = new Error(message);
37
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
38
+ };
39
+
40
+ /**
41
+ * @summary Holds the Model reflection keys
42
+ * @const DBKeys
43
+ *
44
+ * @memberOf module:db-decorators.Model
45
+ */
46
+ const DBKeys = {
47
+ REFLECT: `${decoratorValidation.ModelKeys.REFLECT}persistence.`,
48
+ REPOSITORY: "repository",
49
+ CLASS: "_class",
50
+ ID: "id",
51
+ INDEX: "index",
52
+ UNIQUE: "unique",
53
+ SERIALIZE: "serialize",
54
+ READONLY: "readonly",
55
+ TIMESTAMP: "timestamp",
56
+ HASH: "hash",
57
+ COMPOSED: "composed",
58
+ VERSION: "version",
59
+ ORIGINAL: "__originalObj",
60
+ };
61
+ /**
62
+ * @summary The default separator when concatenating indexes
63
+ *
64
+ * @const DefaultIndexSeparator
65
+ *
66
+ * @category Managers
67
+ * @subcategory Constants
68
+ */
69
+ const DefaultSeparator = "_";
70
+ /**
71
+ * @summary Holds the default timestamp date format
72
+ * @constant DEFAULT_TIMESTAMP_FORMAT
73
+ *
74
+ * @memberOf module:db-decorators.Model
75
+ */
76
+ const DEFAULT_TIMESTAMP_FORMAT = "dd/MM/yyyy HH:mm:ss:S";
77
+
78
+ /**
79
+ * @summary holds the default error messages
80
+ * @const DEFAULT_ERROR_MESSAGES
81
+ *
82
+ * @memberOf module:db-decorators.Model
83
+ */
84
+ const DEFAULT_ERROR_MESSAGES = {
85
+ ID: {
86
+ INVALID: "This Id is invalid",
87
+ REQUIRED: "The Id is mandatory",
88
+ },
89
+ READONLY: {
90
+ INVALID: "This cannot be updated",
91
+ },
92
+ TIMESTAMP: {
93
+ REQUIRED: "Timestamp is Mandatory",
94
+ DATE: "The Timestamp must the a valid date",
95
+ INVALID: "This value must always increase",
96
+ },
97
+ };
98
+ /**
99
+ * @summary Update reflection keys
100
+ * @const UpdateValidationKeys
101
+ * @memberOf module:db-decorators.Operations
102
+ */
103
+ const UpdateValidationKeys = {
104
+ REFLECT: "db.update.validation.",
105
+ TIMESTAMP: DBKeys.TIMESTAMP,
106
+ READONLY: DBKeys.READONLY,
107
+ };
108
+
109
+ /**
110
+ * @summary Validator for the {@link readonly} decorator
111
+ *
112
+ * @class ReadOnlyValidator
113
+ * @extends Validator
114
+ *
115
+ * @category Validators
116
+ */
117
+ exports.ReadOnlyValidator = class ReadOnlyValidator extends decoratorValidation.Validator {
118
+ constructor() {
119
+ super(DEFAULT_ERROR_MESSAGES.READONLY.INVALID);
120
+ }
121
+ /**
122
+ * @inheritDoc
123
+ */
124
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
125
+ hasErrors(value, ...args) {
126
+ return undefined;
127
+ }
128
+ /**
129
+ * @summary Validates a value has not changed
130
+ * @param {any} value
131
+ * @param {any} oldValue
132
+ * @param {string} [message] the error message override
133
+ */
134
+ updateHasErrors(value, oldValue, message) {
135
+ if (value === undefined)
136
+ return;
137
+ return reflection.isEqual(value, oldValue)
138
+ ? undefined
139
+ : this.getMessage(message || this.message);
140
+ }
141
+ };
142
+ exports.ReadOnlyValidator = __decorate([
143
+ decoratorValidation.validator(UpdateValidationKeys.READONLY),
144
+ __metadata("design:paramtypes", [])
145
+ ], exports.ReadOnlyValidator);
146
+
147
+ /**
148
+ * @summary Validates the update of a timestamp
149
+ *
150
+ * @class TimestampValidator
151
+ * @extends Validator
152
+ *
153
+ * @category Validators
154
+ */
155
+ exports.TimestampValidator = class TimestampValidator extends decoratorValidation.Validator {
156
+ constructor() {
157
+ super(DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID);
158
+ }
159
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
160
+ hasErrors(value, ...args) {
161
+ return undefined;
162
+ }
163
+ updateHasErrors(value, oldValue, message) {
164
+ if (value === undefined)
165
+ return;
166
+ message = message || this.getMessage(message || this.message);
167
+ try {
168
+ value = new Date(value);
169
+ oldValue = new Date(oldValue);
170
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
171
+ }
172
+ catch (e) {
173
+ return message;
174
+ }
175
+ return value <= oldValue ? message : undefined;
176
+ }
177
+ };
178
+ exports.TimestampValidator = __decorate([
179
+ decoratorValidation.validator(UpdateValidationKeys.TIMESTAMP),
180
+ __metadata("design:paramtypes", [])
181
+ ], exports.TimestampValidator);
182
+
183
+ /**
184
+ * @summary Base class for an Update validator
185
+ *
186
+ * @param {string} [message] error message. defaults to {@link DecoratorMessages#DEFAULT}
187
+ * @param {string[]} [acceptedTypes] the accepted value types by the decorator
188
+ *
189
+ * @class UpdateValidator
190
+ * @abstract
191
+ * @extends Validator
192
+ *
193
+ * @category Validators
194
+ */
195
+ class UpdateValidator extends decoratorValidation.Validator {
196
+ constructor(message = decoratorValidation.DEFAULT_ERROR_MESSAGES.DEFAULT, ...acceptedTypes) {
197
+ super(message, ...acceptedTypes);
198
+ }
199
+ }
200
+
201
+ /**
202
+ * @summary Set of constants to define db CRUD operations and their equivalent 'on' and 'after' phases
203
+ * @const OperationKeys
204
+ *
205
+ * @memberOf module:db-decorators.Operations
206
+ */
207
+ exports.OperationKeys = void 0;
208
+ (function (OperationKeys) {
209
+ OperationKeys["REFLECT"] = "decaf.model.db.operations.";
210
+ OperationKeys["CREATE"] = "create";
211
+ OperationKeys["READ"] = "read";
212
+ OperationKeys["UPDATE"] = "update";
213
+ OperationKeys["DELETE"] = "delete";
214
+ OperationKeys["ON"] = "on.";
215
+ OperationKeys["AFTER"] = "after.";
216
+ })(exports.OperationKeys || (exports.OperationKeys = {}));
217
+ /**
218
+ * @summary Maps out groups of CRUD operations for easier mapping of decorators
219
+ *
220
+ * @constant DBOperations
221
+ *
222
+ * @memberOf module:db-decorators.Operations
223
+ */
224
+ const DBOperations = {
225
+ CREATE: [exports.OperationKeys.CREATE],
226
+ READ: [exports.OperationKeys.READ],
227
+ UPDATE: [exports.OperationKeys.UPDATE],
228
+ DELETE: [exports.OperationKeys.DELETE],
229
+ CREATE_UPDATE: [exports.OperationKeys.CREATE, exports.OperationKeys.UPDATE],
230
+ READ_CREATE: [exports.OperationKeys.READ, exports.OperationKeys.CREATE],
231
+ ALL: [
232
+ exports.OperationKeys.CREATE,
233
+ exports.OperationKeys.READ,
234
+ exports.OperationKeys.UPDATE,
235
+ exports.OperationKeys.DELETE,
236
+ ],
237
+ };
238
+
239
+ /**
240
+ * @summary Holds the registered operation handlers
241
+ *
242
+ * @class OperationsRegistry
243
+ * @implements IRegistry<OperationHandler<any>>
244
+ *
245
+ * @see OperationHandler
246
+ *
247
+ * @category Operations
248
+ */
249
+ class OperationsRegistry {
250
+ constructor() {
251
+ this.cache = {};
252
+ }
253
+ /**
254
+ * @summary retrieves an {@link OperationHandler} if it exists
255
+ * @param {string} target
256
+ * @param {string} propKey
257
+ * @param {string} operation
258
+ * @param accum
259
+ * @return {OperationHandler | undefined}
260
+ */
261
+ get(target, propKey, operation, accum) {
262
+ accum = accum || [];
263
+ let name;
264
+ try {
265
+ name = typeof target === "string" ? target : target.constructor.name;
266
+ accum.unshift(...Object.values(this.cache[name][propKey][operation] || []));
267
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
268
+ }
269
+ catch (e) {
270
+ if (typeof target === "string" ||
271
+ target === Object.prototype ||
272
+ Object.getPrototypeOf(target) === Object.prototype)
273
+ return accum;
274
+ }
275
+ let proto = Object.getPrototypeOf(target);
276
+ if (proto.constructor.name === name)
277
+ proto = Object.getPrototypeOf(proto);
278
+ return this.get(proto, propKey, operation, accum);
279
+ }
280
+ /**
281
+ * @summary Registers an {@link OperationHandler}
282
+ * @param {OperationHandler} handler
283
+ * @param {string} operation
284
+ * @param {{}} target
285
+ * @param {string | symbol} propKey
286
+ */
287
+ register(handler, operation, target, propKey) {
288
+ const name = target.constructor.name;
289
+ const handlerName = Operations.getHandlerName(handler);
290
+ if (!this.cache[name])
291
+ this.cache[name] = {};
292
+ if (!this.cache[name][propKey])
293
+ this.cache[name][propKey] = {};
294
+ if (!this.cache[name][propKey][operation])
295
+ this.cache[name][propKey][operation] = {};
296
+ if (this.cache[name][propKey][operation][handlerName])
297
+ return;
298
+ this.cache[name][propKey][operation][handlerName] = handler;
299
+ }
300
+ }
301
+
302
+ /**
303
+ * @summary Static class holding common Operation Functionality
304
+ *
305
+ * @class Operations
306
+ *
307
+ * @category Operations
308
+ */
309
+ class Operations {
310
+ constructor() { }
311
+ static getHandlerName(handler) {
312
+ if (handler.name)
313
+ return handler.name;
314
+ console.warn("Handler name not defined. A name will be generated, but this is not desirable. please avoid using anonymous functions");
315
+ return decoratorValidation.Hashing.hash(handler.toString());
316
+ }
317
+ static key(str) {
318
+ return exports.OperationKeys.REFLECT + str;
319
+ }
320
+ static get(targetName, propKey, operation) {
321
+ return Operations.registry.get(targetName, propKey, operation);
322
+ }
323
+ static getOpRegistry() {
324
+ if (!Operations.registry)
325
+ Operations.registry = new OperationsRegistry();
326
+ return Operations.registry;
327
+ }
328
+ static register(handler, operation, target, propKey) {
329
+ Operations.getOpRegistry().register(handler, operation, target, propKey);
330
+ }
331
+ }
332
+
333
+ function handle(op, handler) {
334
+ return (target, propertyKey) => {
335
+ Operations.register(handler, op, target, propertyKey);
336
+ };
337
+ }
338
+ /**
339
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE_UPDATE}
340
+ *
341
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
342
+ * @param data
343
+ * @param {any[]} [args] Arguments that will be passed in order to the handler method
344
+ *
345
+ * @see on
346
+ *
347
+ * @function onCreateUpdate
348
+ *
349
+ * @category Decorators
350
+ */
351
+ function onCreateUpdate(handler, data) {
352
+ return on(DBOperations.CREATE_UPDATE, handler, data);
353
+ }
354
+ /**
355
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.UPDATE}
356
+ *
357
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
358
+ * @param data
359
+ * @param {any[]} [args] Arguments that will be passed in order to the handler method
360
+ *
361
+ * @see on
362
+ *
363
+ * @function onUpdate
364
+ *
365
+ * @category Decorators
366
+ */
367
+ function onUpdate(handler, data) {
368
+ return on(DBOperations.UPDATE, handler, data);
369
+ }
370
+ /**
371
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE}
372
+ *
373
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
374
+ * @param data
375
+ *
376
+ * @see on
377
+ *
378
+ * @function onCreate
379
+ *
380
+ * @category Decorators
381
+ */
382
+ function onCreate(handler, data) {
383
+ return on(DBOperations.CREATE, handler, data);
384
+ }
385
+ /**
386
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.READ}
387
+ *
388
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
389
+ * @param data
390
+ *
391
+ * @see on
392
+ *
393
+ * @function onRead
394
+ *
395
+ * @category Decorators
396
+ */
397
+ function onRead(handler, data) {
398
+ return on(DBOperations.READ, handler, data);
399
+ }
400
+ /**
401
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}
402
+ *
403
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
404
+ * @param data
405
+ *
406
+ * @see on
407
+ *
408
+ * @function onDelete
409
+ *
410
+ * @category Decorators
411
+ */
412
+ function onDelete(handler, data) {
413
+ return on(DBOperations.DELETE, handler, data);
414
+ }
415
+ /**
416
+ * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}
417
+ *
418
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
419
+ * @param data
420
+ *
421
+ * @see on
422
+ *
423
+ * @function onAny
424
+ *
425
+ * @category Decorators
426
+ */
427
+ function onAny(handler, data) {
428
+ return on(DBOperations.ALL, handler, data);
429
+ }
430
+ /**
431
+ * @summary Defines a behaviour to set on the defined {@link DBOperations}
432
+ *
433
+ * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}
434
+ * @param {OnOperationHandler<any>} handler The method called upon the operation
435
+ * @param data
436
+ *
437
+ * ex: handler(...args, ...props.map(p => target[p]))
438
+ *
439
+ * @function on
440
+ *
441
+ * @category Decorators
442
+ */
443
+ function on(op = DBOperations.ALL, handler, data) {
444
+ return operation(exports.OperationKeys.ON, op, handler, data);
445
+ }
446
+ /**
447
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE_UPDATE}
448
+ *
449
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
450
+ * @param data
451
+ *
452
+ * @see after
453
+ *
454
+ * @function afterCreateUpdate
455
+ *
456
+ * @category Decorators
457
+ */
458
+ function afterCreateUpdate(handler, data) {
459
+ return after(DBOperations.CREATE_UPDATE, handler, data);
460
+ }
461
+ /**
462
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.UPDATE}
463
+ *
464
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
465
+ * @param data
466
+ *
467
+ * @see after
468
+ *
469
+ * @function afterUpdate
470
+ *
471
+ * @category Decorators
472
+ */
473
+ function afterUpdate(handler, data) {
474
+ return after(DBOperations.UPDATE, handler, data);
475
+ }
476
+ /**
477
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE}
478
+ *
479
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
480
+ * @param data
481
+ *
482
+ * @see after
483
+ *
484
+ * @function afterCreate
485
+ *
486
+ * @category Decorators
487
+ */
488
+ function afterCreate(handler, data) {
489
+ return after(DBOperations.CREATE, handler, data);
490
+ }
491
+ /**
492
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.READ}
493
+ *
494
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
495
+ * @param data
496
+ * @param {any[]} [args] Arguments that will be passed in order to the handler method
497
+ *
498
+ * @see after
499
+ *
500
+ * @function afterRead
501
+ *
502
+ * @category Decorators
503
+ */
504
+ function afterRead(handler, data) {
505
+ return after(DBOperations.READ, handler, data);
506
+ }
507
+ /**
508
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}
509
+ *
510
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
511
+ * @param data
512
+ * @param {any[]} [args] Arguments that will be passed in order to the handler method
513
+ *
514
+ * @see after
515
+ *
516
+ * @function afterDelete
517
+ *
518
+ * @category Decorators
519
+ */
520
+ function afterDelete(handler, data) {
521
+ return after(DBOperations.DELETE, handler, data);
522
+ }
523
+ /**
524
+ * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}
525
+ *
526
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
527
+ * @param data
528
+ * @param {any[]} [args] Arguments that will be passed in order to the handler method
529
+ *
530
+ * @see after
531
+ *
532
+ * @function afterAny
533
+ *
534
+ * @category Decorators
535
+ */
536
+ function afterAny(handler, data) {
537
+ return after(DBOperations.ALL, handler, data);
538
+ }
539
+ /**
540
+ * @summary Defines a behaviour to set on the defined {@link DBOperations}
541
+ *
542
+ * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}
543
+ * @param {AfterOperationHandler<any>} handler The method called upon the operation
544
+ *
545
+ * ex: handler(...args, ...props.map(p => target[p]))
546
+ *
547
+ * @param data
548
+ * @param args
549
+ * @function after
550
+ *
551
+ * @category Decorators
552
+ */
553
+ function after(op = DBOperations.ALL, handler, data) {
554
+ return operation(exports.OperationKeys.AFTER, op, handler, data);
555
+ }
556
+ function operation(baseOp, operation = DBOperations.ALL, handler, dataToAdd) {
557
+ return (target, propertyKey) => {
558
+ const name = target.constructor.name;
559
+ const decorators = operation.reduce((accum, op) => {
560
+ const compoundKey = baseOp + op;
561
+ let data = Reflect.getMetadata(Operations.key(compoundKey), target, propertyKey);
562
+ if (!data)
563
+ data = {
564
+ operation: op,
565
+ handlers: {},
566
+ };
567
+ const handlerKey = Operations.getHandlerName(handler);
568
+ if (!data.handlers[name] ||
569
+ !data.handlers[name][propertyKey] ||
570
+ !(handlerKey in data.handlers[name][propertyKey])) {
571
+ data.handlers[name] = data.handlers[name] || {};
572
+ data.handlers[name][propertyKey] =
573
+ data.handlers[name][propertyKey] || {};
574
+ data.handlers[name][propertyKey][handlerKey] = {
575
+ data: dataToAdd,
576
+ };
577
+ accum.push(handle(compoundKey, handler), decoratorValidation.propMetadata(Operations.key(compoundKey), data));
578
+ }
579
+ return accum;
580
+ }, []);
581
+ return reflection.apply(...decorators)(target, propertyKey);
582
+ };
583
+ }
584
+
585
+ /**
586
+ * @summary Base Error
587
+ *
588
+ * @param {string} msg the error message
589
+ *
590
+ * @class BaseDLTError
591
+ * @extends Error
592
+ */
593
+ class BaseError extends Error {
594
+ constructor(name, msg) {
595
+ if (msg instanceof BaseError)
596
+ return msg;
597
+ const message = `[${name}] ${msg instanceof Error ? msg.message : msg}`;
598
+ super(message);
599
+ if (msg instanceof Error)
600
+ this.stack = msg.stack;
601
+ }
602
+ }
603
+ /**
604
+ * @summary Represents a failure in the Model details
605
+ *
606
+ * @param {string} msg the error message
607
+ *
608
+ * @class ValidationError
609
+ * @extends BaseError
610
+ */
611
+ class ValidationError extends BaseError {
612
+ constructor(msg) {
613
+ super(ValidationError.name, msg);
614
+ }
615
+ }
616
+ /**
617
+ * @summary Represents an internal failure (should mean an error in code)
618
+ *
619
+ * @param {string} msg the error message
620
+ *
621
+ * @class InternalError
622
+ * @extends BaseError
623
+ */
624
+ class InternalError extends BaseError {
625
+ constructor(msg) {
626
+ super(InternalError.name, msg);
627
+ }
628
+ }
629
+ /**
630
+ * @summary Represents a failure in the Model de/serialization
631
+ *
632
+ * @param {string} msg the error message
633
+ *
634
+ * @class SerializationError
635
+ * @extends BaseError
636
+ *
637
+ */
638
+ class SerializationError extends BaseError {
639
+ constructor(msg) {
640
+ super(SerializationError.name, msg);
641
+ }
642
+ }
643
+ /**
644
+ * @summary Represents a failure in finding a model
645
+ *
646
+ * @param {string} msg the error message
647
+ *
648
+ * @class NotFoundError
649
+ * @extends BaseError
650
+ *
651
+ */
652
+ class NotFoundError extends BaseError {
653
+ constructor(msg) {
654
+ super(NotFoundError.name, msg);
655
+ }
656
+ }
657
+ /**
658
+ * @summary Represents a conflict in the storage
659
+ *
660
+ * @param {string} msg the error message
661
+ *
662
+ * @class ConflictError
663
+ * @extends BaseError
664
+ *
665
+ */
666
+ class ConflictError extends BaseError {
667
+ constructor(msg) {
668
+ super(ConflictError.name, msg);
669
+ }
670
+ }
671
+
672
+ /**
673
+ * @summary retrieves the arguments for the handler
674
+ * @param {any} dec the decorator
675
+ * @param {string} prop the property name
676
+ * @param {{}} m the model
677
+ * @param {{}} [accum] accumulator used for internal recursiveness
678
+ *
679
+ * @function getHandlerArgs
680
+ * @memberOf module:db-decorators.Repository
681
+ */
682
+ const getHandlerArgs = function (dec, prop, m, accum) {
683
+ const name = m.constructor.name;
684
+ if (!name)
685
+ throw new InternalError("Could not determine model class");
686
+ accum = accum || {};
687
+ if (dec.props.handlers[name] && dec.props.handlers[name][prop])
688
+ accum = { ...dec.props.handlers[name][prop], ...accum };
689
+ let proto = Object.getPrototypeOf(m);
690
+ if (proto === Object.prototype)
691
+ return accum;
692
+ if (proto.constructor.name === name)
693
+ proto = Object.getPrototypeOf(proto);
694
+ return getHandlerArgs(dec, prop, proto, accum);
695
+ };
696
+ /**
697
+ *
698
+ * @param {IRepository<T>} repo
699
+ * @param context
700
+ * @param {T} model
701
+ * @param operation
702
+ * @param prefix
703
+ *
704
+ * @param oldModel
705
+ * @function enforceDBPropertyDecoratorsAsync
706
+ *
707
+ * @memberOf db-decorators.utils
708
+ */
709
+ async function enforceDBDecorators(repo, context, model, operation, prefix, oldModel) {
710
+ const decorators = getDbDecorators(model, operation, prefix);
711
+ if (!decorators)
712
+ return;
713
+ for (const prop in decorators) {
714
+ const decs = decorators[prop];
715
+ for (const dec of decs) {
716
+ const { key } = dec;
717
+ const handlers = Operations.get(model, prop, prefix + key);
718
+ if (!handlers || !handlers.length)
719
+ throw new InternalError(`Could not find registered handler for the operation ${prefix + key} under property ${prop}`);
720
+ const handlerArgs = getHandlerArgs(dec, prop, model);
721
+ if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)
722
+ throw new InternalError(decoratorValidation.sf("Args and handlers length do not match"));
723
+ let handler;
724
+ let data;
725
+ for (let i = 0; i < handlers.length; i++) {
726
+ handler = handlers[i];
727
+ data = Object.values(handlerArgs)[i];
728
+ const args = [context, data.data, prop, model];
729
+ if (operation === exports.OperationKeys.UPDATE && prefix === exports.OperationKeys.ON) {
730
+ if (!oldModel)
731
+ throw new InternalError("Missing old model for update operation");
732
+ args.push(oldModel);
733
+ }
734
+ await handler.apply(repo, args);
735
+ }
736
+ }
737
+ }
738
+ }
739
+ /**
740
+ * Specific for DB Decorators
741
+ * @param {T} model
742
+ * @param {string} operation CRUD {@link OperationKeys}
743
+ * @param {string} [extraPrefix]
744
+ *
745
+ * @function getDbPropertyDecorators
746
+ *
747
+ * @memberOf db-decorators.utils
748
+ */
749
+ function getDbDecorators(model, operation, extraPrefix) {
750
+ const decorators = reflection.Reflection.getAllPropertyDecorators(model,
751
+ // undefined,
752
+ exports.OperationKeys.REFLECT + (extraPrefix ? extraPrefix : ""));
753
+ if (!decorators)
754
+ return;
755
+ return Object.keys(decorators).reduce((accum, decorator) => {
756
+ const dec = decorators[decorator].filter((d) => d.key === operation);
757
+ if (dec && dec.length) {
758
+ if (!accum)
759
+ accum = {};
760
+ accum[decorator] = dec;
761
+ }
762
+ return accum;
763
+ }, undefined);
764
+ }
765
+ /**
766
+ * @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes} recursively
767
+ * @param model
768
+ * @param accum
769
+ * @param prefixes
770
+ *
771
+ * @function getAllPropertyDecoratorsRecursive
772
+ * @memberOf module:db-decorators.Repository
773
+ */
774
+ const getAllPropertyDecoratorsRecursive = function (model, accum, ...prefixes) {
775
+ const accumulator = accum || {};
776
+ const mergeDecorators = function (decs) {
777
+ const pushOrSquash = (key, ...values) => {
778
+ values.forEach((val) => {
779
+ let match;
780
+ if (!(match = accumulator[key].find((e) => e.key === val.key)) ||
781
+ match.props.operation !== val.props.operation) {
782
+ accumulator[key].push(val);
783
+ return;
784
+ }
785
+ if (val.key === decoratorValidation.ModelKeys.TYPE)
786
+ return;
787
+ const { handlers, operation } = val.props;
788
+ if (!operation ||
789
+ !operation.match(new RegExp(`^(:?${exports.OperationKeys.ON}|${exports.OperationKeys.AFTER})(:?${exports.OperationKeys.CREATE}|${exports.OperationKeys.READ}|${exports.OperationKeys.UPDATE}|${exports.OperationKeys.DELETE})$`))) {
790
+ accumulator[key].push(val);
791
+ return;
792
+ }
793
+ const accumHandlers = match.props.handlers;
794
+ Object.entries(handlers).forEach(([clazz, handlerDef]) => {
795
+ if (!(clazz in accumHandlers)) {
796
+ accumHandlers[clazz] = handlerDef;
797
+ return;
798
+ }
799
+ Object.entries(handlerDef).forEach(([handlerProp, handler]) => {
800
+ if (!(handlerProp in accumHandlers[clazz])) {
801
+ accumHandlers[clazz][handlerProp] = handler;
802
+ return;
803
+ }
804
+ Object.entries(handler).forEach(([handlerKey, argsObj]) => {
805
+ if (!(handlerKey in accumHandlers[clazz][handlerProp])) {
806
+ accumHandlers[clazz][handlerProp][handlerKey] = argsObj;
807
+ return;
808
+ }
809
+ console.warn(decoratorValidation.sf("Skipping handler registration for {0} under prop {0} because handler is the same", clazz, handlerProp));
810
+ });
811
+ });
812
+ });
813
+ });
814
+ };
815
+ Object.entries(decs).forEach(([key, value]) => {
816
+ accumulator[key] = accumulator[key] || [];
817
+ pushOrSquash(key, ...value);
818
+ });
819
+ };
820
+ const decs = reflection.Reflection.getAllPropertyDecorators(model, ...prefixes);
821
+ if (decs)
822
+ mergeDecorators(decs);
823
+ if (Object.getPrototypeOf(model) === Object.prototype)
824
+ return accumulator;
825
+ // const name = model.constructor.name;
826
+ const proto = Object.getPrototypeOf(model);
827
+ if (!proto)
828
+ return accumulator;
829
+ // if (proto.constructor && proto.constructor.name === name)
830
+ // proto = Object.getPrototypeOf(proto)
831
+ return getAllPropertyDecoratorsRecursive(proto, accumulator, ...prefixes);
832
+ };
833
+
834
+ class DataCache {
835
+ constructor() {
836
+ this.cache = {};
837
+ }
838
+ async get(key) {
839
+ if (!(key in this.cache))
840
+ throw new NotFoundError(`Key ${key} not in dataStore`);
841
+ return this.cache[key];
842
+ }
843
+ async push(key, value) {
844
+ if (key in this.cache)
845
+ throw new ConflictError(`Key ${key} already in dataStore`);
846
+ this.cache[key] = value;
847
+ }
848
+ async put(key, value) {
849
+ this.cache[key] = value;
850
+ }
851
+ async pop(key) {
852
+ const res = this.get(key);
853
+ delete this.cache[key];
854
+ return res;
855
+ }
856
+ async filter(filter) {
857
+ if (typeof filter === "string")
858
+ filter = new RegExp(filter);
859
+ return Object.keys(this.cache)
860
+ .filter((k) => !!filter.exec(k))
861
+ .map((k) => this.cache[k]);
862
+ }
863
+ async purge(key) {
864
+ if (!key)
865
+ this.cache = {};
866
+ else
867
+ await this.pop(key);
868
+ }
869
+ }
870
+
871
+ class Context extends DataCache {
872
+ constructor(operation, model, parent) {
873
+ super();
874
+ this.operation = operation;
875
+ this.model = model;
876
+ this.parent = parent;
877
+ }
878
+ get timestamp() {
879
+ return new Date();
880
+ }
881
+ async get(key) {
882
+ try {
883
+ return super.get(key);
884
+ }
885
+ catch (e) {
886
+ if (this.parent)
887
+ return this.parent.get(key);
888
+ throw e;
889
+ }
890
+ }
891
+ async pop(key) {
892
+ if (key in this.cache)
893
+ return super.pop(key);
894
+ if (!this.parent)
895
+ throw new NotFoundError(`Key ${key} not in dataStore`);
896
+ return this.parent.pop(key);
897
+ }
898
+ child(operation, model) {
899
+ return this.constructor(operation, model, this);
900
+ }
901
+ static async from(operation, model,
902
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
903
+ ...args) {
904
+ return new Context(operation, model);
905
+ }
906
+ static async args(operation, model, args, contextual) {
907
+ const last = args.pop();
908
+ async function getContext() {
909
+ if (contextual)
910
+ return contextual.context(operation, model, ...args);
911
+ return new Context(operation, model);
912
+ }
913
+ let c;
914
+ if (last) {
915
+ if (last instanceof Context) {
916
+ c = last;
917
+ args.push(last);
918
+ }
919
+ else {
920
+ c = await getContext();
921
+ args.push(last, c);
922
+ }
923
+ }
924
+ else {
925
+ c = await getContext();
926
+ args.push(c);
927
+ }
928
+ return { context: c, args: args };
929
+ }
930
+ }
931
+
932
+ /**
933
+ * @summary Util method to change a method of an object prefixing it with another
934
+ * @param {any} obj The Base Object
935
+ * @param {Function} after The original method
936
+ * @param {Function} prefix The Prefix method. The output will be used as arguments in the original method
937
+ * @param {string} [afterName] When the after function anme cannot be extracted, pass it here
938
+ *
939
+ * @function prefixMethod
940
+ *
941
+ * @memberOf module:db-decorators.Repository
942
+ */
943
+ function prefixMethod(obj, after, prefix, afterName) {
944
+ async function wrapper(...args) {
945
+ const results = await Promise.resolve(prefix.call(this, ...args));
946
+ return Promise.resolve(after.apply(this, results));
947
+ }
948
+ const wrapped = wrapper.bind(obj);
949
+ const name = afterName ? afterName : after.name;
950
+ Object.defineProperty(wrapped, "name", {
951
+ enumerable: true,
952
+ configurable: true,
953
+ writable: false,
954
+ value: name,
955
+ });
956
+ obj[name] = wrapped;
957
+ }
958
+ /**
959
+ * @summary Util method to change a method of an object suffixing it with another
960
+ * @param {any} obj The Base Object
961
+ * @param {Function} before The original method
962
+ * @param {Function} suffix The Prefix method. The output will be used as arguments in the original method
963
+ * @param {string} [beforeName] When the after function anme cannot be extracted, pass it here
964
+ *
965
+ * @function suffixMethod
966
+ *
967
+ * @memberOf module:db-decorators.Repository
968
+ */
969
+ function suffixMethod(obj, before, suffix, beforeName) {
970
+ async function wrapper(...args) {
971
+ const results = await Promise.resolve(before.call(this, ...args));
972
+ return suffix.call(this, ...results);
973
+ }
974
+ const wrapped = wrapper.bind(obj);
975
+ const name = beforeName ? beforeName : before.name;
976
+ Object.defineProperty(wrapped, "name", {
977
+ enumerable: true,
978
+ configurable: true,
979
+ writable: false,
980
+ value: name,
981
+ });
982
+ obj[name] = wrapped;
983
+ }
984
+ /**
985
+ * @summary Util method to wrap a method of an object with additional logic
986
+ *
987
+ * @param {any} obj The Base Object
988
+ * @param {Function} before the method to be prefixed
989
+ * @param {Function} method the method to be wrapped
990
+ * @param {Function} after The method to be suffixed
991
+ * @param {string} [methodName] When the after function anme cannot be extracted, pass it here
992
+ *
993
+ * @function wrapMethodWithContext
994
+ *
995
+ * @memberOf module:db-decorators.Repository
996
+ */
997
+ function wrapMethodWithContext(obj, before, method, after, methodName) {
998
+ async function wrapper(...args) {
999
+ let transformedArgs = before.call(obj, ...args);
1000
+ if (transformedArgs instanceof Promise)
1001
+ transformedArgs = await transformedArgs;
1002
+ const context = transformedArgs[transformedArgs.length - 1];
1003
+ if (!(context instanceof Context))
1004
+ throw new InternalError("Missing a context");
1005
+ let results = await method.call(obj, ...transformedArgs);
1006
+ if (results instanceof Promise)
1007
+ results = await results;
1008
+ results = after.call(this, results, context);
1009
+ if (results instanceof Promise)
1010
+ results = await results;
1011
+ return results;
1012
+ }
1013
+ const wrapped = wrapper.bind(obj);
1014
+ const name = methodName ? methodName : method.name;
1015
+ Object.defineProperty(wrapped, "name", {
1016
+ enumerable: true,
1017
+ configurable: true,
1018
+ writable: false,
1019
+ value: name,
1020
+ });
1021
+ obj[name] = wrapped;
1022
+ }
1023
+
1024
+ /**
1025
+ * @summary Returns the primary key attribute for a {@link Model}
1026
+ * @description searches in all the properties in the object for an {@link id} decorated property
1027
+ *
1028
+ * @param {Model} model
1029
+ *
1030
+ * @throws {InternalError} if no property or more than one properties are {@link id} decorated
1031
+ * or no value is set in that property
1032
+ *
1033
+ * @function findPrimaryKey
1034
+ *
1035
+ * @category managers
1036
+ */
1037
+ function findPrimaryKey(model) {
1038
+ const decorators = getAllPropertyDecoratorsRecursive(model, undefined, DBKeys.REFLECT + DBKeys.ID);
1039
+ const idDecorators = Object.entries(decorators).reduce((accum, [prop, decs]) => {
1040
+ const filtered = decs.filter((d) => d.key !== decoratorValidation.ModelKeys.TYPE);
1041
+ if (filtered && filtered.length) {
1042
+ accum[prop] = accum[prop] || [];
1043
+ accum[prop].push(...filtered);
1044
+ }
1045
+ return accum;
1046
+ }, {});
1047
+ if (!idDecorators || !Object.keys(idDecorators).length)
1048
+ throw new InternalError("Could not find ID decorated Property");
1049
+ if (Object.keys(idDecorators).length > 1)
1050
+ throw new InternalError(decoratorValidation.sf(Object.keys(idDecorators).join(", ")));
1051
+ const idProp = Object.keys(idDecorators)[0];
1052
+ if (!idProp)
1053
+ throw new InternalError("Could not find ID decorated Property");
1054
+ return {
1055
+ id: idProp,
1056
+ props: idDecorators[idProp][0].props,
1057
+ };
1058
+ }
1059
+ /**
1060
+ * @summary Returns the primary key value for a {@link Model}
1061
+ * @description searches in all the properties in the object for an {@link pk} decorated property
1062
+ *
1063
+ * @param {Model} model
1064
+ * @param {boolean} [returnEmpty]
1065
+ * @return {string} primary key
1066
+ *
1067
+ * @throws {InternalError} if no property or more than one properties are {@link pk} decorated
1068
+ * @throws {NotFoundError} returnEmpty is false and no value is set on the {@link pk} decorated property
1069
+ *
1070
+ * @function findModelID
1071
+ *
1072
+ * @category managers
1073
+ */
1074
+ function findModelId(model, returnEmpty = false) {
1075
+ const idProp = findPrimaryKey(model).id;
1076
+ const modelId = model[idProp];
1077
+ if (!modelId && !returnEmpty)
1078
+ throw new InternalError(decoratorValidation.sf("No value for the Id is defined under the property {0}", idProp));
1079
+ return modelId;
1080
+ }
1081
+
1082
+ class BaseRepository {
1083
+ get class() {
1084
+ if (!this._class)
1085
+ throw new InternalError(`No class definition found for this repository`);
1086
+ return this._class;
1087
+ }
1088
+ get pk() {
1089
+ if (!this._pk)
1090
+ this._pk = findPrimaryKey(new this.class()).id;
1091
+ return this._pk;
1092
+ }
1093
+ constructor(clazz) {
1094
+ if (clazz)
1095
+ this._class = clazz;
1096
+ // eslint-disable-next-line @typescript-eslint/no-this-alias
1097
+ const self = this;
1098
+ [this.create, this.read, this.update, this.delete].forEach((m) => {
1099
+ const name = m.name;
1100
+ wrapMethodWithContext(self, self[name + "Prefix"], m, self[name + "Suffix"]);
1101
+ });
1102
+ }
1103
+ async createAll(models, ...args) {
1104
+ return Promise.all(models.map((m) => this.create(m, ...args)));
1105
+ }
1106
+ async createPrefix(model, ...args) {
1107
+ const contextArgs = await Context.args(exports.OperationKeys.CREATE, this.class, args);
1108
+ model = new this.class(model);
1109
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.CREATE, exports.OperationKeys.ON);
1110
+ return [model, ...contextArgs.args];
1111
+ }
1112
+ async createSuffix(model, context) {
1113
+ await enforceDBDecorators(this, context, model, exports.OperationKeys.CREATE, exports.OperationKeys.AFTER);
1114
+ return model;
1115
+ }
1116
+ async createAllPrefix(models, ...args) {
1117
+ const contextArgs = await Context.args(exports.OperationKeys.CREATE, this.class, args);
1118
+ await Promise.all(models.map(async (m) => {
1119
+ m = new this.class(m);
1120
+ await enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.CREATE, exports.OperationKeys.ON);
1121
+ return m;
1122
+ }));
1123
+ return [models, ...contextArgs.args];
1124
+ }
1125
+ async createAllSuffix(models, context) {
1126
+ await Promise.all(models.map((m) => enforceDBDecorators(this, context, m, exports.OperationKeys.CREATE, exports.OperationKeys.AFTER)));
1127
+ return models;
1128
+ }
1129
+ async readAll(keys, ...args) {
1130
+ return await Promise.all(keys.map((id) => this.read(id, ...args)));
1131
+ }
1132
+ async readSuffix(model, context) {
1133
+ await enforceDBDecorators(this, context, model, exports.OperationKeys.READ, exports.OperationKeys.AFTER);
1134
+ return model;
1135
+ }
1136
+ async readPrefix(key, ...args) {
1137
+ const contextArgs = await Context.args(exports.OperationKeys.READ, this.class, args);
1138
+ const model = new this.class();
1139
+ model[this.pk] = key;
1140
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.READ, exports.OperationKeys.ON);
1141
+ return [key, ...contextArgs.args];
1142
+ }
1143
+ async readAllPrefix(keys, ...args) {
1144
+ const contextArgs = await Context.args(exports.OperationKeys.READ, this.class, args);
1145
+ await Promise.all(keys.map(async (k) => {
1146
+ const m = new this.class();
1147
+ m[this.pk] = k;
1148
+ return enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.READ, exports.OperationKeys.ON);
1149
+ }));
1150
+ return [keys, ...contextArgs.args];
1151
+ }
1152
+ async readAllSuffix(models, context) {
1153
+ await Promise.all(models.map((m) => enforceDBDecorators(this, context, m, exports.OperationKeys.READ, exports.OperationKeys.AFTER)));
1154
+ return models;
1155
+ }
1156
+ async updateAll(models, ...args) {
1157
+ return Promise.all(models.map((m) => this.update(m, ...args)));
1158
+ }
1159
+ async updateSuffix(model, context) {
1160
+ await enforceDBDecorators(this, context, model, exports.OperationKeys.UPDATE, exports.OperationKeys.AFTER);
1161
+ return model;
1162
+ }
1163
+ async updatePrefix(model, ...args) {
1164
+ const contextArgs = await Context.args(exports.OperationKeys.UPDATE, this.class, args);
1165
+ const id = model[this.pk];
1166
+ if (!id)
1167
+ throw new InternalError(`No value for the Id is defined under the property ${this.pk}`);
1168
+ const oldModel = await this.read(id);
1169
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.UPDATE, exports.OperationKeys.ON, oldModel);
1170
+ return [model, ...contextArgs.args];
1171
+ }
1172
+ async updateAllPrefix(models, ...args) {
1173
+ const contextArgs = await Context.args(exports.OperationKeys.UPDATE, this.class, args);
1174
+ await Promise.all(models.map((m) => {
1175
+ m = new this.class(m);
1176
+ enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.UPDATE, exports.OperationKeys.ON);
1177
+ return m;
1178
+ }));
1179
+ return [models, ...contextArgs.args];
1180
+ }
1181
+ async updateAllSuffix(models, context) {
1182
+ await Promise.all(models.map((m) => enforceDBDecorators(this, context, m, exports.OperationKeys.UPDATE, exports.OperationKeys.AFTER)));
1183
+ return models;
1184
+ }
1185
+ async deleteAll(keys, ...args) {
1186
+ return Promise.all(keys.map((k) => this.delete(k, ...args)));
1187
+ }
1188
+ async deleteSuffix(model, context) {
1189
+ await enforceDBDecorators(this, context, model, exports.OperationKeys.DELETE, exports.OperationKeys.AFTER);
1190
+ return model;
1191
+ }
1192
+ async deletePrefix(key, ...args) {
1193
+ const contextArgs = await Context.args(exports.OperationKeys.DELETE, this.class, args);
1194
+ const model = await this.read(key, ...contextArgs.args);
1195
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.DELETE, exports.OperationKeys.ON);
1196
+ return [key, ...contextArgs.args];
1197
+ }
1198
+ async deleteAllPrefix(keys, ...args) {
1199
+ const contextArgs = await Context.args(exports.OperationKeys.DELETE, this.class, args);
1200
+ const models = await this.readAll(keys, ...contextArgs.args);
1201
+ await Promise.all(models.map(async (m) => {
1202
+ return enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.DELETE, exports.OperationKeys.ON);
1203
+ }));
1204
+ return [keys, ...contextArgs.args];
1205
+ }
1206
+ async deleteAllSuffix(models, context) {
1207
+ await Promise.all(models.map((m) => enforceDBDecorators(this, context, m, exports.OperationKeys.DELETE, exports.OperationKeys.AFTER)));
1208
+ return models;
1209
+ }
1210
+ merge(oldModel, model) {
1211
+ const extract = (model) => Object.entries(model).reduce((accum, [key, val]) => {
1212
+ if (typeof val !== "undefined")
1213
+ accum[key] = val;
1214
+ return accum;
1215
+ }, {});
1216
+ return new this.class(Object.assign({}, extract(oldModel), extract(model)));
1217
+ }
1218
+ toString() {
1219
+ return decoratorValidation.sf("[{0}] - Repository for {1}", this.constructor.name, this.class.name);
1220
+ }
1221
+ }
1222
+
1223
+ class Repository extends BaseRepository {
1224
+ constructor(clazz) {
1225
+ super(clazz);
1226
+ }
1227
+ async createPrefix(model, ...args) {
1228
+ const contextArgs = await Context.args(exports.OperationKeys.CREATE, this.class, args);
1229
+ model = new this.class(model);
1230
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.CREATE, exports.OperationKeys.ON);
1231
+ const errors = model.hasErrors();
1232
+ if (errors)
1233
+ throw new ValidationError(errors.toString());
1234
+ return [model, ...contextArgs.args];
1235
+ }
1236
+ async createAllPrefix(models, ...args) {
1237
+ const contextArgs = await Context.args(exports.OperationKeys.CREATE, this.class, args);
1238
+ await Promise.all(models.map(async (m) => {
1239
+ m = new this.class(m);
1240
+ await enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.CREATE, exports.OperationKeys.ON);
1241
+ return m;
1242
+ }));
1243
+ const errors = models
1244
+ .map((m) => m.hasErrors())
1245
+ .reduce((accum, e, i) => {
1246
+ if (e)
1247
+ accum =
1248
+ typeof accum === "string"
1249
+ ? accum + `\n - ${i}: ${e.toString()}`
1250
+ : ` - ${i}: ${e.toString()}`;
1251
+ return accum;
1252
+ }, undefined);
1253
+ if (errors)
1254
+ throw new ValidationError(errors);
1255
+ return [models, ...contextArgs.args];
1256
+ }
1257
+ async updatePrefix(model, ...args) {
1258
+ const contextArgs = await Context.args(exports.OperationKeys.UPDATE, this.class, args);
1259
+ const pk = model[this.pk];
1260
+ if (!pk)
1261
+ throw new InternalError(`No value for the Id is defined under the property ${this.pk}`);
1262
+ const oldModel = await this.read(pk);
1263
+ model = this.merge(oldModel, model);
1264
+ await enforceDBDecorators(this, contextArgs.context, model, exports.OperationKeys.UPDATE, exports.OperationKeys.ON, oldModel);
1265
+ const errors = model.hasErrors(oldModel);
1266
+ if (errors)
1267
+ throw new ValidationError(errors.toString());
1268
+ return [model, ...contextArgs.args];
1269
+ }
1270
+ async updateAllPrefix(models, ...args) {
1271
+ const contextArgs = await Context.args(exports.OperationKeys.UPDATE, this.class, args);
1272
+ const ids = models.map((m) => {
1273
+ const id = m[this.pk];
1274
+ if (!id)
1275
+ throw new InternalError(`No value for the Id is defined under the property ${this.pk}`);
1276
+ return id;
1277
+ });
1278
+ const oldModels = await this.readAll(ids, ...contextArgs.args);
1279
+ models = models.map((m, i) => this.merge(oldModels[i], m));
1280
+ await Promise.all(models.map((m, i) => enforceDBDecorators(this, contextArgs.context, m, exports.OperationKeys.UPDATE, exports.OperationKeys.ON, oldModels[i])));
1281
+ const errors = models
1282
+ .map((m, i) => m.hasErrors(oldModels[i], m))
1283
+ .reduce((accum, e, i) => {
1284
+ if (e)
1285
+ accum =
1286
+ typeof accum === "string"
1287
+ ? accum + `\n - ${i}: ${e.toString()}`
1288
+ : ` - ${i}: ${e.toString()}`;
1289
+ return accum;
1290
+ }, undefined);
1291
+ if (errors)
1292
+ throw new ValidationError(errors);
1293
+ return [models, ...contextArgs.args];
1294
+ }
1295
+ static key(key) {
1296
+ return DBKeys.REFLECT + key;
1297
+ }
1298
+ }
1299
+
1300
+ /**
1301
+ * Marks the property as readonly.
1302
+ *
1303
+ * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}
1304
+ *
1305
+ * @decorator readonly
1306
+ *
1307
+ * @category Decorators
1308
+ */
1309
+ function readonly(message = DEFAULT_ERROR_MESSAGES.READONLY.INVALID) {
1310
+ return decoratorValidation.propMetadata(decoratorValidation.Validation.updateKey(DBKeys.READONLY), {
1311
+ message: message,
1312
+ });
1313
+ }
1314
+ async function timestampHandler(context, data, key, model) {
1315
+ model[key] = context.timestamp;
1316
+ }
1317
+ /**
1318
+ * Marks the property as timestamp.
1319
+ * Makes it {@link required}
1320
+ * Makes it a {@link date}
1321
+ *
1322
+ * Date Format:
1323
+ *
1324
+ * <pre>
1325
+ * Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),
1326
+ * I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.
1327
+ * You can display date, time, AM/PM, etc.
1328
+ *
1329
+ * Date and Time Patterns
1330
+ * yy = 2-digit year; yyyy = full year
1331
+ * M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name
1332
+ * EEEE = full weekday name; EEE = short weekday name
1333
+ * d = digit day; dd = 2-digit day
1334
+ * h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours
1335
+ * m = minutes; mm = 2-digit minutes; aaa = AM/PM
1336
+ * s = seconds; ss = 2-digit seconds
1337
+ * S = miliseconds
1338
+ * </pre>
1339
+ *
1340
+ * @param {string[]} operation The {@link DBOperations} to act on. Defaults to {@link DBOperations.CREATE_UPDATE}
1341
+ * @param {string} [format] The TimeStamp format. defaults to {@link DEFAULT_TIMESTAMP_FORMAT}
1342
+ * @param {{new: UpdateValidator}} [validator] defaults to {@link TimestampValidator}
1343
+ *
1344
+ * @decorator timestamp
1345
+ *
1346
+ * @category Decorators
1347
+ */
1348
+ function timestamp(operation = DBOperations.CREATE_UPDATE, format = DEFAULT_TIMESTAMP_FORMAT) {
1349
+ const decorators = [
1350
+ decoratorValidation.date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),
1351
+ decoratorValidation.required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),
1352
+ on(operation, timestampHandler),
1353
+ ];
1354
+ if (operation.indexOf(exports.OperationKeys.UPDATE) !== -1)
1355
+ decorators.push(decoratorValidation.propMetadata(decoratorValidation.Validation.updateKey(DBKeys.TIMESTAMP), {
1356
+ message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,
1357
+ }));
1358
+ return reflection.apply(...decorators);
1359
+ }
1360
+ async function serializeOnCreateUpdate(data, key, model, oldModel) {
1361
+ if (!model[key])
1362
+ return;
1363
+ try {
1364
+ model[key] = JSON.stringify(model[key]);
1365
+ }
1366
+ catch (e) {
1367
+ throw new SerializationError(decoratorValidation.sf("Failed to serialize {0} property on {1} model: {2}", key, model.constructor.name, e.message));
1368
+ }
1369
+ }
1370
+ async function serializeAfterAll(data, key, model) {
1371
+ if (!model[key])
1372
+ return;
1373
+ if (typeof model[key] !== "string")
1374
+ return;
1375
+ try {
1376
+ model[key] = JSON.parse(model[key]);
1377
+ }
1378
+ catch (e) {
1379
+ throw new SerializationError(decoratorValidation.sf("Failed to deserialize {0} property on {1} model: {2}", key, model.constructor.name, e.message));
1380
+ }
1381
+ }
1382
+ /**
1383
+ * @summary Serialize Decorator
1384
+ * @description properties decorated will the serialized before stored in the db
1385
+ *
1386
+ * @function serialize
1387
+ *
1388
+ * @memberOf module:wallet-db.Decorators
1389
+ */
1390
+ function serialize() {
1391
+ return reflection.apply(onCreateUpdate(serializeOnCreateUpdate), after(DBOperations.ALL, serializeAfterAll), decoratorValidation.type([String.name, Object.name]), reflection.metadata(Repository.key(DBKeys.SERIALIZE), {}));
1392
+ }
1393
+ //
1394
+ // /**
1395
+ // * @summary One To One relation Decorators
1396
+ // *
1397
+ // * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
1398
+ // * @param {CascadeMetadata} [cascadeOptions]
1399
+ // * @param {boolean} _populate If true, replaces the specified key in the document with the corresponding record from the database
1400
+ // *
1401
+ // * @function onToOne
1402
+ // *
1403
+ // * @memberOf module:wallet-db.Decorators
1404
+ // *
1405
+ // * @see oneToMany
1406
+ // * @see manyToOne
1407
+ // */
1408
+ // export function oneToOne(
1409
+ // clazz: Constructor<any>,
1410
+ // cascadeOptions: CascadeMetadata = DefaultCascade,
1411
+ // _populate: boolean = true,
1412
+ // ) {
1413
+ // Model.register(clazz);
1414
+ // return (target: any, propertyKey: string) => {
1415
+ // type([clazz.name, String.name])(target, propertyKey);
1416
+ // onCreate(oneToOneOnCreate)(target, propertyKey);
1417
+ // onUpdate(oneToOneOnUpdate, cascadeOptions as any)(target, propertyKey);
1418
+ // onDelete(oneToOneOnDelete, cascadeOptions)(target, propertyKey);
1419
+ //
1420
+ // afterCreate(populate, _populate)(target, propertyKey);
1421
+ // afterUpdate(populate, _populate)(target, propertyKey);
1422
+ // afterRead(populate, _populate)(target, propertyKey);
1423
+ // afterDelete(populate, _populate)(target, propertyKey);
1424
+ //
1425
+ // Reflect.defineMetadata(
1426
+ // getDBKey(WalletDbKeys.ONE_TO_ONE),
1427
+ // {
1428
+ // constructor: clazz.name,
1429
+ // cascade: cascadeOptions,
1430
+ // populate: _populate,
1431
+ // },
1432
+ // target,
1433
+ // propertyKey,
1434
+ // );
1435
+ // };
1436
+ // }
1437
+ //
1438
+ // /**
1439
+ // * @summary One To Many relation Decorators
1440
+ // *
1441
+ // * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
1442
+ // * @param {CascadeMetadata} [cascadeOptions]
1443
+ // *
1444
+ // * @function onToMany
1445
+ // *
1446
+ // * @memberOf module:wallet-db.Decorators
1447
+ // *
1448
+ // * @see oneToOne
1449
+ // * @see manyToOne
1450
+ // */
1451
+ // export function oneToMany(
1452
+ // clazz: Constructor<any>,
1453
+ // cascadeOptions: CascadeMetadata = DefaultCascade,
1454
+ // _populate: boolean = true,
1455
+ // ) {
1456
+ // Model.register(clazz);
1457
+ // return (target: any, propertyKey: string) => {
1458
+ // list([clazz, String])(target, propertyKey);
1459
+ // onCreate(oneToManyOnCreate)(target, propertyKey);
1460
+ // onUpdate(oneToManyOnUpdate, cascadeOptions)(target, propertyKey);
1461
+ // onDelete(oneToManyOnDelete, cascadeOptions)(target, propertyKey);
1462
+ //
1463
+ // afterCreate(populate, _populate)(target, propertyKey);
1464
+ // afterUpdate(populate, _populate)(target, propertyKey);
1465
+ // afterRead(populate, _populate)(target, propertyKey);
1466
+ // afterDelete(populate, _populate)(target, propertyKey);
1467
+ //
1468
+ // Reflect.defineMetadata(
1469
+ // getDBKey(WalletDbKeys.ONE_TO_MANY),
1470
+ // {
1471
+ // constructor: clazz.name,
1472
+ // cascade: cascadeOptions,
1473
+ // },
1474
+ // target,
1475
+ // propertyKey,
1476
+ // );
1477
+ // };
1478
+ // }
1479
+ //
1480
+ // /**
1481
+ // * @summary Many To One relation Decorators
1482
+ // *
1483
+ // * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}
1484
+ // * @param {CascadeMetadata} [cascadeOptions]
1485
+ // *
1486
+ // * @function manyToOne
1487
+ // *
1488
+ // * @memberOf module:wallet-db.Decorators
1489
+ // *
1490
+ // * @see oneToMany
1491
+ // * @see oneToOne
1492
+ // */
1493
+ // export function manyToOne(
1494
+ // clazz: Constructor<any>,
1495
+ // cascadeOptions: CascadeMetadata = DefaultCascade,
1496
+ // ) {
1497
+ // Model.register(clazz);
1498
+ // return (target: any, propertyKey: string) => {
1499
+ // Reflect.defineMetadata(
1500
+ // getDBKey(WalletDbKeys.MANY_TO_ONE),
1501
+ // {
1502
+ // constructor: clazz.name,
1503
+ // cascade: cascadeOptions,
1504
+ // },
1505
+ // target,
1506
+ // propertyKey,
1507
+ // );
1508
+ // };
1509
+ // }
1510
+
1511
+ decoratorValidation.Validation.updateKey = function (key) {
1512
+ return UpdateValidationKeys.REFLECT + key;
1513
+ };
1514
+
1515
+ // // eslint-disable-next-line @typescript-eslint/no-unused-vars
1516
+ // import * as Validation from "../validation/validation";
1517
+ function id() {
1518
+ return reflection.apply(decoratorValidation.required(), readonly(), decoratorValidation.propMetadata(Repository.key(DBKeys.ID), {}));
1519
+ }
1520
+
1521
+ /**
1522
+ * @summary Validates the update of a model
1523
+ *
1524
+ * @param {T} oldModel
1525
+ * @param {T} newModel
1526
+ * @param {string[]} [exceptions]
1527
+ *
1528
+ * @function validateCompare
1529
+ * @return {ModelErrorDefinition | undefined}
1530
+ *
1531
+ * @memberOf module:db-decorators.Model
1532
+ */
1533
+ function validateCompare(oldModel, newModel, ...exceptions) {
1534
+ const decoratedProperties = [];
1535
+ for (const prop in newModel)
1536
+ if (Object.prototype.hasOwnProperty.call(newModel, prop) &&
1537
+ exceptions.indexOf(prop) === -1)
1538
+ decoratedProperties.push(reflection.Reflection.getPropertyDecorators(UpdateValidationKeys.REFLECT, newModel, prop));
1539
+ let result = undefined;
1540
+ for (const decoratedProperty of decoratedProperties) {
1541
+ const { prop, decorators } = decoratedProperty;
1542
+ decorators.shift(); // remove the design:type decorator, since the type will already be checked
1543
+ if (!decorators || !decorators.length)
1544
+ continue;
1545
+ let errs = undefined;
1546
+ for (const decorator of decorators) {
1547
+ const validator = decoratorValidation.Validation.get(decorator.key);
1548
+ if (!validator) {
1549
+ console.error(`Could not find Matching validator for ${decorator.key} for property ${String(decoratedProperty.prop)}`);
1550
+ continue;
1551
+ }
1552
+ const err = validator.updateHasErrors(newModel[prop.toString()], oldModel[prop.toString()], ...Object.values(decorator.props));
1553
+ if (err) {
1554
+ errs = errs || {};
1555
+ errs[decorator.key] = err;
1556
+ }
1557
+ }
1558
+ if (errs) {
1559
+ result = result || {};
1560
+ result[decoratedProperty.prop.toString()] = errs;
1561
+ }
1562
+ }
1563
+ // tests nested classes
1564
+ for (const prop of Object.keys(newModel).filter((k) => {
1565
+ if (exceptions.includes(k))
1566
+ return false;
1567
+ return !result || !result[k];
1568
+ })) {
1569
+ let err;
1570
+ // if a nested Model
1571
+ const allDecorators = reflection.Reflection.getPropertyDecorators(decoratorValidation.ValidationKeys.REFLECT, newModel, prop).decorators;
1572
+ const decorators = reflection.Reflection.getPropertyDecorators(decoratorValidation.ValidationKeys.REFLECT, newModel, prop).decorators.filter((d) => [decoratorValidation.ModelKeys.TYPE, decoratorValidation.ValidationKeys.TYPE].indexOf(d.key) !== -1);
1573
+ if (!decorators || !decorators.length)
1574
+ continue;
1575
+ const dec = decorators.pop();
1576
+ const clazz = dec.props.name
1577
+ ? [dec.props.name]
1578
+ : Array.isArray(dec.props.customTypes)
1579
+ ? dec.props.customTypes
1580
+ : [dec.props.customTypes];
1581
+ const reserved = Object.values(decoratorValidation.ReservedModels).map((v) => v.toLowerCase());
1582
+ for (const c of clazz) {
1583
+ if (reserved.indexOf(c.toLowerCase()) === -1) {
1584
+ switch (c) {
1585
+ case Array.name:
1586
+ case Set.name:
1587
+ if (allDecorators.length) {
1588
+ const listDec = allDecorators.find((d) => d.key === decoratorValidation.ValidationKeys.LIST);
1589
+ if (listDec) {
1590
+ let currentList, oldList;
1591
+ switch (c) {
1592
+ case Array.name:
1593
+ currentList = newModel[prop];
1594
+ oldList = oldModel[prop];
1595
+ break;
1596
+ case Set.name:
1597
+ currentList = newModel[prop].values();
1598
+ oldList = oldModel[prop].values();
1599
+ break;
1600
+ default:
1601
+ throw new Error(`Invalid attribute type ${c}`);
1602
+ }
1603
+ err = currentList
1604
+ .map((v) => {
1605
+ const id = findModelId(v, true);
1606
+ if (!id)
1607
+ return "Failed to find model id";
1608
+ const oldModel = oldList.find((el) => id === findModelId(el, true));
1609
+ if (!oldModel)
1610
+ return; // nothing to compare with
1611
+ return v.hasErrors(oldModel);
1612
+ })
1613
+ .filter((e) => !!e);
1614
+ if (!err?.length) {
1615
+ // if the result is an empty list...
1616
+ err = undefined;
1617
+ }
1618
+ }
1619
+ }
1620
+ break;
1621
+ default:
1622
+ try {
1623
+ if (newModel[prop] &&
1624
+ oldModel[prop])
1625
+ err = newModel[prop].hasErrors(oldModel[prop]);
1626
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1627
+ }
1628
+ catch (e) {
1629
+ console.warn(decoratorValidation.sf("Model should be validatable but its not"));
1630
+ }
1631
+ }
1632
+ }
1633
+ if (err) {
1634
+ result = result || {};
1635
+ result[prop] = err;
1636
+ }
1637
+ }
1638
+ }
1639
+ return result ? new decoratorValidation.ModelErrorDefinition(result) : undefined;
1640
+ }
1641
+
1642
+ /**
1643
+ *
1644
+ * @param {str} str
1645
+ * @memberOf db-decorators.model
1646
+ */
1647
+ function hashOnCreateUpdate(data, key, model, oldModel) {
1648
+ if (!model[key])
1649
+ return;
1650
+ const hash = decoratorValidation.Hashing.hash(model[key]);
1651
+ if (oldModel && model[key] === hash)
1652
+ return;
1653
+ model[key] = hash;
1654
+ }
1655
+ function hash() {
1656
+ return reflection.apply(onCreateUpdate(hashOnCreateUpdate), decoratorValidation.propMetadata(Repository.key(DBKeys.HASH), {}));
1657
+ }
1658
+ function composedFromCreateUpdate(context, data, key, model) {
1659
+ try {
1660
+ const { args, type, prefix, suffix, separator } = data;
1661
+ const composed = args.map((arg) => {
1662
+ if (!(arg in model))
1663
+ throw new InternalError(decoratorValidation.sf("Property {0} not found to compose from", arg));
1664
+ if (type === "keys")
1665
+ return arg;
1666
+ if (typeof model[arg] === "undefined")
1667
+ throw new InternalError(decoratorValidation.sf("Property {0} does not contain a value to compose from", arg));
1668
+ return model[arg].toString();
1669
+ });
1670
+ if (prefix)
1671
+ composed.unshift(prefix);
1672
+ if (suffix)
1673
+ composed.push(suffix);
1674
+ model[key] = composed.join(separator);
1675
+ }
1676
+ catch (e) {
1677
+ throw new InternalError(`Failed to compose value: ${e}`);
1678
+ }
1679
+ }
1680
+ function composedFrom(args, hashResult = false, separator = DefaultSeparator, type = "values", prefix = "", suffix = "") {
1681
+ const data = {
1682
+ args: args,
1683
+ hashResult: hashResult,
1684
+ separator: separator,
1685
+ type: type,
1686
+ prefix: prefix,
1687
+ suffix: suffix,
1688
+ };
1689
+ const decorators = [
1690
+ onCreateUpdate(composedFromCreateUpdate, data),
1691
+ decoratorValidation.propMetadata(Repository.key(DBKeys.COMPOSED), data),
1692
+ ];
1693
+ if (hashResult)
1694
+ decorators.push(hash());
1695
+ return reflection.apply(...decorators);
1696
+ }
1697
+ function composedFromKeys(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "") {
1698
+ return composedFrom(args, hash, separator, "keys", prefix, suffix);
1699
+ }
1700
+ function composed(args, separator = DefaultSeparator, hash = false, prefix = "", suffix = "") {
1701
+ return composedFrom(args, hash, separator, "values", prefix, suffix);
1702
+ }
1703
+ /**
1704
+ * Creates a decorator function that updates the version of a model during create or update operations.
1705
+ *
1706
+ * @param {CrudOperations} operation - The type of operation being performed (CREATE or UPDATE).
1707
+ * @returns {function} A function that updates the version of the model based on the operation type.
1708
+ *
1709
+ * @template M - Type extending Model
1710
+ * @template V - Type extending IRepository<M>
1711
+ *
1712
+ * @this {V} - The repository instance
1713
+ * @param {Context<M>} context - The context of the operation
1714
+ * @param {unknown} data - Additional data for the operation (not used in this function)
1715
+ * @param {string} key - The key of the version property in the model
1716
+ * @param {M} model - The model being updated
1717
+ * @throws {InternalError} If an invalid operation is provided or if version update fails
1718
+ */
1719
+ function versionCreateUpdate(operation) {
1720
+ return function versionCreateUpdate(context, data, key, model) {
1721
+ try {
1722
+ switch (operation) {
1723
+ case exports.OperationKeys.CREATE:
1724
+ model[key] = 1;
1725
+ break;
1726
+ case exports.OperationKeys.UPDATE:
1727
+ model[key]++;
1728
+ break;
1729
+ default:
1730
+ throw new InternalError(`Invalid operation: ${operation}`);
1731
+ }
1732
+ }
1733
+ catch (e) {
1734
+ throw new InternalError(`Failed to update version: ${e}`);
1735
+ }
1736
+ };
1737
+ }
1738
+ /**
1739
+ * @description Creates a decorator for versioning a property in a model.
1740
+ * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations.
1741
+ *
1742
+ * @returns {Function} A composite decorator that:
1743
+ * - Sets the type of the property to Number
1744
+ * - Applies a version update on create operations
1745
+ * - Applies a version update on update operations
1746
+ * - Adds metadata indicating this property is used for versioning
1747
+ */
1748
+ function version() {
1749
+ return reflection.apply(decoratorValidation.type(Number.name), onCreate(versionCreateUpdate(exports.OperationKeys.CREATE)), onUpdate(versionCreateUpdate(exports.OperationKeys.UPDATE)), decoratorValidation.propMetadata(Repository.key(DBKeys.VERSION), true));
1750
+ }
1751
+
1752
+ decoratorValidation.Model.prototype.hasErrors = function (previousVersion, ...exclusions) {
1753
+ if (previousVersion && !(previousVersion instanceof decoratorValidation.Model)) {
1754
+ exclusions.unshift(previousVersion);
1755
+ previousVersion = undefined;
1756
+ }
1757
+ const errs = decoratorValidation.validate(this, ...exclusions);
1758
+ if (errs || !previousVersion)
1759
+ return errs;
1760
+ return validateCompare(previousVersion, this, ...exclusions);
1761
+ };
1762
+
1763
+ exports.BaseError = BaseError;
1764
+ exports.BaseRepository = BaseRepository;
1765
+ exports.ConflictError = ConflictError;
1766
+ exports.Context = Context;
1767
+ exports.DBKeys = DBKeys;
1768
+ exports.DBOperations = DBOperations;
1769
+ exports.DEFAULT_ERROR_MESSAGES = DEFAULT_ERROR_MESSAGES;
1770
+ exports.DEFAULT_TIMESTAMP_FORMAT = DEFAULT_TIMESTAMP_FORMAT;
1771
+ exports.DataCache = DataCache;
1772
+ exports.DefaultSeparator = DefaultSeparator;
1773
+ exports.InternalError = InternalError;
1774
+ exports.NotFoundError = NotFoundError;
1775
+ exports.Operations = Operations;
1776
+ exports.OperationsRegistry = OperationsRegistry;
1777
+ exports.Repository = Repository;
1778
+ exports.SerializationError = SerializationError;
1779
+ exports.UpdateValidationKeys = UpdateValidationKeys;
1780
+ exports.UpdateValidator = UpdateValidator;
1781
+ exports.ValidationError = ValidationError;
1782
+ exports.after = after;
1783
+ exports.afterAny = afterAny;
1784
+ exports.afterCreate = afterCreate;
1785
+ exports.afterCreateUpdate = afterCreateUpdate;
1786
+ exports.afterDelete = afterDelete;
1787
+ exports.afterRead = afterRead;
1788
+ exports.afterUpdate = afterUpdate;
1789
+ exports.composed = composed;
1790
+ exports.composedFromCreateUpdate = composedFromCreateUpdate;
1791
+ exports.composedFromKeys = composedFromKeys;
1792
+ exports.enforceDBDecorators = enforceDBDecorators;
1793
+ exports.findModelId = findModelId;
1794
+ exports.findPrimaryKey = findPrimaryKey;
1795
+ exports.getAllPropertyDecoratorsRecursive = getAllPropertyDecoratorsRecursive;
1796
+ exports.getDbDecorators = getDbDecorators;
1797
+ exports.getHandlerArgs = getHandlerArgs;
1798
+ exports.hash = hash;
1799
+ exports.hashOnCreateUpdate = hashOnCreateUpdate;
1800
+ exports.id = id;
1801
+ exports.on = on;
1802
+ exports.onAny = onAny;
1803
+ exports.onCreate = onCreate;
1804
+ exports.onCreateUpdate = onCreateUpdate;
1805
+ exports.onDelete = onDelete;
1806
+ exports.onRead = onRead;
1807
+ exports.onUpdate = onUpdate;
1808
+ exports.operation = operation;
1809
+ exports.prefixMethod = prefixMethod;
1810
+ exports.readonly = readonly;
1811
+ exports.serialize = serialize;
1812
+ exports.serializeAfterAll = serializeAfterAll;
1813
+ exports.serializeOnCreateUpdate = serializeOnCreateUpdate;
1814
+ exports.suffixMethod = suffixMethod;
1815
+ exports.timestamp = timestamp;
1816
+ exports.timestampHandler = timestampHandler;
1817
+ exports.validateCompare = validateCompare;
1818
+ exports.version = version;
1819
+ exports.versionCreateUpdate = versionCreateUpdate;
1820
+ exports.wrapMethodWithContext = wrapMethodWithContext;
1821
+
1822
+ }));
1823
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"db-decorators.cjs","sources":["../node_modules/tslib/tslib.es6.js","../src/model/constants.ts","../src/validation/constants.ts","../src/validation/validators/ReadOnlyValidator.ts","../src/validation/validators/TimestampValidator.ts","../src/validation/validators/UpdateValidator.ts","../src/operations/constants.ts","../src/operations/OperationsRegistry.ts","../src/operations/Operations.ts","../src/operations/decorators.ts","../src/repository/errors.ts","../src/repository/utils.ts","../src/repository/DataCache.ts","../src/repository/Context.ts","../src/repository/wrappers.ts","../src/identity/utils.ts","../src/repository/BaseRepository.ts","../src/repository/Repository.ts","../src/validation/decorators.ts","../src/validation/validation.ts","../src/identity/decorators.ts","../src/model/validation.ts","../src/model/decorators.ts","../src/model/model.ts"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n    function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n    var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n    var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n    var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n    var _, done = false;\r\n    for (var i = decorators.length - 1; i >= 0; i--) {\r\n        var context = {};\r\n        for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n        for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n        context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n        var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n        if (kind === \"accessor\") {\r\n            if (result === void 0) continue;\r\n            if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n            if (_ = accept(result.get)) descriptor.get = _;\r\n            if (_ = accept(result.set)) descriptor.set = _;\r\n            if (_ = accept(result.init)) initializers.unshift(_);\r\n        }\r\n        else if (_ = accept(result)) {\r\n            if (kind === \"field\") initializers.unshift(_);\r\n            else descriptor[key] = _;\r\n        }\r\n    }\r\n    if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n    done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n    var useValue = arguments.length > 2;\r\n    for (var i = 0; i < initializers.length; i++) {\r\n        value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n    }\r\n    return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n    return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n    if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n    return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n    return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    var desc = Object.getOwnPropertyDescriptor(m, k);\r\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n        desc = { enumerable: true, get: function() { return m[k]; } };\r\n    }\r\n    Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n    function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n    ownKeys = Object.getOwnPropertyNames || function (o) {\r\n        var ar = [];\r\n        for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n        return ar;\r\n    };\r\n    return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n    if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n    return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n    if (value !== null && value !== void 0) {\r\n        if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n        var dispose, inner;\r\n        if (async) {\r\n            if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n            dispose = value[Symbol.asyncDispose];\r\n        }\r\n        if (dispose === void 0) {\r\n            if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n            dispose = value[Symbol.dispose];\r\n            if (async) inner = dispose;\r\n        }\r\n        if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n        if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n        env.stack.push({ value: value, dispose: dispose, async: async });\r\n    }\r\n    else if (async) {\r\n        env.stack.push({ async: true });\r\n    }\r\n    return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n    var e = new Error(message);\r\n    return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n    function fail(e) {\r\n        env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n        env.hasError = true;\r\n    }\r\n    var r, s = 0;\r\n    function next() {\r\n        while (r = env.stack.pop()) {\r\n            try {\r\n                if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n                if (r.dispose) {\r\n                    var result = r.dispose.call(r.value);\r\n                    if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n                }\r\n                else s |= 1;\r\n            }\r\n            catch (e) {\r\n                fail(e);\r\n            }\r\n        }\r\n        if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n        if (env.hasError) throw env.error;\r\n    }\r\n    return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n    if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n        return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n            return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n        });\r\n    }\r\n    return path;\r\n}\r\n\r\nexport default {\r\n    __extends: __extends,\r\n    __assign: __assign,\r\n    __rest: __rest,\r\n    __decorate: __decorate,\r\n    __param: __param,\r\n    __esDecorate: __esDecorate,\r\n    __runInitializers: __runInitializers,\r\n    __propKey: __propKey,\r\n    __setFunctionName: __setFunctionName,\r\n    __metadata: __metadata,\r\n    __awaiter: __awaiter,\r\n    __generator: __generator,\r\n    __createBinding: __createBinding,\r\n    __exportStar: __exportStar,\r\n    __values: __values,\r\n    __read: __read,\r\n    __spread: __spread,\r\n    __spreadArrays: __spreadArrays,\r\n    __spreadArray: __spreadArray,\r\n    __await: __await,\r\n    __asyncGenerator: __asyncGenerator,\r\n    __asyncDelegator: __asyncDelegator,\r\n    __asyncValues: __asyncValues,\r\n    __makeTemplateObject: __makeTemplateObject,\r\n    __importStar: __importStar,\r\n    __importDefault: __importDefault,\r\n    __classPrivateFieldGet: __classPrivateFieldGet,\r\n    __classPrivateFieldSet: __classPrivateFieldSet,\r\n    __classPrivateFieldIn: __classPrivateFieldIn,\r\n    __addDisposableResource: __addDisposableResource,\r\n    __disposeResources: __disposeResources,\r\n    __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import { ModelKeys } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @summary Holds the Model reflection keys\n * @const DBKeys\n *\n * @memberOf module:db-decorators.Model\n */\nexport const DBKeys = {\n  REFLECT: `${ModelKeys.REFLECT}persistence.`,\n  REPOSITORY: \"repository\",\n  CLASS: \"_class\",\n  ID: \"id\",\n  INDEX: \"index\",\n  UNIQUE: \"unique\",\n  SERIALIZE: \"serialize\",\n  READONLY: \"readonly\",\n  TIMESTAMP: \"timestamp\",\n  HASH: \"hash\",\n  COMPOSED: \"composed\",\n  VERSION: \"version\",\n  ORIGINAL: \"__originalObj\",\n};\n\n/**\n * @summary The default separator when concatenating indexes\n *\n * @const DefaultIndexSeparator\n *\n * @category Managers\n * @subcategory Constants\n */\nexport const DefaultSeparator = \"_\";\n\n/**\n * @summary Holds the default timestamp date format\n * @constant DEFAULT_TIMESTAMP_FORMAT\n *\n * @memberOf module:db-decorators.Model\n */\nexport const DEFAULT_TIMESTAMP_FORMAT = \"dd/MM/yyyy HH:mm:ss:S\";\n","import { DBKeys } from \"../model/constants\";\n\n/**\n * @summary holds the default error messages\n * @const DEFAULT_ERROR_MESSAGES\n *\n * @memberOf module:db-decorators.Model\n */\nexport const DEFAULT_ERROR_MESSAGES = {\n  ID: {\n    INVALID: \"This Id is invalid\",\n    REQUIRED: \"The Id is mandatory\",\n  },\n  READONLY: {\n    INVALID: \"This cannot be updated\",\n  },\n  TIMESTAMP: {\n    REQUIRED: \"Timestamp is Mandatory\",\n    DATE: \"The Timestamp must the a valid date\",\n    INVALID: \"This value must always increase\",\n  },\n};\n\n/**\n * @summary Update reflection keys\n * @const UpdateValidationKeys\n * @memberOf module:db-decorators.Operations\n */\nexport const UpdateValidationKeys = {\n  REFLECT: \"db.update.validation.\",\n  TIMESTAMP: DBKeys.TIMESTAMP,\n  READONLY: DBKeys.READONLY,\n};\n","import { validator, Validator } from \"@decaf-ts/decorator-validation\";\nimport { DEFAULT_ERROR_MESSAGES, UpdateValidationKeys } from \"../constants\";\nimport { isEqual } from \"@decaf-ts/reflection\";\n\n/**\n * @summary Validator for the {@link readonly} decorator\n *\n * @class ReadOnlyValidator\n * @extends Validator\n *\n * @category Validators\n */\n@validator(UpdateValidationKeys.READONLY)\nexport class ReadOnlyValidator extends Validator {\n  constructor() {\n    super(DEFAULT_ERROR_MESSAGES.READONLY.INVALID);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  hasErrors(value: any, ...args: any[]): string | undefined {\n    return undefined;\n  }\n\n  /**\n   * @summary Validates a value has not changed\n   * @param {any} value\n   * @param {any} oldValue\n   * @param {string} [message] the error message override\n   */\n  public updateHasErrors(\n    value: any,\n    oldValue: any,\n    message?: string,\n  ): string | undefined {\n    if (value === undefined) return;\n\n    return isEqual(value, oldValue)\n      ? undefined\n      : this.getMessage(message || this.message);\n  }\n}\n","import { validator, Validator } from \"@decaf-ts/decorator-validation\";\nimport { DEFAULT_ERROR_MESSAGES, UpdateValidationKeys } from \"../constants\";\n\n/**\n * @summary Validates the update of a timestamp\n *\n * @class TimestampValidator\n * @extends Validator\n *\n * @category Validators\n */\n@validator(UpdateValidationKeys.TIMESTAMP)\nexport class TimestampValidator extends Validator {\n  constructor() {\n    super(DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  hasErrors(value: any, ...args: any[]): string | undefined {\n    return undefined;\n  }\n\n  public updateHasErrors(\n    value: Date | string | number,\n    oldValue: Date | string | number,\n    message?: string\n  ): string | undefined {\n    if (value === undefined) return;\n\n    message = message || this.getMessage(message || this.message);\n\n    try {\n      value = new Date(value);\n      oldValue = new Date(oldValue);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e) {\n      return message;\n    }\n\n    return value <= oldValue ? message : undefined;\n  }\n}\n","import {\n  DEFAULT_ERROR_MESSAGES as DecoratorMessages,\n  Validator,\n} from \"@decaf-ts/decorator-validation\";\n\n/**\n * @summary Base class for an Update validator\n *\n * @param {string} [message] error message. defaults to {@link DecoratorMessages#DEFAULT}\n * @param {string[]} [acceptedTypes] the accepted value types by the decorator\n *\n * @class UpdateValidator\n * @abstract\n * @extends Validator\n *\n * @category Validators\n */\nexport abstract class UpdateValidator extends Validator {\n  protected constructor(\n    message: string = DecoratorMessages.DEFAULT,\n    ...acceptedTypes: string[]\n  ) {\n    super(message, ...acceptedTypes);\n  }\n\n  /**\n   * @summary validates a value by comparing to its old version\n   * @param {any} value\n   * @param {any} oldValue\n   * @param {any[]} args\n   */\n  public abstract updateHasErrors(\n    value: any,\n    oldValue: any,\n    ...args: any[]\n  ): string | undefined;\n}\n","/**\n * @summary Set of constants to define db CRUD operations and their equivalent 'on' and 'after' phases\n * @const OperationKeys\n *\n * @memberOf module:db-decorators.Operations\n */\nexport enum OperationKeys {\n  REFLECT = \"decaf.model.db.operations.\",\n  CREATE = \"create\",\n  READ = \"read\",\n  UPDATE = \"update\",\n  DELETE = \"delete\",\n  ON = \"on.\",\n  AFTER = \"after.\",\n}\n\nexport type CrudOperations =\n  | OperationKeys.CREATE\n  | OperationKeys.READ\n  | OperationKeys.UPDATE\n  | OperationKeys.DELETE;\n\n/**\n * @summary Maps out groups of CRUD operations for easier mapping of decorators\n *\n * @constant DBOperations\n *\n * @memberOf module:db-decorators.Operations\n */\nexport const DBOperations: Record<string, CrudOperations[]> = {\n  CREATE: [OperationKeys.CREATE],\n  READ: [OperationKeys.READ],\n  UPDATE: [OperationKeys.UPDATE],\n  DELETE: [OperationKeys.DELETE],\n  CREATE_UPDATE: [OperationKeys.CREATE, OperationKeys.UPDATE],\n  READ_CREATE: [OperationKeys.READ, OperationKeys.CREATE],\n  ALL: [\n    OperationKeys.CREATE,\n    OperationKeys.READ,\n    OperationKeys.UPDATE,\n    OperationKeys.DELETE,\n  ],\n};\n","import { OperationHandler } from \"./types\";\nimport { OperationKeys } from \"./constants\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { Operations } from \"./Operations\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\n\n/**\n * @summary Holds the registered operation handlers\n *\n * @class OperationsRegistry\n * @implements IRegistry<OperationHandler<any>>\n *\n * @see OperationHandler\n *\n * @category Operations\n */\nexport class OperationsRegistry {\n  private readonly cache: Record<\n    string,\n    Record<\n      string | symbol,\n      Record<string, Record<string, OperationHandler<any, any, any>>>\n    >\n  > = {};\n\n  /**\n   * @summary retrieves an {@link OperationHandler} if it exists\n   * @param {string} target\n   * @param {string} propKey\n   * @param {string} operation\n   * @param accum\n   * @return {OperationHandler | undefined}\n   */\n  get<T extends Model, V extends IRepository<T>, Y>(\n    target: string | Record<string, any>,\n    propKey: string,\n    operation: string,\n    accum?: OperationHandler<T, V, Y>[]\n  ): OperationHandler<T, V, Y>[] | undefined {\n    accum = accum || [];\n    let name;\n    try {\n      name = typeof target === \"string\" ? target : target.constructor.name;\n      accum.unshift(\n        ...Object.values(this.cache[name][propKey][operation] || [])\n      );\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e) {\n      if (\n        typeof target === \"string\" ||\n        target === Object.prototype ||\n        Object.getPrototypeOf(target) === Object.prototype\n      )\n        return accum;\n    }\n\n    let proto = Object.getPrototypeOf(target);\n    if (proto.constructor.name === name) proto = Object.getPrototypeOf(proto);\n\n    return this.get<T, V, Y>(proto, propKey, operation, accum);\n  }\n\n  /**\n   * @summary Registers an {@link OperationHandler}\n   * @param {OperationHandler} handler\n   * @param {string} operation\n   * @param {{}} target\n   * @param {string | symbol} propKey\n   */\n  register<T extends Model, V extends IRepository<T>, Y>(\n    handler: OperationHandler<T, V, Y>,\n    operation: OperationKeys,\n    target: T,\n    propKey: string | symbol\n  ): void {\n    const name = target.constructor.name;\n    const handlerName = Operations.getHandlerName(handler);\n\n    if (!this.cache[name]) this.cache[name] = {};\n    if (!this.cache[name][propKey]) this.cache[name][propKey] = {};\n    if (!this.cache[name][propKey][operation])\n      this.cache[name][propKey][operation] = {};\n    if (this.cache[name][propKey][operation][handlerName]) return;\n    this.cache[name][propKey][operation][handlerName] = handler;\n  }\n}\n","import { Hashing, Model } from \"@decaf-ts/decorator-validation\";\nimport { OperationHandler } from \"./types\";\nimport { OperationsRegistry } from \"./OperationsRegistry\";\nimport { OperationKeys } from \"./constants\";\n\n/**\n * @summary Static class holding common Operation Functionality\n *\n * @class Operations\n *\n * @category Operations\n */\nexport class Operations {\n  private static registry: OperationsRegistry;\n\n  private constructor() {}\n\n  static getHandlerName(handler: OperationHandler<any, any, any>) {\n    if (handler.name) return handler.name;\n\n    console.warn(\n      \"Handler name not defined. A name will be generated, but this is not desirable. please avoid using anonymous functions\"\n    );\n    return Hashing.hash(handler.toString());\n  }\n\n  static key(str: string) {\n    return OperationKeys.REFLECT + str;\n  }\n\n  static get(\n    targetName: string | Record<string, any>,\n    propKey: string,\n    operation: string\n  ) {\n    return Operations.registry.get(targetName, propKey, operation);\n  }\n\n  private static getOpRegistry() {\n    if (!Operations.registry) Operations.registry = new OperationsRegistry();\n    return Operations.registry;\n  }\n\n  static register<V extends Model>(\n    handler: OperationHandler<V, any, any>,\n    operation: OperationKeys,\n    target: V,\n    propKey: string | symbol\n  ) {\n    Operations.getOpRegistry().register(\n      handler as any,\n      operation,\n      target,\n      propKey\n    );\n  }\n}\n","import {\n  IdOperationHandler,\n  OperationHandler,\n  StandardOperationHandler,\n  UpdateOperationHandler,\n} from \"./types\";\nimport { DBOperations, OperationKeys } from \"./constants\";\nimport { Operations } from \"./Operations\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { propMetadata } from \"@decaf-ts/decorator-validation\";\n\nfunction handle(\n  op: OperationKeys,\n  handler: OperationHandler<any, any, any, any>\n) {\n  return (target: any, propertyKey: string) => {\n    Operations.register(handler, op, target, propertyKey);\n  };\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE_UPDATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see on\n *\n * @function onCreateUpdate\n *\n * @category Decorators\n */\nexport function onCreateUpdate<T>(\n  handler:\n    | StandardOperationHandler<any, any, T, any>\n    | UpdateOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return on(DBOperations.CREATE_UPDATE, handler, data);\n}\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.UPDATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see on\n *\n * @function onUpdate\n *\n * @category Decorators\n */\nexport function onUpdate<T>(\n  handler: UpdateOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return on(DBOperations.UPDATE, handler, data);\n}\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.CREATE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onCreate\n *\n * @category Decorators\n */\nexport function onCreate<T>(\n  handler: StandardOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return on(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.READ}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onRead\n *\n * @category Decorators\n */\nexport function onRead<T>(\n  handler: IdOperationHandler<any, any, T, any>,\n  data: T\n) {\n  return on(DBOperations.READ, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onDelete\n *\n * @category Decorators\n */\nexport function onDelete<T>(\n  handler: OperationHandler<any, any, T, any>,\n  data: T\n) {\n  return on(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations.DELETE}\n *\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see on\n *\n * @function onAny\n *\n * @category Decorators\n */\nexport function onAny<T>(handler: OperationHandler<any, any, T, any>, data: T) {\n  return on(DBOperations.ALL, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations}\n *\n * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}\n * @param {OnOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * ex: handler(...args, ...props.map(p => target[p]))\n *\n * @function on\n *\n * @category Decorators\n */\nexport function on<T>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return operation(OperationKeys.ON, op, handler, data);\n}\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE_UPDATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterCreateUpdate\n *\n * @category Decorators\n */\nexport function afterCreateUpdate<T>(\n  handler:\n    | StandardOperationHandler<any, any, T, any>\n    | UpdateOperationHandler<any, any, T, any>,\n  data: T\n) {\n  return after(DBOperations.CREATE_UPDATE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.UPDATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterUpdate\n *\n * @category Decorators\n */\nexport function afterUpdate<T>(\n  handler: UpdateOperationHandler<any, any, T, any>,\n  data: T\n) {\n  return after(DBOperations.UPDATE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.CREATE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n *\n * @see after\n *\n * @function afterCreate\n *\n * @category Decorators\n */\nexport function afterCreate<T>(\n  handler: StandardOperationHandler<any, any, T, any>,\n  data: T\n) {\n  return after(DBOperations.CREATE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.READ}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterRead\n *\n * @category Decorators\n */\nexport function afterRead<T>(\n  handler: StandardOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return after(DBOperations.READ, handler, data);\n}\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterDelete\n *\n * @category Decorators\n */\nexport function afterDelete<T>(\n  handler: StandardOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return after(DBOperations.DELETE, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set after the defined {@link DBOperations.DELETE}\n *\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n * @param data\n * @param {any[]} [args] Arguments that will be passed in order to the handler method\n *\n * @see after\n *\n * @function afterAny\n *\n * @category Decorators\n */\nexport function afterAny<T>(\n  handler: StandardOperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return after(DBOperations.ALL, handler, data);\n}\n\n/**\n * @summary Defines a behaviour to set on the defined {@link DBOperations}\n *\n * @param {OperationKeys[] | DBOperations} op One of {@link DBOperations}\n * @param {AfterOperationHandler<any>} handler The method called upon the operation\n *\n * ex: handler(...args, ...props.map(p => target[p]))\n *\n * @param data\n * @param args\n * @function after\n *\n * @category Decorators\n */\nexport function after<T>(\n  op: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, T, any>,\n  data?: T\n) {\n  return operation(OperationKeys.AFTER, op, handler, data);\n}\n\nexport function operation<T>(\n  baseOp: OperationKeys.ON | OperationKeys.AFTER,\n  operation: OperationKeys[] = DBOperations.ALL,\n  handler: OperationHandler<any, any, T, any>,\n  dataToAdd?: T\n) {\n  return (target: object, propertyKey?: any) => {\n    const name = target.constructor.name;\n    const decorators = operation.reduce((accum: any[], op) => {\n      const compoundKey = baseOp + op;\n      let data = Reflect.getMetadata(\n        Operations.key(compoundKey),\n        target,\n        propertyKey\n      );\n      if (!data)\n        data = {\n          operation: op,\n          handlers: {},\n        };\n\n      const handlerKey = Operations.getHandlerName(handler);\n\n      if (\n        !data.handlers[name] ||\n        !data.handlers[name][propertyKey] ||\n        !(handlerKey in data.handlers[name][propertyKey])\n      ) {\n        data.handlers[name] = data.handlers[name] || {};\n        data.handlers[name][propertyKey] =\n          data.handlers[name][propertyKey] || {};\n        data.handlers[name][propertyKey][handlerKey] = {\n          data: dataToAdd,\n        };\n\n        accum.push(\n          handle(compoundKey as OperationKeys, handler),\n          propMetadata(Operations.key(compoundKey), data)\n        );\n      }\n      return accum;\n    }, []);\n    return apply(...decorators)(target, propertyKey);\n  };\n}\n","/**\n * @summary Base Error\n *\n * @param {string} msg the error message\n *\n * @class BaseDLTError\n * @extends Error\n */\nexport abstract class BaseError extends Error {\n  protected constructor(name: string, msg: string | Error) {\n    if (msg instanceof BaseError) return msg;\n    const message = `[${name}] ${msg instanceof Error ? msg.message : msg}`;\n    super(message);\n    if (msg instanceof Error) this.stack = msg.stack;\n  }\n}\n\n/**\n * @summary Represents a failure in the Model details\n *\n * @param {string} msg the error message\n *\n * @class ValidationError\n * @extends BaseError\n */\nexport class ValidationError extends BaseError {\n  constructor(msg: string | Error) {\n    super(ValidationError.name, msg);\n  }\n}\n/**\n * @summary Represents an internal failure (should mean an error in code)\n *\n * @param {string} msg the error message\n *\n * @class InternalError\n * @extends BaseError\n */\nexport class InternalError extends BaseError {\n  constructor(msg: string | Error) {\n    super(InternalError.name, msg);\n  }\n}\n/**\n * @summary Represents a failure in the Model de/serialization\n *\n * @param {string} msg the error message\n *\n * @class SerializationError\n * @extends BaseError\n *\n */\nexport class SerializationError extends BaseError {\n  constructor(msg: string | Error) {\n    super(SerializationError.name, msg);\n  }\n}\n\n/**\n * @summary Represents a failure in finding a model\n *\n * @param {string} msg the error message\n *\n * @class NotFoundError\n * @extends BaseError\n *\n */\nexport class NotFoundError extends BaseError {\n  constructor(msg: string | Error) {\n    super(NotFoundError.name, msg);\n  }\n}\n/**\n * @summary Represents a conflict in the storage\n *\n * @param {string} msg the error message\n *\n * @class ConflictError\n * @extends BaseError\n *\n */\nexport class ConflictError extends BaseError {\n  constructor(msg: string | Error) {\n    super(ConflictError.name, msg);\n  }\n}\n","import { Operations } from \"../operations/Operations\";\nimport { OperationHandler, UpdateOperationHandler } from \"../operations/types\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { DecoratorMetadata, Reflection } from \"@decaf-ts/reflection\";\nimport { InternalError } from \"./errors\";\nimport {\n  Constructor,\n  Model,\n  ModelKeys,\n  sf,\n} from \"@decaf-ts/decorator-validation\";\nimport { Context } from \"./Context\";\n\nexport type ContextArgs<M extends Model> = {\n  context: Context<M>;\n  args: any[];\n};\n\n/**\n * @summary retrieves the arguments for the handler\n * @param {any} dec the decorator\n * @param {string} prop the property name\n * @param {{}} m the model\n * @param {{}} [accum] accumulator used for internal recursiveness\n *\n * @function getHandlerArgs\n * @memberOf module:db-decorators.Repository\n */\nexport const getHandlerArgs = function (\n  dec: any,\n  prop: string,\n  m: Constructor<any>,\n  accum?: Record<string, { args: string[] }>\n): Record<string, { args: string[] }> | void {\n  const name = m.constructor.name;\n  if (!name) throw new InternalError(\"Could not determine model class\");\n  accum = accum || {};\n\n  if (dec.props.handlers[name] && dec.props.handlers[name][prop])\n    accum = { ...dec.props.handlers[name][prop], ...accum };\n\n  let proto = Object.getPrototypeOf(m);\n  if (proto === Object.prototype) return accum;\n  if (proto.constructor.name === name) proto = Object.getPrototypeOf(proto);\n\n  return getHandlerArgs(dec, prop, proto, accum);\n};\n\n/**\n *\n * @param {IRepository<T>} repo\n * @param context\n * @param {T} model\n * @param operation\n * @param prefix\n *\n * @param oldModel\n * @function enforceDBPropertyDecoratorsAsync\n *\n * @memberOf db-decorators.utils\n */\nexport async function enforceDBDecorators<\n  M extends Model,\n  Y extends IRepository<M>,\n  V,\n>(\n  repo: Y,\n  context: Context<M>,\n  model: M,\n  operation: string,\n  prefix: string,\n  oldModel?: M\n): Promise<void> {\n  const decorators: Record<string, DecoratorMetadata[]> | undefined =\n    getDbDecorators(model, operation, prefix);\n\n  if (!decorators) return;\n\n  for (const prop in decorators) {\n    const decs: DecoratorMetadata[] = decorators[prop];\n    for (const dec of decs) {\n      const { key } = dec;\n      const handlers: OperationHandler<M, Y, V>[] | undefined = Operations.get(\n        model,\n        prop,\n        prefix + key\n      );\n      if (!handlers || !handlers.length)\n        throw new InternalError(\n          `Could not find registered handler for the operation ${prefix + key} under property ${prop}`\n        );\n\n      const handlerArgs = getHandlerArgs(dec, prop, model as any);\n\n      if (!handlerArgs || Object.values(handlerArgs).length !== handlers.length)\n        throw new InternalError(sf(\"Args and handlers length do not match\"));\n\n      let handler: OperationHandler<any, any, any>;\n      let data: any;\n      for (let i = 0; i < handlers.length; i++) {\n        handler = handlers[i];\n        data = Object.values(handlerArgs)[i];\n\n        const args: any[] = [context, data.data, prop, model];\n\n        if (operation === OperationKeys.UPDATE && prefix === OperationKeys.ON) {\n          if (!oldModel)\n            throw new InternalError(\"Missing old model for update operation\");\n          args.push(oldModel);\n        }\n        await (handler as UpdateOperationHandler<M, Y, V>).apply(\n          repo,\n          args as [Context<M>, V, any, M, M]\n        );\n      }\n    }\n  }\n}\n\n/**\n * Specific for DB Decorators\n * @param {T} model\n * @param {string} operation CRUD {@link OperationKeys}\n * @param {string} [extraPrefix]\n *\n * @function getDbPropertyDecorators\n *\n * @memberOf db-decorators.utils\n */\nexport function getDbDecorators<T extends Model>(\n  model: T,\n  operation: string,\n  extraPrefix?: string\n): Record<string, DecoratorMetadata[]> | undefined {\n  const decorators: Record<string, DecoratorMetadata[]> | undefined =\n    Reflection.getAllPropertyDecorators(\n      model,\n      // undefined,\n      OperationKeys.REFLECT + (extraPrefix ? extraPrefix : \"\")\n    );\n  if (!decorators) return;\n  return Object.keys(decorators).reduce(\n    (accum: Record<string, DecoratorMetadata[]> | undefined, decorator) => {\n      const dec = decorators[decorator].filter((d) => d.key === operation);\n      if (dec && dec.length) {\n        if (!accum) accum = {};\n        accum[decorator] = dec;\n      }\n      return accum;\n    },\n    undefined\n  );\n}\n\n/**\n * @summary Retrieves the decorators for an object's properties prefixed by {@param prefixes} recursively\n * @param model\n * @param accum\n * @param prefixes\n *\n * @function getAllPropertyDecoratorsRecursive\n * @memberOf module:db-decorators.Repository\n */\nexport const getAllPropertyDecoratorsRecursive = function <T extends Model>(\n  model: T,\n  accum: { [indexer: string]: any[] } | undefined,\n  ...prefixes: string[]\n): { [indexer: string]: any[] } | undefined {\n  const accumulator = accum || {};\n  const mergeDecorators = function (decs: { [indexer: string]: any[] }) {\n    const pushOrSquash = (key: string, ...values: any[]) => {\n      values.forEach((val) => {\n        let match: any;\n        if (\n          !(match = accumulator[key].find((e) => e.key === val.key)) ||\n          match.props.operation !== val.props.operation\n        ) {\n          accumulator[key].push(val);\n          return;\n        }\n\n        if (val.key === ModelKeys.TYPE) return;\n\n        const { handlers, operation } = val.props;\n\n        if (\n          !operation ||\n          !operation.match(\n            new RegExp(\n              `^(:?${OperationKeys.ON}|${OperationKeys.AFTER})(:?${OperationKeys.CREATE}|${OperationKeys.READ}|${OperationKeys.UPDATE}|${OperationKeys.DELETE})$`\n            )\n          )\n        ) {\n          accumulator[key].push(val);\n          return;\n        }\n\n        const accumHandlers = match.props.handlers;\n\n        Object.entries(handlers).forEach(([clazz, handlerDef]) => {\n          if (!(clazz in accumHandlers)) {\n            accumHandlers[clazz] = handlerDef;\n            return;\n          }\n\n          Object.entries(handlerDef as object).forEach(\n            ([handlerProp, handler]) => {\n              if (!(handlerProp in accumHandlers[clazz])) {\n                accumHandlers[clazz][handlerProp] = handler;\n                return;\n              }\n\n              Object.entries(handler as object).forEach(\n                ([handlerKey, argsObj]) => {\n                  if (!(handlerKey in accumHandlers[clazz][handlerProp])) {\n                    accumHandlers[clazz][handlerProp][handlerKey] = argsObj;\n                    return;\n                  }\n                  console.warn(\n                    sf(\n                      \"Skipping handler registration for {0} under prop {0} because handler is the same\",\n                      clazz,\n                      handlerProp\n                    )\n                  );\n                }\n              );\n            }\n          );\n        });\n      });\n    };\n\n    Object.entries(decs).forEach(([key, value]) => {\n      accumulator[key] = accumulator[key] || [];\n      pushOrSquash(key, ...value);\n    });\n  };\n\n  const decs: { [indexer: string]: any[] } | undefined =\n    Reflection.getAllPropertyDecorators(model, ...prefixes);\n  if (decs) mergeDecorators(decs);\n\n  if (Object.getPrototypeOf(model) === Object.prototype) return accumulator;\n\n  // const name = model.constructor.name;\n  const proto = Object.getPrototypeOf(model);\n  if (!proto) return accumulator;\n  // if (proto.constructor && proto.constructor.name === name)\n  //     proto = Object.getPrototypeOf(proto)\n  return getAllPropertyDecoratorsRecursive(proto, accumulator, ...prefixes);\n};\n","import { ConflictError, NotFoundError } from \"./errors\";\n\nexport class DataCache {\n  protected cache: Record<string, any> = {};\n\n  async get(key: string) {\n    if (!(key in this.cache))\n      throw new NotFoundError(`Key ${key} not in dataStore`);\n    return this.cache[key];\n  }\n\n  async push(key: string, value: any) {\n    if (key in this.cache)\n      throw new ConflictError(`Key ${key} already in dataStore`);\n    this.cache[key] = value;\n  }\n\n  async put(key: string, value: any) {\n    this.cache[key] = value;\n  }\n\n  async pop(key: string) {\n    const res = this.get(key);\n    delete this.cache[key];\n    return res;\n  }\n\n  async filter(filter: string | RegExp) {\n    if (typeof filter === \"string\") filter = new RegExp(filter);\n    return Object.keys(this.cache)\n      .filter((k) => !!filter.exec(k))\n      .map((k) => this.cache[k]);\n  }\n\n  async purge(key?: string) {\n    if (!key) this.cache = {};\n    else await this.pop(key);\n  }\n}\n","import { DataCache } from \"./DataCache\";\nimport { ContextArgs } from \"./utils\";\nimport { Contextual } from \"../interfaces/Contextual\";\nimport { NotFoundError } from \"./errors\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\n\nexport class Context<M extends Model> extends DataCache {\n  protected constructor(\n    protected operation: OperationKeys,\n    protected model?: Constructor<M>,\n    protected parent?: Context<any>\n  ) {\n    super();\n  }\n\n  get timestamp() {\n    return new Date();\n  }\n\n  async get(key: string): Promise<any> {\n    try {\n      return super.get(key);\n    } catch (e: any) {\n      if (this.parent) return this.parent.get(key);\n      throw e;\n    }\n  }\n\n  async pop(key: string): Promise<any> {\n    if (key in this.cache) return super.pop(key);\n    if (!this.parent) throw new NotFoundError(`Key ${key} not in dataStore`);\n    return this.parent.pop(key);\n  }\n\n  child<N extends Model>(\n    operation: OperationKeys,\n    model?: Constructor<N>\n  ): Context<N> {\n    return this.constructor(operation, model, this);\n  }\n\n  static async from<M extends Model, C extends Context<M>>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<C> {\n    return new Context(operation, model) as C;\n  }\n\n  static async args<M extends Model>(\n    operation:\n      | OperationKeys.CREATE\n      | OperationKeys.READ\n      | OperationKeys.UPDATE\n      | OperationKeys.DELETE,\n    model: Constructor<M>,\n    args: any[],\n    contextual?: Contextual<M>\n  ): Promise<ContextArgs<M>> {\n    const last = args.pop();\n\n    async function getContext() {\n      if (contextual) return contextual.context(operation, model, ...args);\n      return new Context(operation, model);\n    }\n\n    let c: Context<M>;\n    if (last) {\n      if (last instanceof Context) {\n        c = last;\n        args.push(last);\n      } else {\n        c = await getContext();\n        args.push(last, c);\n      }\n    } else {\n      c = await getContext();\n      args.push(c);\n    }\n\n    return { context: c, args: args };\n  }\n}\n","import { Context } from \"./Context\";\nimport { InternalError } from \"./errors\";\n\n/**\n * @summary Util method to change a method of an object prefixing it with another\n * @param {any} obj The Base Object\n * @param {Function} after The original method\n * @param {Function} prefix The Prefix method. The output will be used as arguments in the original method\n * @param {string} [afterName] When the after function anme cannot be extracted, pass it here\n *\n * @function prefixMethod\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function prefixMethod(\n  obj: any,\n  after: (...args: any[]) => any,\n  prefix: (...args: any[]) => any,\n  afterName?: string\n) {\n  async function wrapper(this: any, ...args: any[]) {\n    const results = await Promise.resolve(prefix.call(this, ...args));\n    return Promise.resolve(after.apply(this, results));\n  }\n  const wrapped = wrapper.bind(obj);\n  const name = afterName ? afterName : after.name;\n  Object.defineProperty(wrapped, \"name\", {\n    enumerable: true,\n    configurable: true,\n    writable: false,\n    value: name,\n  });\n  obj[name] = wrapped;\n}\n\n/**\n * @summary Util method to change a method of an object suffixing it with another\n * @param {any} obj The Base Object\n * @param {Function} before The original method\n * @param {Function} suffix The Prefix method. The output will be used as arguments in the original method\n * @param {string} [beforeName] When the after function anme cannot be extracted, pass it here\n *\n * @function suffixMethod\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function suffixMethod(\n  obj: any,\n  before: (...args: any[]) => any,\n  suffix: (...args: any[]) => any,\n  beforeName?: string\n) {\n  async function wrapper(this: any, ...args: any[]) {\n    const results = await Promise.resolve(before.call(this, ...args));\n    return suffix.call(this, ...results);\n  }\n  const wrapped = wrapper.bind(obj);\n  const name = beforeName ? beforeName : before.name;\n  Object.defineProperty(wrapped, \"name\", {\n    enumerable: true,\n    configurable: true,\n    writable: false,\n    value: name,\n  });\n  obj[name] = wrapped;\n}\n\n/**\n * @summary Util method to wrap a method of an object with additional logic\n *\n * @param {any} obj The Base Object\n * @param {Function} before the method to be prefixed\n * @param {Function} method the method to be wrapped\n * @param {Function} after The method to be suffixed\n * @param {string} [methodName] When the after function anme cannot be extracted, pass it here\n *\n * @function wrapMethodWithContext\n *\n * @memberOf module:db-decorators.Repository\n */\nexport function wrapMethodWithContext(\n  obj: any,\n  before: (...args: any[]) => any,\n  method: (...args: any[]) => any,\n  after: (...args: any[]) => any,\n  methodName?: string\n) {\n  async function wrapper(this: any, ...args: any[]) {\n    let transformedArgs = before.call(obj, ...args);\n    if (transformedArgs instanceof Promise)\n      transformedArgs = await transformedArgs;\n    const context = transformedArgs[transformedArgs.length - 1] as any;\n    if (!(context instanceof Context))\n      throw new InternalError(\"Missing a context\");\n    let results = await method.call(obj, ...transformedArgs);\n    if (results instanceof Promise) results = await results;\n    results = after.call(this, results, context);\n    if (results instanceof Promise) results = await results;\n    return results;\n  }\n  const wrapped = wrapper.bind(obj);\n  const name = methodName ? methodName : method.name;\n  Object.defineProperty(wrapped, \"name\", {\n    enumerable: true,\n    configurable: true,\n    writable: false,\n    value: name,\n  });\n  obj[name] = wrapped;\n}\n","import { DBKeys } from \"../model/constants\";\nimport { getAllPropertyDecoratorsRecursive } from \"../repository/utils\";\nimport { Model, ModelKeys, sf } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"../repository/errors\";\n\n/**\n * @summary Returns the primary key attribute for a {@link Model}\n * @description searches in all the properties in the object for an {@link id} decorated property\n *\n * @param {Model} model\n *\n * @throws {InternalError} if no property or more than one properties are {@link id} decorated\n * or no value is set in that property\n *\n * @function findPrimaryKey\n *\n * @category managers\n */\nexport function findPrimaryKey<T extends Model>(model: T) {\n  const decorators = getAllPropertyDecoratorsRecursive(\n    model,\n    undefined,\n    DBKeys.REFLECT + DBKeys.ID\n  );\n  const idDecorators = Object.entries(decorators as object).reduce(\n    (accum: { [indexer: string]: any[] }, [prop, decs]) => {\n      const filtered = (decs as { key: string }[]).filter(\n        (d) => d.key !== ModelKeys.TYPE\n      );\n      if (filtered && filtered.length) {\n        accum[prop] = accum[prop] || [];\n        accum[prop].push(...filtered);\n      }\n      return accum;\n    },\n    {}\n  );\n\n  if (!idDecorators || !Object.keys(idDecorators).length)\n    throw new InternalError(\"Could not find ID decorated Property\");\n  if (Object.keys(idDecorators).length > 1)\n    throw new InternalError(sf(Object.keys(idDecorators).join(\", \")));\n  const idProp = Object.keys(idDecorators)[0];\n  if (!idProp) throw new InternalError(\"Could not find ID decorated Property\");\n  return {\n    id: idProp,\n    props: idDecorators[idProp][0].props,\n  };\n}\n\n/**\n * @summary Returns the primary key value for a {@link Model}\n * @description searches in all the properties in the object for an {@link pk} decorated property\n *\n * @param {Model} model\n * @param {boolean} [returnEmpty]\n * @return {string} primary key\n *\n * @throws {InternalError} if no property or more than one properties are {@link pk} decorated\n * @throws {NotFoundError} returnEmpty is false and no value is set on the {@link pk} decorated property\n *\n * @function findModelID\n *\n * @category managers\n */\nexport function findModelId(model: Model, returnEmpty = false) {\n  const idProp = findPrimaryKey(model).id;\n  const modelId = (model as any)[idProp];\n  if (!modelId && !returnEmpty)\n    throw new InternalError(\n      sf(\"No value for the Id is defined under the property {0}\", idProp)\n    );\n  return modelId;\n}\n","import { IRepository } from \"../interfaces/IRepository\";\nimport { Constructor, Model, sf } from \"@decaf-ts/decorator-validation\";\nimport { enforceDBDecorators } from \"./utils\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { InternalError } from \"./errors\";\nimport { wrapMethodWithContext } from \"./wrappers\";\nimport { findPrimaryKey } from \"../identity/utils\";\nimport { Context } from \"./Context\";\n\nexport abstract class BaseRepository<M extends Model>\n  implements IRepository<M>\n{\n  private readonly _class!: Constructor<M>;\n  private _pk!: string;\n\n  get class() {\n    if (!this._class)\n      throw new InternalError(`No class definition found for this repository`);\n    return this._class;\n  }\n\n  get pk() {\n    if (!this._pk) this._pk = findPrimaryKey(new this.class()).id;\n    return this._pk;\n  }\n\n  protected constructor(clazz?: Constructor<M>) {\n    if (clazz) this._class = clazz;\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this;\n    [this.create, this.read, this.update, this.delete].forEach((m) => {\n      const name = m.name;\n      wrapMethodWithContext(\n        self,\n        (self as any)[name + \"Prefix\"],\n        m,\n        (self as any)[name + \"Suffix\"]\n      );\n    });\n  }\n\n  abstract create(model: M, ...args: any[]): Promise<M>;\n\n  async createAll(models: M[], ...args: any[]): Promise<M[]> {\n    return Promise.all(models.map((m) => this.create(m, ...args)));\n  }\n\n  protected async createPrefix(model: M, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    model = new this.class(model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.ON\n    );\n    return [model, ...contextArgs.args];\n  }\n\n  protected async createSuffix(model: M, context: Context<M>) {\n    await enforceDBDecorators(\n      this,\n      context,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.AFTER\n    );\n    return model;\n  }\n\n  protected async createAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    return [models, ...contextArgs.args];\n  }\n\n  protected async createAllSuffix(models: M[], context: Context<M>) {\n    await Promise.all(\n      models.map((m) =>\n        enforceDBDecorators(\n          this,\n          context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.AFTER\n        )\n      )\n    );\n    return models;\n  }\n\n  abstract read(key: string | number, ...args: any[]): Promise<M>;\n\n  async readAll(keys: string[] | number[], ...args: any[]): Promise<M[]> {\n    return await Promise.all(keys.map((id) => this.read(id, ...args)));\n  }\n\n  protected async readSuffix(model: M, context: Context<M>) {\n    await enforceDBDecorators(\n      this,\n      context,\n      model,\n      OperationKeys.READ,\n      OperationKeys.AFTER\n    );\n    return model;\n  }\n\n  protected async readPrefix(key: string, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args\n    );\n    const model: M = new this.class();\n    (model as Record<string, any>)[this.pk] = key;\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.READ,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  protected async readAllPrefix(keys: string[] | number[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args\n    );\n    await Promise.all(\n      keys.map(async (k) => {\n        const m = new this.class();\n        (m as Record<string, any>)[this.pk] = k;\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.READ,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  protected async readAllSuffix(models: M[], context: Context<M>) {\n    await Promise.all(\n      models.map((m) =>\n        enforceDBDecorators(\n          this,\n          context,\n          m,\n          OperationKeys.READ,\n          OperationKeys.AFTER\n        )\n      )\n    );\n    return models;\n  }\n\n  abstract update(model: M, ...args: any[]): Promise<M>;\n\n  async updateAll(models: M[], ...args: any): Promise<M[]> {\n    return Promise.all(models.map((m) => this.update(m, ...args)));\n  }\n\n  protected async updateSuffix(model: M, context: Context<M>) {\n    await enforceDBDecorators(\n      this,\n      context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.AFTER\n    );\n    return model;\n  }\n\n  protected async updatePrefix(model: M, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const id = (model as any)[this.pk];\n    if (!id)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk}`\n      );\n    const oldModel = await this.read(id);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n    return [model, ...contextArgs.args];\n  }\n\n  protected async updateAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    await Promise.all(\n      models.map((m) => {\n        m = new this.class(m);\n        enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    return [models, ...contextArgs.args];\n  }\n\n  protected async updateAllSuffix(models: M[], context: Context<M>) {\n    await Promise.all(\n      models.map((m) =>\n        enforceDBDecorators(\n          this,\n          context,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.AFTER\n        )\n      )\n    );\n    return models;\n  }\n\n  abstract delete(key: string | number, ...args: any[]): Promise<M>;\n\n  async deleteAll(keys: string[] | number[], ...args: any[]): Promise<M[]> {\n    return Promise.all(keys.map((k) => this.delete(k, ...args)));\n  }\n\n  protected async deleteSuffix(model: M, context: Context<M>) {\n    await enforceDBDecorators(\n      this,\n      context,\n      model,\n      OperationKeys.DELETE,\n      OperationKeys.AFTER\n    );\n    return model;\n  }\n\n  protected async deletePrefix(key: any, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args\n    );\n    const model = await this.read(key, ...contextArgs.args);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.DELETE,\n      OperationKeys.ON\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  protected async deleteAllPrefix(keys: string[] | number[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args\n    );\n    const models = await this.readAll(keys, ...contextArgs.args);\n    await Promise.all(\n      models.map(async (m) => {\n        return enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.DELETE,\n          OperationKeys.ON\n        );\n      })\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  protected async deleteAllSuffix(models: M[], context: Context<M>) {\n    await Promise.all(\n      models.map((m) =>\n        enforceDBDecorators(\n          this,\n          context,\n          m,\n          OperationKeys.DELETE,\n          OperationKeys.AFTER\n        )\n      )\n    );\n    return models;\n  }\n\n  protected merge(oldModel: M, model: M): M {\n    const extract = (model: M) =>\n      Object.entries(model).reduce((accum: Record<string, any>, [key, val]) => {\n        if (typeof val !== \"undefined\") accum[key] = val;\n        return accum;\n      }, {});\n\n    return new this.class(Object.assign({}, extract(oldModel), extract(model)));\n  }\n\n  toString() {\n    return sf(\n      \"[{0}] - Repository for {1}\",\n      this.constructor.name,\n      this.class.name\n    );\n  }\n}\n","import { enforceDBDecorators } from \"./utils\";\nimport { OperationKeys } from \"../operations/constants\";\nimport { InternalError, ValidationError } from \"./errors\";\nimport { BaseRepository } from \"./BaseRepository\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { DBKeys } from \"../model/constants\";\nimport { Context } from \"./Context\";\n\nexport abstract class Repository<M extends Model> extends BaseRepository<M> {\n  protected constructor(clazz?: Constructor<M>) {\n    super(clazz);\n  }\n\n  protected override async createPrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    model = new this.class(model);\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.CREATE,\n      OperationKeys.ON\n    );\n\n    const errors = model.hasErrors();\n    if (errors) throw new ValidationError(errors.toString());\n\n    return [model, ...contextArgs.args];\n  }\n\n  protected async createAllPrefix(models: M[], ...args: any[]): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args\n    );\n    await Promise.all(\n      models.map(async (m) => {\n        m = new this.class(m);\n        await enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.CREATE,\n          OperationKeys.ON\n        );\n        return m;\n      })\n    );\n    const errors = models\n      .map((m) => m.hasErrors())\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  protected async updatePrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...args: any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const pk = (model as any)[this.pk];\n    if (!pk)\n      throw new InternalError(\n        `No value for the Id is defined under the property ${this.pk}`\n      );\n\n    const oldModel = await this.read(pk);\n\n    model = this.merge(oldModel, model);\n\n    await enforceDBDecorators(\n      this,\n      contextArgs.context,\n      model,\n      OperationKeys.UPDATE,\n      OperationKeys.ON,\n      oldModel\n    );\n\n    const errors = model.hasErrors(oldModel);\n    if (errors) throw new ValidationError(errors.toString());\n    return [model, ...contextArgs.args];\n  }\n\n  protected async updateAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args\n    );\n    const ids = models.map((m) => {\n      const id = (m as any)[this.pk];\n      if (!id)\n        throw new InternalError(\n          `No value for the Id is defined under the property ${this.pk}`\n        );\n      return id;\n    });\n    const oldModels = await this.readAll(ids, ...contextArgs.args);\n    models = models.map((m, i) => this.merge(oldModels[i], m));\n    await Promise.all(\n      models.map((m, i) =>\n        enforceDBDecorators(\n          this,\n          contextArgs.context,\n          m,\n          OperationKeys.UPDATE,\n          OperationKeys.ON,\n          oldModels[i]\n        )\n      )\n    );\n\n    const errors = models\n      .map((m, i) => m.hasErrors(oldModels[i], m))\n      .reduce((accum: string | undefined, e, i) => {\n        if (e)\n          accum =\n            typeof accum === \"string\"\n              ? accum + `\\n - ${i}: ${e.toString()}`\n              : ` - ${i}: ${e.toString()}`;\n        return accum;\n      }, undefined);\n    if (errors) throw new ValidationError(errors);\n    return [models, ...contextArgs.args];\n  }\n\n  static key(key: string) {\n    return DBKeys.REFLECT + key;\n  }\n}\n","import {\n  date,\n  Model,\n  propMetadata,\n  required,\n  sf,\n  type,\n  Validation,\n} from \"@decaf-ts/decorator-validation\";\nimport { DBKeys, DEFAULT_TIMESTAMP_FORMAT } from \"../model/constants\";\nimport { DEFAULT_ERROR_MESSAGES } from \"./constants\";\nimport { DBOperations, OperationKeys } from \"../operations/constants\";\nimport { after, on, onCreateUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { SerializationError } from \"../repository/errors\";\nimport { apply, metadata } from \"@decaf-ts/reflection\";\nimport { Repository } from \"../repository\";\nimport { Context } from \"../repository/Context\";\n\n/**\n * Marks the property as readonly.\n *\n * @param {string} [message] the error message. Defaults to {@link DEFAULT_ERROR_MESSAGES.READONLY.INVALID}\n *\n * @decorator readonly\n *\n * @category Decorators\n */\nexport function readonly(\n  message: string = DEFAULT_ERROR_MESSAGES.READONLY.INVALID\n) {\n  return propMetadata(Validation.updateKey(DBKeys.READONLY), {\n    message: message,\n  });\n}\n\nexport async function timestampHandler<\n  M extends Model,\n  V extends IRepository<M>,\n  Y = any,\n>(this: V, context: Context<M>, data: Y, key: string, model: M): Promise<void> {\n  (model as any)[key] = context.timestamp;\n}\n\n/**\n * Marks the property as timestamp.\n * Makes it {@link required}\n * Makes it a {@link date}\n *\n * Date Format:\n *\n * <pre>\n *      Using similar formatting as Moment.js, Class DateTimeFormatter (Java), and Class SimpleDateFormat (Java),\n *      I implemented a comprehensive solution formatDate(date, patternStr) where the code is easy to read and modify.\n *      You can display date, time, AM/PM, etc.\n *\n *      Date and Time Patterns\n *      yy = 2-digit year; yyyy = full year\n *      M = digit month; MM = 2-digit month; MMM = short month name; MMMM = full month name\n *      EEEE = full weekday name; EEE = short weekday name\n *      d = digit day; dd = 2-digit day\n *      h = hours am/pm; hh = 2-digit hours am/pm; H = hours; HH = 2-digit hours\n *      m = minutes; mm = 2-digit minutes; aaa = AM/PM\n *      s = seconds; ss = 2-digit seconds\n *      S = miliseconds\n * </pre>\n *\n * @param {string[]} operation The {@link DBOperations} to act on. Defaults to {@link DBOperations.CREATE_UPDATE}\n * @param {string} [format] The TimeStamp format. defaults to {@link DEFAULT_TIMESTAMP_FORMAT}\n * @param {{new: UpdateValidator}} [validator] defaults to {@link TimestampValidator}\n *\n * @decorator timestamp\n *\n * @category Decorators\n */\nexport function timestamp(\n  operation: OperationKeys[] = DBOperations.CREATE_UPDATE as unknown as OperationKeys[],\n  format: string = DEFAULT_TIMESTAMP_FORMAT\n) {\n  const decorators: any[] = [\n    date(format, DEFAULT_ERROR_MESSAGES.TIMESTAMP.DATE),\n    required(DEFAULT_ERROR_MESSAGES.TIMESTAMP.REQUIRED),\n    on(operation, timestampHandler),\n  ];\n\n  if (operation.indexOf(OperationKeys.UPDATE) !== -1)\n    decorators.push(\n      propMetadata(Validation.updateKey(DBKeys.TIMESTAMP), {\n        message: DEFAULT_ERROR_MESSAGES.TIMESTAMP.INVALID,\n      })\n    );\n\n  return apply(...decorators);\n}\n\nexport async function serializeOnCreateUpdate<\n  T extends Model,\n  V extends IRepository<T>,\n  Y = any,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n>(this: V, data: Y, key: string, model: T, oldModel: T): Promise<void> {\n  if (!(model as any)[key]) return;\n  try {\n    (model as any)[key] = JSON.stringify((model as any)[key]);\n  } catch (e: any) {\n    throw new SerializationError(\n      sf(\n        \"Failed to serialize {0} property on {1} model: {2}\",\n        key,\n        model.constructor.name,\n        e.message\n      )\n    );\n  }\n}\n\nexport async function serializeAfterAll<\n  T extends Model,\n  V extends IRepository<T>,\n  Y = any,\n>(this: V, data: Y, key: string, model: T): Promise<void> {\n  if (!(model as any)[key]) return;\n  if (typeof (model as any)[key] !== \"string\") return;\n\n  try {\n    (model as any)[key] = JSON.parse((model as any)[key]);\n  } catch (e: any) {\n    throw new SerializationError(\n      sf(\n        \"Failed to deserialize {0} property on {1} model: {2}\",\n        key,\n        model.constructor.name,\n        e.message\n      )\n    );\n  }\n}\n\n/**\n * @summary Serialize Decorator\n * @description properties decorated will the serialized before stored in the db\n *\n * @function serialize\n *\n * @memberOf module:wallet-db.Decorators\n */\nexport function serialize() {\n  return apply(\n    onCreateUpdate(serializeOnCreateUpdate),\n    after(DBOperations.ALL, serializeAfterAll),\n    type([String.name, Object.name]),\n    metadata(Repository.key(DBKeys.SERIALIZE), {})\n  );\n}\n\n//\n// /**\n//  * @summary One To One relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  * @param {boolean} _populate If true, replaces the specified key in the document with the corresponding record from the database\n//  *\n//  * @function onToOne\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToMany\n//  * @see manyToOne\n//  */\n// export function oneToOne(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n//   _populate: boolean = true,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     type([clazz.name, String.name])(target, propertyKey);\n//     onCreate(oneToOneOnCreate)(target, propertyKey);\n//     onUpdate(oneToOneOnUpdate, cascadeOptions as any)(target, propertyKey);\n//     onDelete(oneToOneOnDelete, cascadeOptions)(target, propertyKey);\n//\n//     afterCreate(populate, _populate)(target, propertyKey);\n//     afterUpdate(populate, _populate)(target, propertyKey);\n//     afterRead(populate, _populate)(target, propertyKey);\n//     afterDelete(populate, _populate)(target, propertyKey);\n//\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.ONE_TO_ONE),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//         populate: _populate,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n//\n// /**\n//  * @summary One To Many relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  *\n//  * @function onToMany\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToOne\n//  * @see manyToOne\n//  */\n// export function oneToMany(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n//   _populate: boolean = true,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     list([clazz, String])(target, propertyKey);\n//     onCreate(oneToManyOnCreate)(target, propertyKey);\n//     onUpdate(oneToManyOnUpdate, cascadeOptions)(target, propertyKey);\n//     onDelete(oneToManyOnDelete, cascadeOptions)(target, propertyKey);\n//\n//     afterCreate(populate, _populate)(target, propertyKey);\n//     afterUpdate(populate, _populate)(target, propertyKey);\n//     afterRead(populate, _populate)(target, propertyKey);\n//     afterDelete(populate, _populate)(target, propertyKey);\n//\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.ONE_TO_MANY),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n//\n// /**\n//  * @summary Many To One relation Decorators\n//  *\n//  * @param {Constructor<any>} clazz the {@link Sequence} to use. Defaults to {@link NoneSequence}\n//  * @param {CascadeMetadata} [cascadeOptions]\n//  *\n//  * @function manyToOne\n//  *\n//  * @memberOf module:wallet-db.Decorators\n//  *\n//  * @see oneToMany\n//  * @see oneToOne\n//  */\n// export function manyToOne(\n//   clazz: Constructor<any>,\n//   cascadeOptions: CascadeMetadata = DefaultCascade,\n// ) {\n//   Model.register(clazz);\n//   return (target: any, propertyKey: string) => {\n//     Reflect.defineMetadata(\n//       getDBKey(WalletDbKeys.MANY_TO_ONE),\n//       {\n//         constructor: clazz.name,\n//         cascade: cascadeOptions,\n//       },\n//       target,\n//       propertyKey,\n//     );\n//   };\n// }\n","import {\n  Validator,\n  Validation,\n  ValidatorDefinition,\n  IValidatorRegistry,\n} from \"@decaf-ts/decorator-validation\";\nimport { UpdateValidationKeys } from \"./constants\";\n\nValidation.updateKey = function (key: string) {\n  return UpdateValidationKeys.REFLECT + key;\n};\n\ndeclare module \"@decaf-ts/decorator-validation\" {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-expect-error\n  declare class Validation {\n    private static actingValidatorRegistry?;\n    private constructor();\n    /**\n     * @summary Defines the acting ValidatorRegistry\n     *\n     * @param {IValidatorRegistry} validatorRegistry the new implementation of the validator Registry\n     * @param {function(Validator): Validator} [migrationHandler] the method to map the validator if required;\n     */\n    static setRegistry(\n      validatorRegistry: IValidatorRegistry<Validator>,\n      migrationHandler?: (validator: Validator) => Validator\n    ): void;\n    /**\n     * @summary Returns the current ValidatorRegistry\n     *\n     * @return IValidatorRegistry, defaults to {@link ValidatorRegistry}\n     */\n    private static getRegistry;\n    /**\n     * @summary Retrieves a validator\n     *\n     * @param {string} validatorKey one of the {@link ValidationKeys}\n     * @return {Validator | undefined} the registered Validator or undefined if there is nono matching the provided key\n     */\n    static get<T extends Validator>(validatorKey: string): T | undefined;\n    /**\n     * @summary Registers the provided validators onto the registry\n     *\n     * @param {T[] | ValidatorDefinition[]} validator\n     */\n    static register<T extends Validator>(\n      ...validator: (ValidatorDefinition | T)[]\n    ): void;\n    /**\n     * @summary Builds the key to store as Metadata under Reflections\n     * @description concatenates {@link ValidationKeys#REFLECT} with the provided key\n     *\n     * @param {string} key\n     */\n    static key(key: string): string;\n\n    static updateKey(key: string): string;\n  }\n}\n","import { propMetadata, required } from \"@decaf-ts/decorator-validation\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport { readonly } from \"../validation\";\nimport { DBKeys } from \"../model/constants\";\nimport { Repository } from \"../repository\";\n// // eslint-disable-next-line @typescript-eslint/no-unused-vars\n// import * as Validation from \"../validation/validation\";\n\nexport function id() {\n  return apply(\n    required(),\n    readonly(),\n    propMetadata(Repository.key(DBKeys.ID), {})\n  );\n}\n","import {\n  Model,\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, Reflection } 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        Reflection.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((k) => {\n    if (exceptions.includes(k)) return false;\n    return !result || !result[k];\n  })) {\n    let err: string | undefined;\n    // if a nested Model\n    const allDecorators = Reflection.getPropertyDecorators(\n      ValidationKeys.REFLECT,\n      newModel,\n      prop\n    ).decorators;\n    const decorators = Reflection.getPropertyDecorators(\n      ValidationKeys.REFLECT,\n      newModel,\n      prop\n    ).decorators.filter(\n      (d) => [ModelKeys.TYPE, ValidationKeys.TYPE].indexOf(d.key as any) !== -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","import { DBKeys, DefaultSeparator } from \"./constants\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport {\n  Hashing,\n  Model,\n  propMetadata,\n  sf,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { onCreate, onCreateUpdate, onUpdate } from \"../operations/decorators\";\nimport { IRepository } from \"../interfaces/IRepository\";\nimport { InternalError } from \"../repository/errors\";\nimport { Repository } from \"../repository/Repository\";\nimport { Context } from \"../repository/Context\";\nimport { CrudOperations, OperationKeys } from \"../operations\";\n\n/**\n *\n * @param {str} str\n * @memberOf db-decorators.model\n */\n\nexport function hashOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M>,\n  Y = any,\n>(this: R, data: Y, key: string, model: M, oldModel?: M): void {\n  if (!(model as any)[key]) return;\n  const hash = Hashing.hash((model as any)[key]);\n  if (oldModel && (model as any)[key] === hash) return;\n  (model as any)[key] = hash;\n}\n\nexport function hash() {\n  return apply(\n    onCreateUpdate(hashOnCreateUpdate),\n    propMetadata(Repository.key(DBKeys.HASH), {})\n  );\n}\n\nexport type ComposedFromMetadata = {\n  args: string[];\n  separator: string;\n  hashResult: boolean;\n  type: \"keys\" | \"values\";\n  prefix?: string;\n  suffix?: string;\n};\n\nexport function composedFromCreateUpdate<\n  M extends Model,\n  V extends IRepository<M>,\n>(\n  this: V,\n  context: Context<M>,\n  data: ComposedFromMetadata,\n  key: string,\n  model: M\n) {\n  try {\n    const { args, type, prefix, suffix, separator } = data;\n    const composed = args.map((arg: string) => {\n      if (!(arg in model))\n        throw new InternalError(\n          sf(\"Property {0} not found to compose from\", arg)\n        );\n      if (type === \"keys\") return arg;\n      if (typeof (model as any)[arg] === \"undefined\")\n        throw new InternalError(\n          sf(\"Property {0} does not contain a value to compose from\", arg)\n        );\n      return ((model as any)[arg] as any).toString();\n    });\n\n    if (prefix) composed.unshift(prefix);\n    if (suffix) composed.push(suffix);\n\n    (model as any)[key] = composed.join(separator);\n  } catch (e: any) {\n    throw new InternalError(`Failed to compose value: ${e}`);\n  }\n}\n\nfunction composedFrom(\n  args: string[],\n  hashResult: boolean = false,\n  separator: string = DefaultSeparator,\n  type: \"keys\" | \"values\" = \"values\",\n  prefix = \"\",\n  suffix = \"\"\n) {\n  const data: ComposedFromMetadata = {\n    args: args,\n    hashResult: hashResult,\n    separator: separator,\n    type: type,\n    prefix: prefix,\n    suffix: suffix,\n  };\n\n  const decorators = [\n    onCreateUpdate(composedFromCreateUpdate, data),\n    propMetadata(Repository.key(DBKeys.COMPOSED), data),\n  ];\n  if (hashResult) decorators.push(hash());\n  return apply(...decorators);\n}\n\nexport function composedFromKeys(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\"\n) {\n  return composedFrom(args, hash, separator, \"keys\", prefix, suffix);\n}\n\nexport function composed(\n  args: string[],\n  separator: string = DefaultSeparator,\n  hash: boolean = false,\n  prefix = \"\",\n  suffix = \"\"\n) {\n  return composedFrom(args, hash, separator, \"values\", prefix, suffix);\n}\n\n/**\n * Creates a decorator function that updates the version of a model during create or update operations.\n *\n * @param {CrudOperations} operation - The type of operation being performed (CREATE or UPDATE).\n * @returns {function} A function that updates the version of the model based on the operation type.\n *\n * @template M - Type extending Model\n * @template V - Type extending IRepository<M>\n *\n * @this {V} - The repository instance\n * @param {Context<M>} context - The context of the operation\n * @param {unknown} data - Additional data for the operation (not used in this function)\n * @param {string} key - The key of the version property in the model\n * @param {M} model - The model being updated\n * @throws {InternalError} If an invalid operation is provided or if version update fails\n */\nexport function versionCreateUpdate(operation: CrudOperations) {\n  return function versionCreateUpdate<\n    M extends Model,\n    V extends IRepository<M>,\n  >(this: V, context: Context<M>, data: unknown, key: string, model: M) {\n    try {\n      switch (operation) {\n        case OperationKeys.CREATE:\n          (model as any)[key] = 1;\n          break;\n        case OperationKeys.UPDATE:\n          (model as any)[key]++;\n          break;\n        default:\n          throw new InternalError(`Invalid operation: ${operation}`);\n      }\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to update version: ${e}`);\n    }\n  };\n}\n\n/**\n * @description Creates a decorator for versioning a property in a model.\n * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations.\n *\n * @returns {Function} A composite decorator that:\n *   - Sets the type of the property to Number\n *   - Applies a version update on create operations\n *   - Applies a version update on update operations\n *   - Adds metadata indicating this property is used for versioning\n */\nexport function version() {\n  return apply(\n    type(Number.name),\n    onCreate(versionCreateUpdate(OperationKeys.CREATE)),\n    onUpdate(versionCreateUpdate(OperationKeys.UPDATE)),\n    propMetadata(Repository.key(DBKeys.VERSION), true)\n  );\n}\n","import {\n  Comparable,\n  Hashable,\n  ModelArg,\n  ModelErrorDefinition,\n  Serializable,\n  Validatable,\n  Model,\n  validate,\n  Constructor,\n  ModelBuilderFunction,\n  BuilderRegistry,\n  ModelConstructor,\n} from \"@decaf-ts/decorator-validation\";\nimport { validateCompare } from \"./validation\";\n\nModel.prototype.hasErrors = function <M extends Model>(\n  this: M,\n  previousVersion?: M | any,\n  ...exclusions: any[]\n): ModelErrorDefinition | undefined {\n  if (previousVersion && !(previousVersion instanceof Model)) {\n    exclusions.unshift(previousVersion);\n    previousVersion = undefined;\n  }\n\n  const errs = validate(this, ...exclusions);\n  if (errs || !previousVersion) return errs;\n\n  return validateCompare(previousVersion, this, ...exclusions);\n};\n\ndeclare module \"@decaf-ts/decorator-validation\" {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-expect-error\n  declare abstract class Model\n    implements Validatable, Serializable, Hashable, Comparable<Model>\n  {\n    protected constructor(arg?: ModelArg<Model>);\n\n    hasErrors(...exclusions: any[]): ModelErrorDefinition | undefined;\n    hasErrors(\n      previousVersion?: Model | any,\n      ...exclusions: any[]\n    ): ModelErrorDefinition | undefined;\n\n    /**\n     * @summary Compare object equality recursively\n     * @param {any} obj object to compare to\n     * @param {string} [exceptions] property names to be excluded from the comparison\n     */\n    equals(obj: any, ...exceptions: string[]): boolean;\n    /**\n     * @summary Returns the serialized model according to the currently defined {@link Serializer}\n     */\n    serialize(): string;\n    /**\n     * @summary Override the implementation for js's 'toString()' which sucks...\n     * @override\n     */\n    toString(): string;\n    /**\n     * @summary Defines a default implementation for object hash. Relies on a very basic implementation based on Java's string hash;\n     */\n    hash(): string;\n    /**\n     * @summary Deserializes a Model\n     * @param {string} str\n     *\n     * @param args\n     * @throws {Error} If it fails to parse the string, or if it fails to build the model\n     */\n    static deserialize(str: string): any;\n    /**\n     * @summary Repopulates the Object properties with the ones from the new object\n     * @description Iterates all common properties of obj (if existing) and self, and copies them onto self\n     *\n     * @param {T} self\n     * @param {T | Record<string, any>} [obj]\n     *\n     */\n    static fromObject<T extends Model>(\n      self: T,\n      obj?: T | Record<string, any>\n    ): T;\n    /**\n     * @summary Repopulates the instance with the ones from the new Model Object\n     * @description Iterates all common properties of obj (if existing) and self, and copies them onto self.\n     * Is aware of nested Model Objects and rebuilds them also.\n     * When List properties are decorated with {@link list}, they list items will also be rebuilt\n     *\n     * @param {T} self\n     * @param {T | Record<string, any>} [obj]\n     *\n     */\n    static fromModel<T extends Model>(\n      self: T,\n      obj?: T | Record<string, any>\n    ): T;\n    /**\n     * @summary Sets the Global {@link ModelBuilderFunction}\n     * @param {ModelBuilderFunction} [builder]\n     */\n    static setBuilder(builder?: ModelBuilderFunction): void;\n    /**\n     * @summary Retrieves the current global {@link ModelBuilderFunction}\n     */\n    static getBuilder(): ModelBuilderFunction | undefined;\n    /**\n     * Returns the current {@link ModelRegistryManager}\n     *\n     * @return ModelRegistry, defaults to {@link ModelRegistryManager}\n     */\n    private static getRegistry;\n    /**\n     * Returns the current actingModelRegistry\n     *\n     * @param {BuilderRegistry} modelRegistry the new implementation of Registry\n     */\n    static setRegistry(modelRegistry: BuilderRegistry<any>): void;\n    /**\n     * @summary register new Models\n     * @param {any} constructor\n     * @param {string} [name] when not defined, the name of the constructor will be used\n     *\n     * @see ModelRegistry\n     */\n    static register<T extends Model>(\n      constructor: ModelConstructor<T>,\n      name?: string\n    ): void;\n    /**\n     * @summary Gets a registered Model {@link ModelConstructor}\n     * @param {string} name\n     *\n     * @see ModelRegistry\n     */\n    static get<T extends Model>(name: string): ModelConstructor<T> | undefined;\n    /**\n     * @param {Record<string, any>} obj\n     * @param {string} [clazz] when provided, it will attempt to find the matching constructor\n     *\n     * @throws Error If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n     *\n     * @see ModelRegistry\n     */\n    static build<T extends Model>(obj?: Record<string, any>, clazz?: string): T;\n    static getMetadata<V extends Model>(model: V): any;\n    static getAttributes<V extends Model>(model: Constructor<V> | V): string[];\n    static equals<V extends Model>(\n      obj1: V,\n      obj2: V,\n      ...exceptions: any[]\n    ): boolean;\n    static hasErrors<V extends Model>(\n      model: V,\n      ...exceptions: any[]\n    ): ModelErrorDefinition | undefined;\n    static serialize<V extends Model>(model: V): any;\n    static hash<V extends Model>(model: V): any;\n    /**\n     * @summary Builds the key to store as Metadata under Reflections\n     * @description concatenates {@link ModelKeys#REFLECT} with the provided key\n     * @param {string} str\n     */\n    static key(str: string): string;\n  }\n}\n"],"names":["ModelKeys","ReadOnlyValidator","Validator","isEqual","validator","TimestampValidator","DecoratorMessages","OperationKeys","Hashing","propMetadata","apply","sf","Reflection","Validation","date","required","type","metadata","ValidationKeys","ReservedModels","ModelErrorDefinition","Model","validate"],"mappings":"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","x_google_ignoreList":[0]}