@decaf-ts/db-decorators 0.6.1 → 0.6.3

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 (141) hide show
  1. package/LICENSE.md +21 -157
  2. package/README.md +571 -10
  3. package/dist/db-decorators.cjs +1599 -426
  4. package/dist/db-decorators.esm.cjs +1597 -428
  5. package/lib/esm/identity/decorators.d.ts +7 -0
  6. package/lib/esm/identity/decorators.js +11 -4
  7. package/lib/esm/identity/index.js +3 -3
  8. package/lib/esm/identity/utils.d.ts +36 -23
  9. package/lib/esm/identity/utils.js +38 -25
  10. package/lib/esm/index.d.ts +12 -27
  11. package/lib/esm/index.js +13 -28
  12. package/lib/esm/interfaces/BulkCrudOperator.d.ts +39 -0
  13. package/lib/esm/interfaces/BulkCrudOperator.js +1 -1
  14. package/lib/esm/interfaces/Contextual.d.ts +17 -0
  15. package/lib/esm/interfaces/Contextual.js +1 -1
  16. package/lib/esm/interfaces/CrudOperator.d.ts +26 -23
  17. package/lib/esm/interfaces/CrudOperator.js +1 -1
  18. package/lib/esm/interfaces/IRepository.d.ts +10 -2
  19. package/lib/esm/interfaces/IRepository.js +1 -1
  20. package/lib/esm/interfaces/index.js +5 -5
  21. package/lib/esm/model/constants.d.ts +11 -13
  22. package/lib/esm/model/constants.js +12 -14
  23. package/lib/esm/model/decorators.d.ts +112 -23
  24. package/lib/esm/model/decorators.js +119 -29
  25. package/lib/esm/model/index.d.ts +1 -0
  26. package/lib/esm/model/index.js +7 -6
  27. package/lib/esm/model/model.d.ts +2 -141
  28. package/lib/esm/model/model.js +2 -13
  29. package/lib/esm/model/overrides.d.ts +1 -0
  30. package/lib/esm/model/overrides.js +34 -0
  31. package/lib/esm/model/utils.d.ts +39 -0
  32. package/lib/esm/model/utils.js +42 -3
  33. package/lib/esm/model/validation.d.ts +51 -8
  34. package/lib/esm/model/validation.js +246 -107
  35. package/lib/esm/operations/Operations.d.ts +65 -3
  36. package/lib/esm/operations/Operations.js +68 -6
  37. package/lib/esm/operations/OperationsRegistry.d.ts +44 -16
  38. package/lib/esm/operations/OperationsRegistry.js +46 -18
  39. package/lib/esm/operations/constants.d.ts +27 -8
  40. package/lib/esm/operations/constants.js +16 -9
  41. package/lib/esm/operations/decorators.d.ts +140 -134
  42. package/lib/esm/operations/decorators.js +152 -137
  43. package/lib/esm/operations/index.js +6 -6
  44. package/lib/esm/operations/types.d.ts +10 -0
  45. package/lib/esm/operations/types.js +1 -1
  46. package/lib/esm/repository/BaseRepository.d.ts +322 -0
  47. package/lib/esm/repository/BaseRepository.js +297 -7
  48. package/lib/esm/repository/Context.d.ts +153 -2
  49. package/lib/esm/repository/Context.js +154 -6
  50. package/lib/esm/repository/Repository.d.ts +89 -0
  51. package/lib/esm/repository/Repository.js +102 -15
  52. package/lib/esm/repository/constants.d.ts +7 -0
  53. package/lib/esm/repository/constants.js +8 -1
  54. package/lib/esm/repository/errors.d.ts +61 -34
  55. package/lib/esm/repository/errors.js +62 -35
  56. package/lib/esm/repository/index.js +9 -9
  57. package/lib/esm/repository/types.d.ts +25 -0
  58. package/lib/esm/repository/types.js +1 -1
  59. package/lib/esm/repository/utils.d.ts +11 -0
  60. package/lib/esm/repository/utils.js +4 -4
  61. package/lib/esm/repository/wrappers.d.ts +2 -2
  62. package/lib/esm/repository/wrappers.js +5 -5
  63. package/lib/esm/validation/constants.d.ts +20 -5
  64. package/lib/esm/validation/constants.js +22 -7
  65. package/lib/esm/validation/decorators.d.ts +101 -19
  66. package/lib/esm/validation/decorators.js +109 -27
  67. package/lib/esm/validation/index.js +5 -5
  68. package/lib/esm/validation/validation.js +10 -2
  69. package/lib/esm/validation/validators/ReadOnlyValidator.d.ts +32 -8
  70. package/lib/esm/validation/validators/ReadOnlyValidator.js +34 -10
  71. package/lib/esm/validation/validators/TimestampValidator.d.ts +37 -3
  72. package/lib/esm/validation/validators/TimestampValidator.js +39 -5
  73. package/lib/esm/validation/validators/UpdateValidator.d.ts +28 -11
  74. package/lib/esm/validation/validators/UpdateValidator.js +23 -8
  75. package/lib/esm/validation/validators/index.js +4 -4
  76. package/lib/identity/decorators.cjs +8 -1
  77. package/lib/identity/decorators.d.ts +7 -0
  78. package/lib/identity/utils.cjs +35 -22
  79. package/lib/identity/utils.d.ts +36 -23
  80. package/lib/index.cjs +14 -28
  81. package/lib/index.d.ts +12 -27
  82. package/lib/interfaces/BulkCrudOperator.cjs +1 -1
  83. package/lib/interfaces/BulkCrudOperator.d.ts +39 -0
  84. package/lib/interfaces/Contextual.cjs +1 -1
  85. package/lib/interfaces/Contextual.d.ts +17 -0
  86. package/lib/interfaces/CrudOperator.cjs +1 -1
  87. package/lib/interfaces/CrudOperator.d.ts +26 -23
  88. package/lib/interfaces/IRepository.cjs +1 -1
  89. package/lib/interfaces/IRepository.d.ts +10 -2
  90. package/lib/model/constants.cjs +12 -14
  91. package/lib/model/constants.d.ts +11 -13
  92. package/lib/model/decorators.cjs +114 -24
  93. package/lib/model/decorators.d.ts +112 -23
  94. package/lib/model/index.cjs +2 -1
  95. package/lib/model/index.d.ts +1 -0
  96. package/lib/model/model.cjs +1 -13
  97. package/lib/model/model.d.ts +2 -141
  98. package/lib/model/overrides.cjs +36 -0
  99. package/lib/model/overrides.d.ts +1 -0
  100. package/lib/model/utils.cjs +40 -1
  101. package/lib/model/utils.d.ts +39 -0
  102. package/lib/model/validation.cjs +246 -104
  103. package/lib/model/validation.d.ts +51 -8
  104. package/lib/operations/Operations.cjs +66 -4
  105. package/lib/operations/Operations.d.ts +65 -3
  106. package/lib/operations/OperationsRegistry.cjs +45 -17
  107. package/lib/operations/OperationsRegistry.d.ts +44 -16
  108. package/lib/operations/constants.cjs +16 -9
  109. package/lib/operations/constants.d.ts +27 -8
  110. package/lib/operations/decorators.cjs +150 -135
  111. package/lib/operations/decorators.d.ts +140 -134
  112. package/lib/operations/types.cjs +1 -1
  113. package/lib/operations/types.d.ts +10 -0
  114. package/lib/repository/BaseRepository.cjs +291 -1
  115. package/lib/repository/BaseRepository.d.ts +322 -0
  116. package/lib/repository/Context.cjs +153 -5
  117. package/lib/repository/Context.d.ts +153 -2
  118. package/lib/repository/Repository.cjs +96 -9
  119. package/lib/repository/Repository.d.ts +89 -0
  120. package/lib/repository/constants.cjs +8 -1
  121. package/lib/repository/constants.d.ts +7 -0
  122. package/lib/repository/errors.cjs +62 -35
  123. package/lib/repository/errors.d.ts +61 -34
  124. package/lib/repository/types.cjs +1 -1
  125. package/lib/repository/types.d.ts +25 -0
  126. package/lib/repository/utils.cjs +1 -1
  127. package/lib/repository/utils.d.ts +11 -0
  128. package/lib/repository/wrappers.cjs +3 -3
  129. package/lib/repository/wrappers.d.ts +2 -2
  130. package/lib/validation/constants.cjs +21 -6
  131. package/lib/validation/constants.d.ts +20 -5
  132. package/lib/validation/decorators.cjs +102 -20
  133. package/lib/validation/decorators.d.ts +101 -19
  134. package/lib/validation/validation.cjs +9 -1
  135. package/lib/validation/validators/ReadOnlyValidator.cjs +33 -9
  136. package/lib/validation/validators/ReadOnlyValidator.d.ts +32 -8
  137. package/lib/validation/validators/TimestampValidator.cjs +38 -4
  138. package/lib/validation/validators/TimestampValidator.d.ts +37 -3
  139. package/lib/validation/validators/UpdateValidator.cjs +23 -8
  140. package/lib/validation/validators/UpdateValidator.d.ts +28 -11
  141. package/package.json +2 -2
@@ -3,10 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DEFAULT_TIMESTAMP_FORMAT = exports.DefaultSeparator = exports.DBKeys = void 0;
4
4
  const decorator_validation_1 = require("@decaf-ts/decorator-validation");
5
5
  /**
6
- * @summary Holds the Model reflection keys
6
+ * @description Database reflection keys
7
+ * @summary Collection of keys used for reflection metadata in database operations
7
8
  * @const DBKeys
8
- *
9
- * @memberOf module:db-decorators.Model
9
+ * @memberOf module:db-decorators
10
10
  */
11
11
  exports.DBKeys = {
12
12
  REFLECT: `${decorator_validation_1.ModelKeys.REFLECT}persistence.`,
@@ -25,19 +25,17 @@ exports.DBKeys = {
25
25
  ORIGINAL: "__originalObj",
26
26
  };
27
27
  /**
28
- * @summary The default separator when concatenating indexes
29
- *
30
- * @const DefaultIndexSeparator
31
- *
32
- * @category Managers
33
- * @subcategory Constants
28
+ * @description Default separator character for composite indexes
29
+ * @summary The default separator character used when concatenating multiple fields into a single index
30
+ * @const DefaultSeparator
31
+ * @memberOf module:db-decorators
34
32
  */
35
33
  exports.DefaultSeparator = "_";
36
34
  /**
37
- * @summary Holds the default timestamp date format
38
- * @constant DEFAULT_TIMESTAMP_FORMAT
39
- *
40
- * @memberOf module:db-decorators.Model
35
+ * @description Default format for timestamp fields
36
+ * @summary Standard date format string used for timestamp fields in database models
37
+ * @const DEFAULT_TIMESTAMP_FORMAT
38
+ * @memberOf module:db-decorators
41
39
  */
42
40
  exports.DEFAULT_TIMESTAMP_FORMAT = "dd/MM/yyyy HH:mm:ss:S";
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vZGVsL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5RUFBMkQ7QUFFM0Q7Ozs7O0dBS0c7QUFDVSxRQUFBLE1BQU0sR0FBRztJQUNwQixPQUFPLEVBQUUsR0FBRyxnQ0FBUyxDQUFDLE9BQU8sY0FBYztJQUMzQyxVQUFVLEVBQUUsWUFBWTtJQUN4QixLQUFLLEVBQUUsUUFBUTtJQUNmLEVBQUUsRUFBRSxJQUFJO0lBQ1IsS0FBSyxFQUFFLE9BQU87SUFDZCxNQUFNLEVBQUUsUUFBUTtJQUNoQixTQUFTLEVBQUUsV0FBVztJQUN0QixRQUFRLEVBQUUsVUFBVTtJQUNwQixTQUFTLEVBQUUsV0FBVztJQUN0QixTQUFTLEVBQUUsV0FBVztJQUN0QixJQUFJLEVBQUUsTUFBTTtJQUNaLFFBQVEsRUFBRSxVQUFVO0lBQ3BCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLFFBQVEsRUFBRSxlQUFlO0NBQzFCLENBQUM7QUFFRjs7Ozs7OztHQU9HO0FBQ1UsUUFBQSxnQkFBZ0IsR0FBRyxHQUFHLENBQUM7QUFFcEM7Ozs7O0dBS0c7QUFDVSxRQUFBLHdCQUF3QixHQUFHLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWxLZXlzIH0gZnJvbSBcIkBkZWNhZi10cy9kZWNvcmF0b3ItdmFsaWRhdGlvblwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IEhvbGRzIHRoZSBNb2RlbCByZWZsZWN0aW9uIGtleXNcbiAqIEBjb25zdCBEQktleXNcbiAqXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnMuTW9kZWxcbiAqL1xuZXhwb3J0IGNvbnN0IERCS2V5cyA9IHtcbiAgUkVGTEVDVDogYCR7TW9kZWxLZXlzLlJFRkxFQ1R9cGVyc2lzdGVuY2UuYCxcbiAgUkVQT1NJVE9SWTogXCJyZXBvc2l0b3J5XCIsXG4gIENMQVNTOiBcIl9jbGFzc1wiLFxuICBJRDogXCJpZFwiLFxuICBJTkRFWDogXCJpbmRleFwiLFxuICBVTklRVUU6IFwidW5pcXVlXCIsXG4gIFNFUklBTElaRTogXCJzZXJpYWxpemVcIixcbiAgUkVBRE9OTFk6IFwicmVhZG9ubHlcIixcbiAgVElNRVNUQU1QOiBcInRpbWVzdGFtcFwiLFxuICBUUkFOU0lFTlQ6IFwidHJhbnNpZW50XCIsXG4gIEhBU0g6IFwiaGFzaFwiLFxuICBDT01QT1NFRDogXCJjb21wb3NlZFwiLFxuICBWRVJTSU9OOiBcInZlcnNpb25cIixcbiAgT1JJR0lOQUw6IFwiX19vcmlnaW5hbE9ialwiLFxufTtcblxuLyoqXG4gKiBAc3VtbWFyeSBUaGUgZGVmYXVsdCBzZXBhcmF0b3Igd2hlbiBjb25jYXRlbmF0aW5nIGluZGV4ZXNcbiAqXG4gKiBAY29uc3QgRGVmYXVsdEluZGV4U2VwYXJhdG9yXG4gKlxuICogQGNhdGVnb3J5IE1hbmFnZXJzXG4gKiBAc3ViY2F0ZWdvcnkgQ29uc3RhbnRzXG4gKi9cbmV4cG9ydCBjb25zdCBEZWZhdWx0U2VwYXJhdG9yID0gXCJfXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgSG9sZHMgdGhlIGRlZmF1bHQgdGltZXN0YW1wIGRhdGUgZm9ybWF0XG4gKiBAY29uc3RhbnQgREVGQVVMVF9USU1FU1RBTVBfRk9STUFUXG4gKlxuICogQG1lbWJlck9mIG1vZHVsZTpkYi1kZWNvcmF0b3JzLk1vZGVsXG4gKi9cbmV4cG9ydCBjb25zdCBERUZBVUxUX1RJTUVTVEFNUF9GT1JNQVQgPSBcImRkL01NL3l5eXkgSEg6bW06c3M6U1wiO1xuIl19
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21vZGVsL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5RUFBMkQ7QUFFM0Q7Ozs7O0dBS0c7QUFDVSxRQUFBLE1BQU0sR0FBRztJQUNwQixPQUFPLEVBQUUsR0FBRyxnQ0FBUyxDQUFDLE9BQU8sY0FBYztJQUMzQyxVQUFVLEVBQUUsWUFBWTtJQUN4QixLQUFLLEVBQUUsUUFBUTtJQUNmLEVBQUUsRUFBRSxJQUFJO0lBQ1IsS0FBSyxFQUFFLE9BQU87SUFDZCxNQUFNLEVBQUUsUUFBUTtJQUNoQixTQUFTLEVBQUUsV0FBVztJQUN0QixRQUFRLEVBQUUsVUFBVTtJQUNwQixTQUFTLEVBQUUsV0FBVztJQUN0QixTQUFTLEVBQUUsV0FBVztJQUN0QixJQUFJLEVBQUUsTUFBTTtJQUNaLFFBQVEsRUFBRSxVQUFVO0lBQ3BCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLFFBQVEsRUFBRSxlQUFlO0NBQzFCLENBQUM7QUFFRjs7Ozs7R0FLRztBQUNVLFFBQUEsZ0JBQWdCLEdBQUcsR0FBRyxDQUFDO0FBRXBDOzs7OztHQUtHO0FBQ1UsUUFBQSx3QkFBd0IsR0FBRyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGVsS2V5cyB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRGF0YWJhc2UgcmVmbGVjdGlvbiBrZXlzXG4gKiBAc3VtbWFyeSBDb2xsZWN0aW9uIG9mIGtleXMgdXNlZCBmb3IgcmVmbGVjdGlvbiBtZXRhZGF0YSBpbiBkYXRhYmFzZSBvcGVyYXRpb25zXG4gKiBAY29uc3QgREJLZXlzXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IERCS2V5cyA9IHtcbiAgUkVGTEVDVDogYCR7TW9kZWxLZXlzLlJFRkxFQ1R9cGVyc2lzdGVuY2UuYCxcbiAgUkVQT1NJVE9SWTogXCJyZXBvc2l0b3J5XCIsXG4gIENMQVNTOiBcIl9jbGFzc1wiLFxuICBJRDogXCJpZFwiLFxuICBJTkRFWDogXCJpbmRleFwiLFxuICBVTklRVUU6IFwidW5pcXVlXCIsXG4gIFNFUklBTElaRTogXCJzZXJpYWxpemVcIixcbiAgUkVBRE9OTFk6IFwicmVhZG9ubHlcIixcbiAgVElNRVNUQU1QOiBcInRpbWVzdGFtcFwiLFxuICBUUkFOU0lFTlQ6IFwidHJhbnNpZW50XCIsXG4gIEhBU0g6IFwiaGFzaFwiLFxuICBDT01QT1NFRDogXCJjb21wb3NlZFwiLFxuICBWRVJTSU9OOiBcInZlcnNpb25cIixcbiAgT1JJR0lOQUw6IFwiX19vcmlnaW5hbE9ialwiLFxufTtcblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gRGVmYXVsdCBzZXBhcmF0b3IgY2hhcmFjdGVyIGZvciBjb21wb3NpdGUgaW5kZXhlc1xuICogQHN1bW1hcnkgVGhlIGRlZmF1bHQgc2VwYXJhdG9yIGNoYXJhY3RlciB1c2VkIHdoZW4gY29uY2F0ZW5hdGluZyBtdWx0aXBsZSBmaWVsZHMgaW50byBhIHNpbmdsZSBpbmRleFxuICogQGNvbnN0IERlZmF1bHRTZXBhcmF0b3JcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGItZGVjb3JhdG9yc1xuICovXG5leHBvcnQgY29uc3QgRGVmYXVsdFNlcGFyYXRvciA9IFwiX1wiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBEZWZhdWx0IGZvcm1hdCBmb3IgdGltZXN0YW1wIGZpZWxkc1xuICogQHN1bW1hcnkgU3RhbmRhcmQgZGF0ZSBmb3JtYXQgc3RyaW5nIHVzZWQgZm9yIHRpbWVzdGFtcCBmaWVsZHMgaW4gZGF0YWJhc2UgbW9kZWxzXG4gKiBAY29uc3QgREVGQVVMVF9USU1FU1RBTVBfRk9STUFUXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRiLWRlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfVElNRVNUQU1QX0ZPUk1BVCA9IFwiZGQvTU0veXl5eSBISDptbTpzczpTXCI7XG4iXX0=
@@ -1,8 +1,8 @@
1
1
  /**
2
- * @summary Holds the Model reflection keys
2
+ * @description Database reflection keys
3
+ * @summary Collection of keys used for reflection metadata in database operations
3
4
  * @const DBKeys
4
- *
5
- * @memberOf module:db-decorators.Model
5
+ * @memberOf module:db-decorators
6
6
  */
7
7
  export declare const DBKeys: {
8
8
  REFLECT: string;
@@ -21,18 +21,16 @@ export declare const DBKeys: {
21
21
  ORIGINAL: string;
22
22
  };
23
23
  /**
24
- * @summary The default separator when concatenating indexes
25
- *
26
- * @const DefaultIndexSeparator
27
- *
28
- * @category Managers
29
- * @subcategory Constants
24
+ * @description Default separator character for composite indexes
25
+ * @summary The default separator character used when concatenating multiple fields into a single index
26
+ * @const DefaultSeparator
27
+ * @memberOf module:db-decorators
30
28
  */
31
29
  export declare const DefaultSeparator = "_";
32
30
  /**
33
- * @summary Holds the default timestamp date format
34
- * @constant DEFAULT_TIMESTAMP_FORMAT
35
- *
36
- * @memberOf module:db-decorators.Model
31
+ * @description Default format for timestamp fields
32
+ * @summary Standard date format string used for timestamp fields in database models
33
+ * @const DEFAULT_TIMESTAMP_FORMAT
34
+ * @memberOf module:db-decorators
37
35
  */
38
36
  export declare const DEFAULT_TIMESTAMP_FORMAT = "dd/MM/yyyy HH:mm:ss:S";
@@ -16,9 +16,21 @@ const errors_1 = require("./../repository/errors.cjs");
16
16
  const Repository_1 = require("./../repository/Repository.cjs");
17
17
  const operations_1 = require("./../operations/index.cjs");
18
18
  /**
19
- *
20
- * @param {str} str
21
- * @memberOf db-decorators.model
19
+ * @description Hashes a property value during create or update operations
20
+ * @summary Callback function used by the hash decorator to apply hashing to a property value
21
+ * @template M - Type extending Model
22
+ * @template R - Type extending IRepository
23
+ * @template V - Type for metadata
24
+ * @template F - Type extending RepositoryFlags
25
+ * @template C - Type extending Context
26
+ * @param {C} context - The operation context
27
+ * @param {V} data - Metadata for the operation
28
+ * @param key - The property key to hash
29
+ * @param {M} model - The model being processed
30
+ * @param {M} [oldModel] - The previous model state (for updates)
31
+ * @return {void}
32
+ * @function hashOnCreateUpdate
33
+ * @memberOf module:db-decorators
22
34
  */
23
35
  function hashOnCreateUpdate(context, data, key, model, oldModel) {
24
36
  if (typeof model[key] === "undefined")
@@ -28,9 +40,32 @@ function hashOnCreateUpdate(context, data, key, model, oldModel) {
28
40
  return;
29
41
  model[key] = hash;
30
42
  }
43
+ /**
44
+ * @description Creates a decorator that hashes a property value
45
+ * @summary Decorator that automatically hashes a property value during create and update operations
46
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
47
+ * @function hash
48
+ * @category Property Decorators
49
+ */
31
50
  function hash() {
32
51
  return (0, reflection_1.apply)((0, decorators_1.onCreateUpdate)(hashOnCreateUpdate), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.DBKeys.HASH), {}));
33
52
  }
53
+ /**
54
+ * @description Composes a property value from other properties during create or update operations
55
+ * @summary Callback function used by composed decorators to generate a property value from other properties
56
+ * @template M - Type extending Model
57
+ * @template R - Type extending IRepository
58
+ * @template V - Type extending ComposedFromMetadata
59
+ * @template F - Type extending RepositoryFlags
60
+ * @template C - Type extending Context
61
+ * @param {C} context - The operation context
62
+ * @param {V} data - Metadata for the composition
63
+ * @param key - The property key to set the composed value on
64
+ * @param {M} model - The model being processed
65
+ * @return {void}
66
+ * @function composedFromCreateUpdate
67
+ * @memberOf module:db-decorators
68
+ */
34
69
  function composedFromCreateUpdate(context, data, key, model) {
35
70
  try {
36
71
  const { args, type, prefix, suffix, separator } = data;
@@ -53,6 +88,19 @@ function composedFromCreateUpdate(context, data, key, model) {
53
88
  throw new errors_1.InternalError(`Failed to compose value: ${e}`);
54
89
  }
55
90
  }
91
+ /**
92
+ * @description Creates a decorator that composes a property value from other properties
93
+ * @summary Base function for creating property composition decorators
94
+ * @param {string[]} args - Property names to compose from
95
+ * @param {boolean} [hashResult=false] - Whether to hash the composed result
96
+ * @param {string} [separator=DefaultSeparator] - Character used to join the composed values
97
+ * @param {"keys"|"values"} [type="values"] - Whether to use property keys or values
98
+ * @param {string} [prefix=""] - Optional prefix to add to the composed value
99
+ * @param {string} [suffix=""] - Optional suffix to add to the composed value
100
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
101
+ * @function composedFrom
102
+ * @category PropertyDecorators
103
+ */
56
104
  function composedFrom(args, hashResult = false, separator = constants_1.DefaultSeparator, type = "values", prefix = "", suffix = "") {
57
105
  const data = {
58
106
  args: args,
@@ -70,27 +118,65 @@ function composedFrom(args, hashResult = false, separator = constants_1.DefaultS
70
118
  decorators.push(hash());
71
119
  return (0, reflection_1.apply)(...decorators);
72
120
  }
121
+ /**
122
+ * @description Creates a decorator that composes a property value from property keys
123
+ * @summary Decorator that generates a property value by joining the names of other properties
124
+ * @param {string[]} args - Property names to compose from
125
+ * @param {string} [separator=DefaultSeparator] - Character used to join the property names
126
+ * @param {boolean} [hash=false] - Whether to hash the composed result
127
+ * @param {string} [prefix=""] - Optional prefix to add to the composed value
128
+ * @param {string} [suffix=""] - Optional suffix to add to the composed value
129
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
130
+ * @function composedFromKeys
131
+ * @category PropertyDecorators
132
+ */
73
133
  function composedFromKeys(args, separator = constants_1.DefaultSeparator, hash = false, prefix = "", suffix = "") {
74
134
  return composedFrom(args, hash, separator, "keys", prefix, suffix);
75
135
  }
136
+ /**
137
+ * @description Creates a decorator that composes a property value from property values
138
+ * @summary Decorator that generates a property value by joining the values of other properties
139
+ * @param {string[]} args - Property names whose values will be composed
140
+ * @param {string} [separator=DefaultSeparator] - Character used to join the property values
141
+ * @param {boolean} [hash=false] - Whether to hash the composed result
142
+ * @param {string} [prefix=""] - Optional prefix to add to the composed value
143
+ * @param {string} [suffix=""] - Optional suffix to add to the composed value
144
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
145
+ * @function composed
146
+ * @category PropertyDecorators
147
+ */
76
148
  function composed(args, separator = constants_1.DefaultSeparator, hash = false, prefix = "", suffix = "") {
77
149
  return composedFrom(args, hash, separator, "values", prefix, suffix);
78
150
  }
79
151
  /**
80
- * Creates a decorator function that updates the version of a model during create or update operations.
81
- *
82
- * @param {CrudOperations} operation - The type of operation being performed (CREATE or UPDATE).
83
- * @returns {function} A function that updates the version of the model based on the operation type.
84
- *
152
+ * @description Creates a function that updates a version property during operations
153
+ * @summary Factory function that generates a callback for incrementing version numbers
154
+ * @param {CrudOperations} operation - The type of operation (CREATE or UPDATE)
155
+ * @return {Function} A callback function that updates the version property
85
156
  * @template M - Type extending Model
86
- * @template V - Type extending IRepository<M>
157
+ * @template R - Type extending IRepository
158
+ * @template V - Type for metadata
159
+ * @template F - Type extending RepositoryFlags
160
+ * @template C - Type extending Context
161
+ * @function versionCreateUpdate
162
+ * @memberOf module:db-decorators
163
+ * @mermaid
164
+ * sequenceDiagram
165
+ * participant Caller
166
+ * participant versionCreateUpdate
87
167
  *
88
- * @this {V} - The repository instance
89
- * @param {Context<M>} context - The context of the operation
90
- * @param {unknown} data - Additional data for the operation (not used in this function)
91
- * @param {string} key - The key of the version property in the model
92
- * @param {M} model - The model being updated
93
- * @throws {InternalError} If an invalid operation is provided or if version update fails
168
+ * Caller->>versionCreateUpdate: operation
169
+ * versionCreateUpdate-->>Caller: callback function
170
+ * Note over Caller,versionCreateUpdate: When callback is executed:
171
+ * Caller->>versionCreateUpdate: context, data, key, model
172
+ * alt operation is CREATE
173
+ * versionCreateUpdate->>versionCreateUpdate: set version to 1
174
+ * else operation is UPDATE
175
+ * versionCreateUpdate->>versionCreateUpdate: increment version
176
+ * else invalid operation
177
+ * versionCreateUpdate->>versionCreateUpdate: throw error
178
+ * end
179
+ * versionCreateUpdate-->>Caller: void
94
180
  */
95
181
  function versionCreateUpdate(operation) {
96
182
  return function versionCreateUpdate(context, data, key, model) {
@@ -112,22 +198,26 @@ function versionCreateUpdate(operation) {
112
198
  };
113
199
  }
114
200
  /**
115
- * @description Creates a decorator for versioning a property in a model.
116
- * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations.
117
- *
118
- * @returns {Function} A composite decorator that:
119
- * - Sets the type of the property to Number
120
- * - Applies a version update on create operations
121
- * - Applies a version update on update operations
122
- * - Adds metadata indicating this property is used for versioning
201
+ * @description Creates a decorator for versioning a property in a model
202
+ * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations
203
+ * @return {PropertyDecorator} A composite decorator that sets the type to Number, manages version updates, and adds versioning metadata
204
+ * @function version
205
+ * @category PropertyDecorators
123
206
  */
124
207
  function version() {
125
208
  return (0, reflection_1.apply)((0, decorator_validation_1.type)(Number.name), (0, decorators_1.onCreate)(versionCreateUpdate(operations_1.OperationKeys.CREATE)), (0, decorators_1.onUpdate)(versionCreateUpdate(operations_1.OperationKeys.UPDATE)), (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.DBKeys.VERSION), true));
126
209
  }
210
+ /**
211
+ * @description Creates a decorator that marks a property as transient
212
+ * @summary Decorator that indicates a property should not be persisted to the database
213
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
214
+ * @function transient
215
+ * @category PropertyDecorators
216
+ */
127
217
  function transient() {
128
218
  return function transient(model, attribute) {
129
219
  (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.DBKeys.TRANSIENT), true)(model, attribute);
130
220
  (0, decorator_validation_1.propMetadata)(Repository_1.Repository.key(constants_1.DBKeys.TRANSIENT), true)(model.constructor);
131
221
  };
132
222
  }
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":"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","sourcesContent":["import { DBKeys, DefaultSeparator } from \"./constants\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport {\n  Hashing,\n  Model,\n  propMetadata,\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\";\nimport { RepositoryFlags } from \"../repository/types\";\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, F, C>,\n  V extends object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M, oldModel?: M): void {\n  if (typeof model[key] === \"undefined\") return;\n  const hash = Hashing.hash((model as any)[key]);\n  if (oldModel && (model as any)[key] === hash) return;\n  model[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  R extends IRepository<M, F, C>,\n  V extends ComposedFromMetadata,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M) {\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(`Property ${arg} not found to compose from`);\n      if (type === \"keys\") return arg;\n      if (typeof (model as any)[arg] === \"undefined\")\n        throw new InternalError(\n          `Property ${args} does not contain a value to compose from`\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    R extends IRepository<M, F, C>,\n    V extends object,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >(this: R, context: C, data: V, key: keyof M, 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\nexport function transient() {\n  return function transient(model: any, attribute: string) {\n    propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model, attribute);\n    propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model.constructor);\n  };\n}\n"]}
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/model/decorators.ts"],"names":[],"mappings":";;AAiCA,gDAWC;AASD,oBAKC;AAuCD,4DA2BC;AAoDD,4CAQC;AAcD,4BAQC;AAgCD,kDAuBC;AASD,0BAOC;AASD,8BAKC;AAnSD,+CAAuD;AACvD,qDAA6C;AAC7C,yEAKwC;AACxC,+DAA8E;AAE9E,uDAAqD;AACrD,+DAAsD;AAEtD,0DAA8D;AAG9D;;;;;;;;;;;;;;;;GAgBG;AACH,SAAgB,kBAAkB,CAMvB,OAAU,EAAE,IAAO,EAAE,GAAY,EAAE,KAAQ,EAAE,QAAY;IAClE,IAAI,OAAO,KAAK,CAAC,GAAG,CAAC,KAAK,WAAW;QAAE,OAAO;IAC9C,MAAM,IAAI,GAAG,8BAAO,CAAC,IAAI,CAAE,KAAa,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/C,IAAI,QAAQ,IAAK,KAAa,CAAC,GAAG,CAAC,KAAK,IAAI;QAAE,OAAO;IACrD,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;AACpB,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,IAAI;IAClB,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAc,EAAC,kBAAkB,CAAC,EAClC,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,kBAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAC9C,CAAC;AACJ,CAAC;AAuBD;;;;;;;;;;;;;;;GAeG;AACH,SAAgB,wBAAwB,CAM7B,OAAU,EAAE,IAAO,EAAE,GAAY,EAAE,KAAQ;IACpD,IAAI,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAW,EAAE,EAAE;YACxC,IAAI,CAAC,CAAC,GAAG,IAAI,KAAK,CAAC;gBACjB,MAAM,IAAI,sBAAa,CAAC,YAAY,GAAG,4BAA4B,CAAC,CAAC;YACvE,IAAI,IAAI,KAAK,MAAM;gBAAE,OAAO,GAAG,CAAC;YAChC,IAAI,OAAQ,KAAa,CAAC,GAAG,CAAC,KAAK,WAAW;gBAC5C,MAAM,IAAI,sBAAa,CACrB,YAAY,IAAI,2CAA2C,CAC5D,CAAC;YACJ,OAAS,KAAa,CAAC,GAAG,CAAS,CAAC,QAAQ,EAAE,CAAC;QACjD,CAAC,CAAC,CAAC;QAEH,IAAI,MAAM;YAAE,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,MAAM;YAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEjC,KAAa,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjD,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,MAAM,IAAI,sBAAa,CAAC,4BAA4B,CAAC,EAAE,CAAC,CAAC;IAC3D,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,SAAS,YAAY,CACnB,IAAc,EACd,aAAsB,KAAK,EAC3B,YAAoB,4BAAgB,EACpC,OAA0B,QAAQ,EAClC,MAAM,GAAG,EAAE,EACX,MAAM,GAAG,EAAE;IAEX,MAAM,IAAI,GAAyB;QACjC,IAAI,EAAE,IAAI;QACV,UAAU,EAAE,UAAU;QACtB,SAAS,EAAE,SAAS;QACpB,IAAI,EAAE,IAAI;QACV,MAAM,EAAE,MAAM;QACd,MAAM,EAAE,MAAM;KACf,CAAC;IAEF,MAAM,UAAU,GAAG;QACjB,IAAA,2BAAc,EAAC,wBAAwB,EAAE,IAAI,CAAC;QAC9C,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,kBAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC;KACpD,CAAC;IACF,IAAI,UAAU;QAAE,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IACxC,OAAO,IAAA,kBAAK,EAAC,GAAG,UAAU,CAAC,CAAC;AAC9B,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,gBAAgB,CAC9B,IAAc,EACd,YAAoB,4BAAgB,EACpC,OAAgB,KAAK,EACrB,MAAM,GAAG,EAAE,EACX,MAAM,GAAG,EAAE;IAEX,OAAO,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AACrE,CAAC;AAED;;;;;;;;;;;GAWG;AACH,SAAgB,QAAQ,CACtB,IAAc,EACd,YAAoB,4BAAgB,EACpC,OAAgB,KAAK,EACrB,MAAM,GAAG,EAAE,EACX,MAAM,GAAG,EAAE;IAEX,OAAO,YAAY,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AACvE,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,SAAgB,mBAAmB,CAAC,SAAyB;IAC3D,OAAO,SAAS,mBAAmB,CAMxB,OAAU,EAAE,IAAO,EAAE,GAAY,EAAE,KAAQ;QACpD,IAAI,CAAC;YACH,QAAQ,SAAS,EAAE,CAAC;gBAClB,KAAK,0BAAa,CAAC,MAAM;oBACtB,KAAa,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;oBACxB,MAAM;gBACR,KAAK,0BAAa,CAAC,MAAM;oBACtB,KAAa,CAAC,GAAG,CAAC,EAAE,CAAC;oBACtB,MAAM;gBACR;oBACE,MAAM,IAAI,sBAAa,CAAC,sBAAsB,SAAS,EAAE,CAAC,CAAC;YAC/D,CAAC;QACH,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,sBAAa,CAAC,6BAA6B,CAAC,EAAE,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,OAAO;IACrB,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAI,EAAC,MAAM,CAAC,IAAI,CAAC,EACjB,IAAA,qBAAQ,EAAC,mBAAmB,CAAC,0BAAa,CAAC,MAAM,CAAC,CAAC,EACnD,IAAA,qBAAQ,EAAC,mBAAmB,CAAC,0BAAa,CAAC,MAAM,CAAC,CAAC,EACnD,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,kBAAM,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,CACnD,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,SAAS;IACvB,OAAO,SAAS,SAAS,CAAC,KAAU,EAAE,SAAiB;QACrD,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,kBAAM,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACvE,IAAA,mCAAY,EAAC,uBAAU,CAAC,GAAG,CAAC,kBAAM,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IAC1E,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import { DBKeys, DefaultSeparator } from \"./constants\";\nimport { apply } from \"@decaf-ts/reflection\";\nimport {\n  Hashing,\n  Model,\n  propMetadata,\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\";\nimport { RepositoryFlags } from \"../repository/types\";\n\n/**\n * @description Hashes a property value during create or update operations\n * @summary Callback function used by the hash decorator to apply hashing to a property value\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the operation\n * @param key - The property key to hash\n * @param {M} model - The model being processed\n * @param {M} [oldModel] - The previous model state (for updates)\n * @return {void}\n * @function hashOnCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function hashOnCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends object,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M, oldModel?: M): void {\n  if (typeof model[key] === \"undefined\") return;\n  const hash = Hashing.hash((model as any)[key]);\n  if (oldModel && (model as any)[key] === hash) return;\n  model[key] = hash;\n}\n\n/**\n * @description Creates a decorator that hashes a property value\n * @summary Decorator that automatically hashes a property value during create and update operations\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function hash\n * @category Property Decorators\n */\nexport function hash() {\n  return apply(\n    onCreateUpdate(hashOnCreateUpdate),\n    propMetadata(Repository.key(DBKeys.HASH), {})\n  );\n}\n\n/**\n * @description Metadata for composed property decorators\n * @summary Configuration options for property composition from other properties\n * @typedef {Object} ComposedFromMetadata\n * @property {string[]} args - Property names to compose from\n * @property {string} separator - Character used to join the composed values\n * @property {boolean} hashResult - Whether to hash the composed result\n * @property {\"keys\"|\"values\"} type - Whether to use property keys or values\n * @property {string} [prefix] - Optional prefix to add to the composed value\n * @property {string} [suffix] - Optional suffix to add to the composed value\n * @memberOf module:db-decorators\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\n/**\n * @description Composes a property value from other properties during create or update operations\n * @summary Callback function used by composed decorators to generate a property value from other properties\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type extending ComposedFromMetadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @param {C} context - The operation context\n * @param {V} data - Metadata for the composition\n * @param key - The property key to set the composed value on\n * @param {M} model - The model being processed\n * @return {void}\n * @function composedFromCreateUpdate\n * @memberOf module:db-decorators\n */\nexport function composedFromCreateUpdate<\n  M extends Model,\n  R extends IRepository<M, F, C>,\n  V extends ComposedFromMetadata,\n  F extends RepositoryFlags = RepositoryFlags,\n  C extends Context<F> = Context<F>,\n>(this: R, context: C, data: V, key: keyof M, model: M) {\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(`Property ${arg} not found to compose from`);\n      if (type === \"keys\") return arg;\n      if (typeof (model as any)[arg] === \"undefined\")\n        throw new InternalError(\n          `Property ${args} does not contain a value to compose from`\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\n/**\n * @description Creates a decorator that composes a property value from other properties\n * @summary Base function for creating property composition decorators\n * @param {string[]} args - Property names to compose from\n * @param {boolean} [hashResult=false] - Whether to hash the composed result\n * @param {string} [separator=DefaultSeparator] - Character used to join the composed values\n * @param {\"keys\"|\"values\"} [type=\"values\"] - Whether to use property keys or values\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFrom\n * @category PropertyDecorators\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\n/**\n * @description Creates a decorator that composes a property value from property keys\n * @summary Decorator that generates a property value by joining the names of other properties\n * @param {string[]} args - Property names to compose from\n * @param {string} [separator=DefaultSeparator] - Character used to join the property names\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composedFromKeys\n * @category PropertyDecorators\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\n/**\n * @description Creates a decorator that composes a property value from property values\n * @summary Decorator that generates a property value by joining the values of other properties\n * @param {string[]} args - Property names whose values will be composed\n * @param {string} [separator=DefaultSeparator] - Character used to join the property values\n * @param {boolean} [hash=false] - Whether to hash the composed result\n * @param {string} [prefix=\"\"] - Optional prefix to add to the composed value\n * @param {string} [suffix=\"\"] - Optional suffix to add to the composed value\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function composed\n * @category PropertyDecorators\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 * @description Creates a function that updates a version property during operations\n * @summary Factory function that generates a callback for incrementing version numbers\n * @param {CrudOperations} operation - The type of operation (CREATE or UPDATE)\n * @return {Function} A callback function that updates the version property\n * @template M - Type extending Model\n * @template R - Type extending IRepository\n * @template V - Type for metadata\n * @template F - Type extending RepositoryFlags\n * @template C - Type extending Context\n * @function versionCreateUpdate\n * @memberOf module:db-decorators\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant versionCreateUpdate\n *\n *   Caller->>versionCreateUpdate: operation\n *   versionCreateUpdate-->>Caller: callback function\n *   Note over Caller,versionCreateUpdate: When callback is executed:\n *   Caller->>versionCreateUpdate: context, data, key, model\n *   alt operation is CREATE\n *     versionCreateUpdate->>versionCreateUpdate: set version to 1\n *   else operation is UPDATE\n *     versionCreateUpdate->>versionCreateUpdate: increment version\n *   else invalid operation\n *     versionCreateUpdate->>versionCreateUpdate: throw error\n *   end\n *   versionCreateUpdate-->>Caller: void\n */\nexport function versionCreateUpdate(operation: CrudOperations) {\n  return function versionCreateUpdate<\n    M extends Model,\n    R extends IRepository<M, F, C>,\n    V extends object,\n    F extends RepositoryFlags = RepositoryFlags,\n    C extends Context<F> = Context<F>,\n  >(this: R, context: C, data: V, key: keyof M, 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 * @return {PropertyDecorator} A composite decorator that sets the type to Number, manages version updates, and adds versioning metadata\n * @function version\n * @category PropertyDecorators\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\n/**\n * @description Creates a decorator that marks a property as transient\n * @summary Decorator that indicates a property should not be persisted to the database\n * @return {PropertyDecorator} A decorator that can be applied to class properties\n * @function transient\n * @category PropertyDecorators\n */\nexport function transient() {\n  return function transient(model: any, attribute: string) {\n    propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model, attribute);\n    propMetadata(Repository.key(DBKeys.TRANSIENT), true)(model.constructor);\n  };\n}\n"]}
@@ -4,12 +4,43 @@ import { Context } from "../repository/Context";
4
4
  import { CrudOperations } from "../operations";
5
5
  import { RepositoryFlags } from "../repository/types";
6
6
  /**
7
- *
8
- * @param {str} str
9
- * @memberOf db-decorators.model
7
+ * @description Hashes a property value during create or update operations
8
+ * @summary Callback function used by the hash decorator to apply hashing to a property value
9
+ * @template M - Type extending Model
10
+ * @template R - Type extending IRepository
11
+ * @template V - Type for metadata
12
+ * @template F - Type extending RepositoryFlags
13
+ * @template C - Type extending Context
14
+ * @param {C} context - The operation context
15
+ * @param {V} data - Metadata for the operation
16
+ * @param key - The property key to hash
17
+ * @param {M} model - The model being processed
18
+ * @param {M} [oldModel] - The previous model state (for updates)
19
+ * @return {void}
20
+ * @function hashOnCreateUpdate
21
+ * @memberOf module:db-decorators
10
22
  */
11
23
  export declare function hashOnCreateUpdate<M extends Model, R extends IRepository<M, F, C>, V extends object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M, oldModel?: M): void;
24
+ /**
25
+ * @description Creates a decorator that hashes a property value
26
+ * @summary Decorator that automatically hashes a property value during create and update operations
27
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
28
+ * @function hash
29
+ * @category Property Decorators
30
+ */
12
31
  export declare function hash(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
32
+ /**
33
+ * @description Metadata for composed property decorators
34
+ * @summary Configuration options for property composition from other properties
35
+ * @typedef {Object} ComposedFromMetadata
36
+ * @property {string[]} args - Property names to compose from
37
+ * @property {string} separator - Character used to join the composed values
38
+ * @property {boolean} hashResult - Whether to hash the composed result
39
+ * @property {"keys"|"values"} type - Whether to use property keys or values
40
+ * @property {string} [prefix] - Optional prefix to add to the composed value
41
+ * @property {string} [suffix] - Optional suffix to add to the composed value
42
+ * @memberOf module:db-decorators
43
+ */
13
44
  export type ComposedFromMetadata = {
14
45
  args: string[];
15
46
  separator: string;
@@ -18,35 +49,93 @@ export type ComposedFromMetadata = {
18
49
  prefix?: string;
19
50
  suffix?: string;
20
51
  };
52
+ /**
53
+ * @description Composes a property value from other properties during create or update operations
54
+ * @summary Callback function used by composed decorators to generate a property value from other properties
55
+ * @template M - Type extending Model
56
+ * @template R - Type extending IRepository
57
+ * @template V - Type extending ComposedFromMetadata
58
+ * @template F - Type extending RepositoryFlags
59
+ * @template C - Type extending Context
60
+ * @param {C} context - The operation context
61
+ * @param {V} data - Metadata for the composition
62
+ * @param key - The property key to set the composed value on
63
+ * @param {M} model - The model being processed
64
+ * @return {void}
65
+ * @function composedFromCreateUpdate
66
+ * @memberOf module:db-decorators
67
+ */
21
68
  export declare function composedFromCreateUpdate<M extends Model, R extends IRepository<M, F, C>, V extends ComposedFromMetadata, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M): void;
69
+ /**
70
+ * @description Creates a decorator that composes a property value from property keys
71
+ * @summary Decorator that generates a property value by joining the names of other properties
72
+ * @param {string[]} args - Property names to compose from
73
+ * @param {string} [separator=DefaultSeparator] - Character used to join the property names
74
+ * @param {boolean} [hash=false] - Whether to hash the composed result
75
+ * @param {string} [prefix=""] - Optional prefix to add to the composed value
76
+ * @param {string} [suffix=""] - Optional suffix to add to the composed value
77
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
78
+ * @function composedFromKeys
79
+ * @category PropertyDecorators
80
+ */
22
81
  export declare function composedFromKeys(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
82
+ /**
83
+ * @description Creates a decorator that composes a property value from property values
84
+ * @summary Decorator that generates a property value by joining the values of other properties
85
+ * @param {string[]} args - Property names whose values will be composed
86
+ * @param {string} [separator=DefaultSeparator] - Character used to join the property values
87
+ * @param {boolean} [hash=false] - Whether to hash the composed result
88
+ * @param {string} [prefix=""] - Optional prefix to add to the composed value
89
+ * @param {string} [suffix=""] - Optional suffix to add to the composed value
90
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
91
+ * @function composed
92
+ * @category PropertyDecorators
93
+ */
23
94
  export declare function composed(args: string[], separator?: string, hash?: boolean, prefix?: string, suffix?: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
24
95
  /**
25
- * Creates a decorator function that updates the version of a model during create or update operations.
26
- *
27
- * @param {CrudOperations} operation - The type of operation being performed (CREATE or UPDATE).
28
- * @returns {function} A function that updates the version of the model based on the operation type.
29
- *
96
+ * @description Creates a function that updates a version property during operations
97
+ * @summary Factory function that generates a callback for incrementing version numbers
98
+ * @param {CrudOperations} operation - The type of operation (CREATE or UPDATE)
99
+ * @return {Function} A callback function that updates the version property
30
100
  * @template M - Type extending Model
31
- * @template V - Type extending IRepository<M>
101
+ * @template R - Type extending IRepository
102
+ * @template V - Type for metadata
103
+ * @template F - Type extending RepositoryFlags
104
+ * @template C - Type extending Context
105
+ * @function versionCreateUpdate
106
+ * @memberOf module:db-decorators
107
+ * @mermaid
108
+ * sequenceDiagram
109
+ * participant Caller
110
+ * participant versionCreateUpdate
32
111
  *
33
- * @this {V} - The repository instance
34
- * @param {Context<M>} context - The context of the operation
35
- * @param {unknown} data - Additional data for the operation (not used in this function)
36
- * @param {string} key - The key of the version property in the model
37
- * @param {M} model - The model being updated
38
- * @throws {InternalError} If an invalid operation is provided or if version update fails
112
+ * Caller->>versionCreateUpdate: operation
113
+ * versionCreateUpdate-->>Caller: callback function
114
+ * Note over Caller,versionCreateUpdate: When callback is executed:
115
+ * Caller->>versionCreateUpdate: context, data, key, model
116
+ * alt operation is CREATE
117
+ * versionCreateUpdate->>versionCreateUpdate: set version to 1
118
+ * else operation is UPDATE
119
+ * versionCreateUpdate->>versionCreateUpdate: increment version
120
+ * else invalid operation
121
+ * versionCreateUpdate->>versionCreateUpdate: throw error
122
+ * end
123
+ * versionCreateUpdate-->>Caller: void
39
124
  */
40
125
  export declare function versionCreateUpdate(operation: CrudOperations): <M extends Model, R extends IRepository<M, F, C>, V extends object, F extends RepositoryFlags = RepositoryFlags, C extends Context<F> = Context<F>>(this: R, context: C, data: V, key: keyof M, model: M) => void;
41
126
  /**
42
- * @description Creates a decorator for versioning a property in a model.
43
- * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations.
44
- *
45
- * @returns {Function} A composite decorator that:
46
- * - Sets the type of the property to Number
47
- * - Applies a version update on create operations
48
- * - Applies a version update on update operations
49
- * - Adds metadata indicating this property is used for versioning
127
+ * @description Creates a decorator for versioning a property in a model
128
+ * @summary This decorator applies multiple sub-decorators to handle version management during create and update operations
129
+ * @return {PropertyDecorator} A composite decorator that sets the type to Number, manages version updates, and adds versioning metadata
130
+ * @function version
131
+ * @category PropertyDecorators
50
132
  */
51
133
  export declare function version(): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
134
+ /**
135
+ * @description Creates a decorator that marks a property as transient
136
+ * @summary Decorator that indicates a property should not be persisted to the database
137
+ * @return {PropertyDecorator} A decorator that can be applied to class properties
138
+ * @function transient
139
+ * @category PropertyDecorators
140
+ */
52
141
  export declare function transient(): (model: any, attribute: string) => void;
@@ -18,5 +18,6 @@ __exportStar(require("./validation.cjs"), exports);
18
18
  __exportStar(require("./constants.cjs"), exports);
19
19
  __exportStar(require("./decorators.cjs"), exports);
20
20
  __exportStar(require("./model.cjs"), exports);
21
+ __exportStar(require("./overrides.cjs"), exports);
21
22
  __exportStar(require("./utils.cjs"), exports);
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG1EQUE2QjtBQUM3QixrREFBNEI7QUFDNUIsbURBQTZCO0FBQzdCLDhDQUF3QjtBQUN4Qiw4Q0FBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2RlY29yYXRvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuIl19
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLG1EQUE2QjtBQUM3QixrREFBNEI7QUFDNUIsbURBQTZCO0FBQzdCLDhDQUF3QjtBQUN4QixrREFBNEI7QUFDNUIsOENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vdmFsaWRhdGlvblwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kZWNvcmF0b3JzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vb3ZlcnJpZGVzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsc1wiO1xuIl19
@@ -2,4 +2,5 @@ export * from "./validation";
2
2
  export * from "./constants";
3
3
  export * from "./decorators";
4
4
  export * from "./model";
5
+ export * from "./overrides";
5
6
  export * from "./utils";
@@ -1,15 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const decorator_validation_1 = require("@decaf-ts/decorator-validation");
4
- const validation_1 = require("./validation.cjs");
5
- decorator_validation_1.Model.prototype.hasErrors = function (previousVersion, ...exclusions) {
6
- if (previousVersion && !(previousVersion instanceof decorator_validation_1.Model)) {
7
- exclusions.unshift(previousVersion);
8
- previousVersion = undefined;
9
- }
10
- const errs = (0, decorator_validation_1.validate)(this, ...exclusions);
11
- if (errs || !previousVersion)
12
- return errs;
13
- return (0, validation_1.validateCompare)(previousVersion, this, ...exclusions);
14
- };
15
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/model/model.ts"],"names":[],"mappings":";;AAAA,yEAawC;AACxC,iDAA+C;AAE/C,4BAAK,CAAC,SAAS,CAAC,SAAS,GAAG,UAE1B,eAAyB,EACzB,GAAG,UAAiB;IAEpB,IAAI,eAAe,IAAI,CAAC,CAAC,eAAe,YAAY,4BAAK,CAAC,EAAE,CAAC;QAC3D,UAAU,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACpC,eAAe,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,MAAM,IAAI,GAAG,IAAA,+BAAQ,EAAC,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC;IAC3C,IAAI,IAAI,IAAI,CAAC,eAAe;QAAE,OAAO,IAAI,CAAC;IAE1C,OAAO,IAAA,4BAAe,EAAC,eAAe,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC;AAC/D,CAAC,CAAC","sourcesContent":["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    /**\n     * @summary Returns the serialized model according to the currently defined {@link Serializer}\n     */\n    serialize(): string;\n\n    /**\n     * @summary Override the implementation for js's 'toString()' which sucks...\n     * @override\n     */\n    toString(): string;\n\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    /**\n     * @summary Deserializes a Model\n     * @param {string} str\n     *\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    /**\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    /**\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    /**\n     * @summary Sets the Global {@link ModelBuilderFunction}\n     * @param {ModelBuilderFunction} [builder]\n     */\n    static setBuilder(builder?: ModelBuilderFunction): void;\n\n    /**\n     * @summary Retrieves the current global {@link ModelBuilderFunction}\n     */\n    static getBuilder(): ModelBuilderFunction | undefined;\n\n    /**\n     * Returns the current {@link ModelRegistryManager}\n     *\n     * @return ModelRegistry, defaults to {@link ModelRegistryManager}\n     */\n    private static getRegistry;\n\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    /**\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    /**\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    /**\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\n    static getMetadata<V extends Model>(model: V): any;\n\n    static getAttributes<V extends Model>(model: Constructor<V> | V): string[];\n\n    static equals<M extends Model>(\n      obj1: M,\n      obj2: M,\n      ...exceptions: any[]\n    ): boolean;\n\n    static hasErrors<M extends Model>(\n      model: M,\n      ...propsToIgnore: string[]\n    ): ModelErrorDefinition | undefined;\n\n    static serialize<M extends Model>(model: M): any;\n\n    static hash<M extends Model>(model: M): any;\n\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     * @description Determines if an object is a model instance or has model metadata\n     * @summary Checks whether a given object is either an instance of the Model class or\n     * has model metadata attached to it. This function is essential for serialization and\n     * deserialization processes, as it helps identify model objects that need special handling.\n     * It safely handles potential errors during metadata retrieval.\n     *\n     * @param {Record<string, any>} target - The object to check\n     * @return {boolean} True if the object is a model instance or has model metadata, false otherwise\n     *\n     * @example\n     * ```typescript\n     * // Check if an object is a model\n     * const user = new User({ name: \"John\" });\n     * const isUserModel = isModel(user); // true\n     *\n     * // Check a plain object\n     * const plainObject = { name: \"John\" };\n     * const isPlainObjectModel = isModel(plainObject); // false\n     * ```\n     */\n    static isModel(target: Record<string, any>): boolean;\n\n    /**\n     * @description Checks if a property of a model is itself a model or has a model type\n     * @summary Determines whether a specific property of a model instance is either a model instance\n     * or has a type that is registered as a model. This function is used for model serialization\n     * and deserialization to properly handle nested models.\n     * @template M extends {@link Model}\n     * @param {M} target - The model instance to check\n     * @param {string} attribute - The property name to check\n     * @return {boolean | string | undefined} Returns true if the property is a model instance,\n     * the model name if the property has a model type, or undefined if not a model\n     */\n    static isPropertyModel<M extends Model>(\n      target: M,\n      attribute: string\n    ): boolean | string | undefined;\n  }\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbW9kZWwvbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgTW9kZWxFcnJvckRlZmluaXRpb24gfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5cbmRlY2xhcmUgbW9kdWxlIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCIge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10cy1jb21tZW50XG4gIC8vIEB0cy1leHBlY3QtZXJyb3JcbiAgZGVjbGFyZSBpbnRlcmZhY2UgTW9kZWwge1xuICAgIGhhc0Vycm9ycyhcbiAgICAgIHByZXZpb3VzVmVyc2lvbj86IE1vZGVsIHwgYW55LFxuICAgICAgLi4uZXhjbHVzaW9uczogYW55W11cbiAgICApOiBNb2RlbEVycm9yRGVmaW5pdGlvbiB8IHVuZGVmaW5lZDtcbiAgfVxufVxuIl19