zibri 2.4.0 → 2.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 (859) hide show
  1. package/dist/cjs/application-options.model.d.ts +2 -2
  2. package/dist/cjs/application-options.model.d.ts.map +1 -1
  3. package/dist/cjs/application.d.ts.map +1 -1
  4. package/dist/cjs/application.js +8 -3
  5. package/dist/cjs/application.js.map +1 -1
  6. package/dist/cjs/assets/asset.service.d.ts.map +1 -1
  7. package/dist/cjs/assets/asset.service.js +3 -1
  8. package/dist/cjs/assets/asset.service.js.map +1 -1
  9. package/dist/cjs/auth/2fa/methods/otp/otp-credentials.model.d.ts +1 -1
  10. package/dist/cjs/auth/2fa/methods/otp/otp-credentials.model.d.ts.map +1 -1
  11. package/dist/cjs/auth/2fa/methods/otp/otp-credentials.model.js.map +1 -1
  12. package/dist/cjs/auth/2fa/methods/otp/otp.two-factor-method.js +1 -1
  13. package/dist/cjs/auth/2fa/methods/otp/otp.two-factor-method.js.map +1 -1
  14. package/dist/cjs/auth/encryption/encryption-key.model.d.ts +5 -1
  15. package/dist/cjs/auth/encryption/encryption-key.model.d.ts.map +1 -1
  16. package/dist/cjs/auth/encryption/encryption-key.model.js +9 -1
  17. package/dist/cjs/auth/encryption/encryption-key.model.js.map +1 -1
  18. package/dist/cjs/auth/strategies/cookie/cookie-auth.auth-strategy.d.ts.map +1 -1
  19. package/dist/cjs/auth/strategies/cookie/cookie-auth.auth-strategy.js.map +1 -1
  20. package/dist/cjs/auth/strategies/cookie/cookie-auth.controller.js +1 -1
  21. package/dist/cjs/auth/strategies/cookie/cookie-auth.controller.js.map +1 -1
  22. package/dist/cjs/auth/strategies/jwt/jwt-auth.controller.js +1 -1
  23. package/dist/cjs/auth/strategies/jwt/jwt-auth.controller.js.map +1 -1
  24. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.d.ts +5 -1
  25. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.d.ts.map +1 -1
  26. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.js +9 -1
  27. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.js.map +1 -1
  28. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.d.ts.map +1 -1
  29. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.js +3 -2
  30. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.js.map +1 -1
  31. package/dist/cjs/backup/backup-resource-entity.model.d.ts +6 -2
  32. package/dist/cjs/backup/backup-resource-entity.model.d.ts.map +1 -1
  33. package/dist/cjs/backup/backup-resource-entity.model.js +9 -1
  34. package/dist/cjs/backup/backup-resource-entity.model.js.map +1 -1
  35. package/dist/cjs/backup/backup.service.js +2 -2
  36. package/dist/cjs/backup/backup.service.js.map +1 -1
  37. package/dist/cjs/caching/cache/base-cache.model.js.map +1 -1
  38. package/dist/cjs/caching/cache/multi-tier.cache.js.map +1 -1
  39. package/dist/cjs/caching/cache/read-aside/read-aside.cache.js.map +1 -1
  40. package/dist/cjs/caching/cache/read-aside/write-around-read-aside.cache.js.map +1 -1
  41. package/dist/cjs/caching/cache/read-aside/write-behind-read-aside.cache.js.map +1 -1
  42. package/dist/cjs/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.js.map +1 -1
  43. package/dist/cjs/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.js.map +1 -1
  44. package/dist/cjs/caching/cache/read-aside/write-through-read-aside.cache.js.map +1 -1
  45. package/dist/cjs/caching/cache/read-through/read-through.cache.js.map +1 -1
  46. package/dist/cjs/caching/cache/read-through/write-around-read-through.cache.js.map +1 -1
  47. package/dist/cjs/caching/cache/read-through/write-behind-read-through.cache.js.map +1 -1
  48. package/dist/cjs/caching/cache/read-through/write-invalidate-read-through-args-only.cache.js.map +1 -1
  49. package/dist/cjs/caching/cache/read-through/write-invalidate-read-through-with-result.cache.js.map +1 -1
  50. package/dist/cjs/caching/cache/read-through/write-through-read-through.cache.js.map +1 -1
  51. package/dist/cjs/change-sets/change-set-repository.d.ts +5 -3
  52. package/dist/cjs/change-sets/change-set-repository.d.ts.map +1 -1
  53. package/dist/cjs/change-sets/change-set-repository.js +16 -16
  54. package/dist/cjs/change-sets/change-set-repository.js.map +1 -1
  55. package/dist/cjs/change-sets/models/change-set-entity.model.d.ts +2 -2
  56. package/dist/cjs/change-sets/models/change-set-entity.model.d.ts.map +1 -1
  57. package/dist/cjs/change-sets/models/change-set-entity.model.js +29 -1
  58. package/dist/cjs/change-sets/models/change-set-entity.model.js.map +1 -1
  59. package/dist/cjs/change-sets/models/change-set.model.d.ts +1 -1
  60. package/dist/cjs/change-sets/models/change-set.model.d.ts.map +1 -1
  61. package/dist/cjs/change-sets/models/change-set.model.js +2 -2
  62. package/dist/cjs/change-sets/models/change-set.model.js.map +1 -1
  63. package/dist/cjs/change-sets/models/change.model.d.ts +7 -3
  64. package/dist/cjs/change-sets/models/change.model.d.ts.map +1 -1
  65. package/dist/cjs/change-sets/models/change.model.js +9 -1
  66. package/dist/cjs/change-sets/models/change.model.js.map +1 -1
  67. package/dist/cjs/change-sets/models/soft-delete-entity.model.d.ts +2 -2
  68. package/dist/cjs/change-sets/models/soft-delete-entity.model.d.ts.map +1 -1
  69. package/dist/cjs/change-sets/models/soft-delete-entity.model.js +26 -0
  70. package/dist/cjs/change-sets/models/soft-delete-entity.model.js.map +1 -1
  71. package/dist/cjs/change-sets/soft-delete-repository.d.ts +6 -5
  72. package/dist/cjs/change-sets/soft-delete-repository.d.ts.map +1 -1
  73. package/dist/cjs/change-sets/soft-delete-repository.js +22 -6
  74. package/dist/cjs/change-sets/soft-delete-repository.js.map +1 -1
  75. package/dist/cjs/context/als.utilities.d.ts +3 -3
  76. package/dist/cjs/context/als.utilities.d.ts.map +1 -1
  77. package/dist/cjs/context/als.utilities.js.map +1 -1
  78. package/dist/cjs/context/cache/cache.context.d.ts +27 -0
  79. package/dist/cjs/context/cache/cache.context.d.ts.map +1 -0
  80. package/dist/cjs/context/cache/cache.context.js +61 -0
  81. package/dist/cjs/context/cache/cache.context.js.map +1 -0
  82. package/dist/cjs/context/request/request-context-token.model.js +1 -1
  83. package/dist/cjs/context/request/request-context-token.model.js.map +1 -1
  84. package/dist/cjs/cron/cron-job-entity.model.d.ts +2 -2
  85. package/dist/cjs/cron/cron-job-entity.model.d.ts.map +1 -1
  86. package/dist/cjs/cron/cron-job-entity.model.js.map +1 -1
  87. package/dist/cjs/data-source/data-sources/data-source-initialization.error.d.ts +7 -0
  88. package/dist/cjs/data-source/data-sources/data-source-initialization.error.d.ts.map +1 -0
  89. package/dist/cjs/data-source/data-sources/data-source-initialization.error.js +14 -0
  90. package/dist/cjs/data-source/data-sources/data-source-initialization.error.js.map +1 -0
  91. package/dist/cjs/data-source/data-sources/data-source.interface.d.ts +9 -1
  92. package/dist/cjs/data-source/data-sources/data-source.interface.d.ts.map +1 -1
  93. package/dist/cjs/data-source/data-sources/data-source.interface.js.map +1 -1
  94. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.d.ts +45 -0
  95. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.d.ts.map +1 -0
  96. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.js +298 -0
  97. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.js.map +1 -0
  98. package/dist/cjs/data-source/data-sources/sql-data-source.interface.d.ts +32 -0
  99. package/dist/cjs/data-source/data-sources/sql-data-source.interface.d.ts.map +1 -0
  100. package/dist/cjs/{entity/models/one-to-one-property-metadata.model.js → data-source/data-sources/sql-data-source.interface.js} +1 -1
  101. package/dist/cjs/data-source/data-sources/sql-data-source.interface.js.map +1 -0
  102. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.d.ts +156 -0
  103. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.d.ts.map +1 -0
  104. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.js +378 -0
  105. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.js.map +1 -0
  106. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.d.ts +26 -0
  107. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.d.ts.map +1 -0
  108. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js +373 -0
  109. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js.map +1 -0
  110. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.d.ts +74 -0
  111. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.d.ts.map +1 -0
  112. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.js +250 -0
  113. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.js.map +1 -0
  114. package/dist/cjs/data-source/migration/migration-entity.model.d.ts +2 -2
  115. package/dist/cjs/data-source/migration/migration-entity.model.d.ts.map +1 -1
  116. package/dist/cjs/data-source/migration/migration-entity.model.js.map +1 -1
  117. package/dist/cjs/data-source/migration/migration.model.d.ts +2 -2
  118. package/dist/cjs/data-source/migration/migration.model.d.ts.map +1 -1
  119. package/dist/cjs/data-source/models/options/count-options.model.d.ts +2 -7
  120. package/dist/cjs/data-source/models/options/count-options.model.d.ts.map +1 -1
  121. package/dist/cjs/data-source/models/options/delete-all-options.model.d.ts +2 -4
  122. package/dist/cjs/data-source/models/options/delete-all-options.model.d.ts.map +1 -1
  123. package/dist/cjs/data-source/models/options/find-all-options.model.d.ts +2 -2
  124. package/dist/cjs/data-source/models/options/find-all-options.model.d.ts.map +1 -1
  125. package/dist/cjs/data-source/models/options/find-by-id-options.model.d.ts +1 -6
  126. package/dist/cjs/data-source/models/options/find-by-id-options.model.d.ts.map +1 -1
  127. package/dist/cjs/data-source/models/options/find-one-options.model.d.ts +2 -11
  128. package/dist/cjs/data-source/models/options/find-one-options.model.d.ts.map +1 -1
  129. package/dist/cjs/data-source/models/options/update-all-options.model.d.ts +1 -7
  130. package/dist/cjs/data-source/models/options/update-all-options.model.d.ts.map +1 -1
  131. package/dist/cjs/data-source/models/options/update-by-id-options.model.d.ts +1 -7
  132. package/dist/cjs/data-source/models/options/update-by-id-options.model.d.ts.map +1 -1
  133. package/dist/cjs/data-source/models/where/array-where-filter.model.d.ts +142 -3
  134. package/dist/cjs/data-source/models/where/array-where-filter.model.d.ts.map +1 -1
  135. package/dist/cjs/data-source/models/where/base-where-filter.model.d.ts +18 -1
  136. package/dist/cjs/data-source/models/where/base-where-filter.model.d.ts.map +1 -1
  137. package/dist/cjs/data-source/models/where/boolean-where-filter.model.d.ts +4 -2
  138. package/dist/cjs/data-source/models/where/boolean-where-filter.model.d.ts.map +1 -1
  139. package/dist/cjs/data-source/models/where/date-where-filter.model.d.ts +16 -15
  140. package/dist/cjs/data-source/models/where/date-where-filter.model.d.ts.map +1 -1
  141. package/dist/cjs/data-source/models/where/number-where-filter.model.d.ts +8 -15
  142. package/dist/cjs/data-source/models/where/number-where-filter.model.d.ts.map +1 -1
  143. package/dist/cjs/data-source/models/where/object-where-filter.model.d.ts +52 -7
  144. package/dist/cjs/data-source/models/where/object-where-filter.model.d.ts.map +1 -1
  145. package/dist/cjs/data-source/models/where/string-where-filter.model.d.ts +25 -15
  146. package/dist/cjs/data-source/models/where/string-where-filter.model.d.ts.map +1 -1
  147. package/dist/cjs/data-source/models/where/where-filter-keys.model.d.ts +46 -0
  148. package/dist/cjs/data-source/models/where/where-filter-keys.model.d.ts.map +1 -0
  149. package/dist/cjs/data-source/models/where/where-filter-keys.model.js +39 -0
  150. package/dist/cjs/data-source/models/where/where-filter-keys.model.js.map +1 -0
  151. package/dist/cjs/data-source/models/where/where-filter.model.d.ts +2 -2
  152. package/dist/cjs/data-source/models/where/where-filter.model.d.ts.map +1 -1
  153. package/dist/cjs/data-source/query-failed.error.js +27 -1
  154. package/dist/cjs/data-source/query-failed.error.js.map +1 -1
  155. package/dist/cjs/data-source/repository.d.ts +8 -3
  156. package/dist/cjs/data-source/repository.d.ts.map +1 -1
  157. package/dist/cjs/data-source/repository.js +42 -16
  158. package/dist/cjs/data-source/repository.js.map +1 -1
  159. package/dist/cjs/di/decorators/inject-repository.decorator.d.ts +2 -2
  160. package/dist/cjs/di/decorators/inject-repository.decorator.d.ts.map +1 -1
  161. package/dist/cjs/di/decorators/inject-repository.decorator.js.map +1 -1
  162. package/dist/cjs/di/default/zibri-di-providers.default.d.ts.map +1 -1
  163. package/dist/cjs/di/default/zibri-di-providers.default.js +4 -0
  164. package/dist/cjs/di/default/zibri-di-providers.default.js.map +1 -1
  165. package/dist/cjs/di/default/zibri-di-tokens.default.d.ts +5 -2
  166. package/dist/cjs/di/default/zibri-di-tokens.default.d.ts.map +1 -1
  167. package/dist/cjs/di/default/zibri-di-tokens.default.js +2 -0
  168. package/dist/cjs/di/default/zibri-di-tokens.default.js.map +1 -1
  169. package/dist/cjs/email/email.service.d.ts +3 -3
  170. package/dist/cjs/email/email.service.d.ts.map +1 -1
  171. package/dist/cjs/email/email.service.js +8 -10
  172. package/dist/cjs/email/email.service.js.map +1 -1
  173. package/dist/cjs/email/models/email.model.d.ts +4 -4
  174. package/dist/cjs/email/models/email.model.d.ts.map +1 -1
  175. package/dist/cjs/email/models/email.model.js +5 -5
  176. package/dist/cjs/email/models/email.model.js.map +1 -1
  177. package/dist/cjs/entity/decorators/entity.decorator.d.ts +28 -1
  178. package/dist/cjs/entity/decorators/entity.decorator.d.ts.map +1 -1
  179. package/dist/cjs/entity/decorators/entity.decorator.js +6 -3
  180. package/dist/cjs/entity/decorators/entity.decorator.js.map +1 -1
  181. package/dist/cjs/entity/decorators/property.decorator.d.ts +5 -8
  182. package/dist/cjs/entity/decorators/property.decorator.d.ts.map +1 -1
  183. package/dist/cjs/entity/decorators/property.decorator.js +34 -20
  184. package/dist/cjs/entity/decorators/property.decorator.js.map +1 -1
  185. package/dist/cjs/entity/entity-metadata-missing.error.d.ts +9 -0
  186. package/dist/cjs/entity/entity-metadata-missing.error.d.ts.map +1 -0
  187. package/dist/cjs/entity/entity-metadata-missing.error.js +17 -0
  188. package/dist/cjs/entity/entity-metadata-missing.error.js.map +1 -0
  189. package/dist/cjs/entity/generation/generate-entity-file.function.js +1 -1
  190. package/dist/cjs/entity/generation/generate-entity-file.function.js.map +1 -1
  191. package/dist/cjs/entity/models/base-relation-metadata.model.d.ts +1 -1
  192. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.d.ts +28 -0
  193. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.d.ts.map +1 -0
  194. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.js +3 -0
  195. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.js.map +1 -0
  196. package/dist/cjs/entity/models/has-one-property-metadata.model.d.ts +18 -0
  197. package/dist/cjs/entity/models/has-one-property-metadata.model.d.ts.map +1 -0
  198. package/dist/{esm/entity/models/one-to-one-property-metadata.model.js → cjs/entity/models/has-one-property-metadata.model.js} +1 -1
  199. package/dist/cjs/entity/models/has-one-property-metadata.model.js.map +1 -0
  200. package/dist/cjs/entity/models/many-to-many-property-metadata.model.d.ts +3 -3
  201. package/dist/cjs/entity/models/many-to-many-property-metadata.model.d.ts.map +1 -1
  202. package/dist/cjs/entity/models/many-to-one-property-metadata.model.d.ts +11 -1
  203. package/dist/cjs/entity/models/many-to-one-property-metadata.model.d.ts.map +1 -1
  204. package/dist/cjs/entity/models/relation.enum.d.ts +2 -1
  205. package/dist/cjs/entity/models/relation.enum.d.ts.map +1 -1
  206. package/dist/cjs/entity/models/relation.enum.js +2 -1
  207. package/dist/cjs/entity/models/relation.enum.js.map +1 -1
  208. package/dist/cjs/entity/partial-class.model.js +1 -1
  209. package/dist/cjs/entity/partial-class.model.js.map +1 -1
  210. package/dist/cjs/event/event-cleanup.cron-job.d.ts.map +1 -1
  211. package/dist/cjs/event/event-cleanup.cron-job.js +4 -6
  212. package/dist/cjs/event/event-cleanup.cron-job.js.map +1 -1
  213. package/dist/cjs/event/event-subscriber-run.model.d.ts +7 -9
  214. package/dist/cjs/event/event-subscriber-run.model.d.ts.map +1 -1
  215. package/dist/cjs/event/event-subscriber-run.model.js +11 -18
  216. package/dist/cjs/event/event-subscriber-run.model.js.map +1 -1
  217. package/dist/cjs/event/event.model.js +1 -1
  218. package/dist/cjs/event/event.model.js.map +1 -1
  219. package/dist/cjs/event/event.service.d.ts.map +1 -1
  220. package/dist/cjs/event/event.service.js +6 -3
  221. package/dist/cjs/event/event.service.js.map +1 -1
  222. package/dist/cjs/global/global-registry.d.ts +2 -2
  223. package/dist/cjs/global/global-registry.d.ts.map +1 -1
  224. package/dist/cjs/global/model-registry/default-descriptor.d.ts.map +1 -1
  225. package/dist/cjs/global/model-registry/default-descriptor.js +2 -1
  226. package/dist/cjs/global/model-registry/default-descriptor.js.map +1 -1
  227. package/dist/cjs/global/model-registry/encryption-descriptor.d.ts.map +1 -1
  228. package/dist/cjs/global/model-registry/encryption-descriptor.js +2 -1
  229. package/dist/cjs/global/model-registry/encryption-descriptor.js.map +1 -1
  230. package/dist/cjs/global/model-registry/exclude-descriptor.d.ts.map +1 -1
  231. package/dist/cjs/global/model-registry/exclude-descriptor.js +2 -1
  232. package/dist/cjs/global/model-registry/exclude-descriptor.js.map +1 -1
  233. package/dist/cjs/global/model-registry/hash-descriptor.d.ts.map +1 -1
  234. package/dist/cjs/global/model-registry/hash-descriptor.js +2 -1
  235. package/dist/cjs/global/model-registry/hash-descriptor.js.map +1 -1
  236. package/dist/cjs/http/http-request.model.d.ts +2 -2
  237. package/dist/cjs/http/http-request.model.d.ts.map +1 -1
  238. package/dist/cjs/http/known-header.enum.d.ts +1 -0
  239. package/dist/cjs/http/known-header.enum.d.ts.map +1 -1
  240. package/dist/cjs/http/known-header.enum.js +1 -0
  241. package/dist/cjs/http/known-header.enum.js.map +1 -1
  242. package/dist/cjs/http-client/http-client.d.ts.map +1 -1
  243. package/dist/cjs/http-client/http-client.js.map +1 -1
  244. package/dist/cjs/index.d.ts +19 -6
  245. package/dist/cjs/index.d.ts.map +1 -1
  246. package/dist/cjs/index.js +20 -6
  247. package/dist/cjs/index.js.map +1 -1
  248. package/dist/cjs/localization/formatting/format-price.function.d.ts.map +1 -1
  249. package/dist/cjs/localization/formatting/format-price.function.js.map +1 -1
  250. package/dist/cjs/logging/log-context.model.d.ts +7 -32
  251. package/dist/cjs/logging/log-context.model.d.ts.map +1 -1
  252. package/dist/cjs/logging/log-context.model.js +9 -55
  253. package/dist/cjs/logging/log-context.model.js.map +1 -1
  254. package/dist/cjs/logging/logger.js +1 -1
  255. package/dist/cjs/logging/logger.js.map +1 -1
  256. package/dist/cjs/multithreading/models/thread-job-entity.model.d.ts +5 -5
  257. package/dist/cjs/multithreading/models/thread-job-entity.model.d.ts.map +1 -1
  258. package/dist/cjs/multithreading/models/thread-job-entity.model.js +4 -4
  259. package/dist/cjs/multithreading/models/thread-job-entity.model.js.map +1 -1
  260. package/dist/cjs/multithreading/services/thread-job.d.ts +4 -4
  261. package/dist/cjs/multithreading/services/thread-job.d.ts.map +1 -1
  262. package/dist/cjs/multithreading/services/thread-job.js.map +1 -1
  263. package/dist/cjs/open-api/open-api-service.interface.d.ts +2 -1
  264. package/dist/cjs/open-api/open-api-service.interface.d.ts.map +1 -1
  265. package/dist/cjs/open-api/open-api.service.d.ts +5 -2
  266. package/dist/cjs/open-api/open-api.service.d.ts.map +1 -1
  267. package/dist/cjs/open-api/open-api.service.js +276 -150
  268. package/dist/cjs/open-api/open-api.service.js.map +1 -1
  269. package/dist/cjs/parsing/form-data/form-data.body-parser.d.ts.map +1 -1
  270. package/dist/cjs/parsing/form-data/form-data.body-parser.js +2 -1
  271. package/dist/cjs/parsing/form-data/form-data.body-parser.js.map +1 -1
  272. package/dist/cjs/parsing/functions/parse-boolean.function.d.ts.map +1 -1
  273. package/dist/cjs/parsing/functions/parse-boolean.function.js.map +1 -1
  274. package/dist/cjs/parsing/functions/parse-object.function.d.ts.map +1 -1
  275. package/dist/cjs/parsing/functions/parse-object.function.js +2 -1
  276. package/dist/cjs/parsing/functions/parse-object.function.js.map +1 -1
  277. package/dist/cjs/parsing/html/csp-options.model.d.ts +1 -1
  278. package/dist/cjs/parsing/html/csp-options.model.d.ts.map +1 -1
  279. package/dist/cjs/parsing/html/csp-options.model.js.map +1 -1
  280. package/dist/cjs/parsing/parser.d.ts.map +1 -1
  281. package/dist/cjs/parsing/parser.js +5 -4
  282. package/dist/cjs/parsing/parser.js.map +1 -1
  283. package/dist/cjs/plugin/invoicing/models/invoice-address.model.d.ts +2 -2
  284. package/dist/cjs/plugin/invoicing/models/invoice-address.model.d.ts.map +1 -1
  285. package/dist/cjs/plugin/invoicing/models/invoice-address.model.js +2 -2
  286. package/dist/cjs/plugin/invoicing/models/invoice-address.model.js.map +1 -1
  287. package/dist/cjs/plugin/invoicing/models/vat.model.d.ts +1 -1
  288. package/dist/cjs/plugin/invoicing/models/vat.model.d.ts.map +1 -1
  289. package/dist/cjs/plugin/invoicing/models/vat.model.js +1 -1
  290. package/dist/cjs/plugin/invoicing/models/vat.model.js.map +1 -1
  291. package/dist/cjs/plugin/mailing-list/mailing-list.controller.js +1 -1
  292. package/dist/cjs/plugin/mailing-list/mailing-list.controller.js.map +1 -1
  293. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscriber.model.d.ts +1 -1
  294. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscriber.model.d.ts.map +1 -1
  295. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscriber.model.js +1 -1
  296. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscriber.model.js.map +1 -1
  297. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.d.ts +1 -1
  298. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.d.ts.map +1 -1
  299. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.js +1 -1
  300. package/dist/cjs/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.js.map +1 -1
  301. package/dist/cjs/plugin/payment/models/payment.model.d.ts +2 -2
  302. package/dist/cjs/plugin/payment/models/payment.model.d.ts.map +1 -1
  303. package/dist/cjs/plugin/payment/models/payment.model.js +1 -1
  304. package/dist/cjs/plugin/payment/models/payment.model.js.map +1 -1
  305. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal-client.d.ts +17 -17
  306. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal-client.d.ts.map +1 -1
  307. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal-client.js +17 -17
  308. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal-client.js.map +1 -1
  309. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal.payment-provider.js +1 -1
  310. package/dist/cjs/plugin/payment/providers/pay-pal/pay-pal.payment-provider.js.map +1 -1
  311. package/dist/cjs/preact/preact.utilities.js +1 -1
  312. package/dist/cjs/preact/preact.utilities.js.map +1 -1
  313. package/dist/cjs/preact/validate-email-templates.function.js +1 -1
  314. package/dist/cjs/preact/validate-email-templates.function.js.map +1 -1
  315. package/dist/cjs/rate-limiting/rate-limiter.d.ts +10 -5
  316. package/dist/cjs/rate-limiting/rate-limiter.d.ts.map +1 -1
  317. package/dist/cjs/rate-limiting/rate-limiter.js +22 -12
  318. package/dist/cjs/rate-limiting/rate-limiter.js.map +1 -1
  319. package/dist/cjs/routing/controller-route-configuration.model.d.ts +5 -0
  320. package/dist/cjs/routing/controller-route-configuration.model.d.ts.map +1 -1
  321. package/dist/cjs/routing/decorators/body.decorator.js +2 -1
  322. package/dist/cjs/routing/decorators/body.decorator.js.map +1 -1
  323. package/dist/cjs/routing/decorators/controller.decorator.d.ts +5 -0
  324. package/dist/cjs/routing/decorators/controller.decorator.d.ts.map +1 -1
  325. package/dist/cjs/routing/decorators/controller.decorator.js +3 -2
  326. package/dist/cjs/routing/decorators/controller.decorator.js.map +1 -1
  327. package/dist/cjs/routing/decorators/create-http-decorator.function.d.ts +2 -1
  328. package/dist/cjs/routing/decorators/create-http-decorator.function.d.ts.map +1 -1
  329. package/dist/cjs/routing/decorators/create-http-decorator.function.js +2 -2
  330. package/dist/cjs/routing/decorators/create-http-decorator.function.js.map +1 -1
  331. package/dist/cjs/routing/decorators/delete.decorator.d.ts +3 -1
  332. package/dist/cjs/routing/decorators/delete.decorator.d.ts.map +1 -1
  333. package/dist/cjs/routing/decorators/delete.decorator.js +3 -2
  334. package/dist/cjs/routing/decorators/delete.decorator.js.map +1 -1
  335. package/dist/cjs/routing/decorators/get.decorator.d.ts +3 -1
  336. package/dist/cjs/routing/decorators/get.decorator.d.ts.map +1 -1
  337. package/dist/cjs/routing/decorators/get.decorator.js +3 -2
  338. package/dist/cjs/routing/decorators/get.decorator.js.map +1 -1
  339. package/dist/cjs/routing/decorators/http-decorator-option-input.model.d.ts +11 -0
  340. package/dist/cjs/routing/decorators/http-decorator-option-input.model.d.ts.map +1 -0
  341. package/dist/cjs/routing/decorators/http-decorator-option-input.model.js +3 -0
  342. package/dist/cjs/routing/decorators/http-decorator-option-input.model.js.map +1 -0
  343. package/dist/cjs/routing/decorators/patch.decorator.d.ts +3 -1
  344. package/dist/cjs/routing/decorators/patch.decorator.d.ts.map +1 -1
  345. package/dist/cjs/routing/decorators/patch.decorator.js +3 -2
  346. package/dist/cjs/routing/decorators/patch.decorator.js.map +1 -1
  347. package/dist/cjs/routing/decorators/post.decorator.d.ts +3 -1
  348. package/dist/cjs/routing/decorators/post.decorator.d.ts.map +1 -1
  349. package/dist/cjs/routing/decorators/post.decorator.js +3 -2
  350. package/dist/cjs/routing/decorators/post.decorator.js.map +1 -1
  351. package/dist/cjs/routing/resolve-route-params.function.js +2 -1
  352. package/dist/cjs/routing/resolve-route-params.function.js.map +1 -1
  353. package/dist/cjs/routing/route-configuration.model.d.ts +11 -1
  354. package/dist/cjs/routing/route-configuration.model.d.ts.map +1 -1
  355. package/dist/cjs/routing/router.d.ts +6 -2
  356. package/dist/cjs/routing/router.d.ts.map +1 -1
  357. package/dist/cjs/routing/router.js +191 -70
  358. package/dist/cjs/routing/router.js.map +1 -1
  359. package/dist/cjs/utilities/fs.utilities.d.ts +1 -1
  360. package/dist/cjs/utilities/fs.utilities.js +1 -1
  361. package/dist/cjs/utilities/metadata-injection-keys.enum.d.ts +1 -0
  362. package/dist/cjs/utilities/metadata-injection-keys.enum.d.ts.map +1 -1
  363. package/dist/cjs/utilities/metadata-injection-keys.enum.js +1 -0
  364. package/dist/cjs/utilities/metadata-injection-keys.enum.js.map +1 -1
  365. package/dist/cjs/utilities/sem-ver.utilities.d.ts +46 -0
  366. package/dist/cjs/utilities/sem-ver.utilities.d.ts.map +1 -0
  367. package/dist/cjs/utilities/sem-ver.utilities.js +204 -0
  368. package/dist/cjs/utilities/sem-ver.utilities.js.map +1 -0
  369. package/dist/cjs/utilities/typeorm.utilities.d.ts +39 -0
  370. package/dist/cjs/utilities/typeorm.utilities.d.ts.map +1 -0
  371. package/dist/cjs/utilities/typeorm.utilities.js +47 -0
  372. package/dist/cjs/utilities/typeorm.utilities.js.map +1 -0
  373. package/dist/cjs/utilities/uuid.utilities.js +2 -2
  374. package/dist/cjs/utilities/uuid.utilities.js.map +1 -1
  375. package/dist/cjs/validation/validation-problem.model.d.ts.map +1 -1
  376. package/dist/cjs/validation/validation-problem.model.js +4 -7
  377. package/dist/cjs/validation/validation-problem.model.js.map +1 -1
  378. package/dist/cjs/validation/validation.service.d.ts.map +1 -1
  379. package/dist/cjs/validation/validation.service.js +6 -4
  380. package/dist/cjs/validation/validation.service.js.map +1 -1
  381. package/dist/cjs/versioning/route-with-version-data.model.d.ts +15 -0
  382. package/dist/cjs/versioning/route-with-version-data.model.d.ts.map +1 -0
  383. package/dist/cjs/versioning/route-with-version-data.model.js +3 -0
  384. package/dist/cjs/versioning/route-with-version-data.model.js.map +1 -0
  385. package/dist/cjs/versioning/supported-versions-options.model.d.ts +17 -0
  386. package/dist/cjs/versioning/supported-versions-options.model.d.ts.map +1 -0
  387. package/dist/cjs/versioning/supported-versions-options.model.js +3 -0
  388. package/dist/cjs/versioning/supported-versions-options.model.js.map +1 -0
  389. package/dist/cjs/versioning/version.model.d.ts +29 -0
  390. package/dist/cjs/versioning/version.model.d.ts.map +1 -0
  391. package/dist/cjs/{types/version.type.js → versioning/version.model.js} +1 -1
  392. package/dist/cjs/versioning/version.model.js.map +1 -0
  393. package/dist/cjs/versioning/versioning-service.interface.d.ts +31 -0
  394. package/dist/cjs/versioning/versioning-service.interface.d.ts.map +1 -0
  395. package/dist/cjs/versioning/versioning-service.interface.js +3 -0
  396. package/dist/cjs/versioning/versioning-service.interface.js.map +1 -0
  397. package/dist/cjs/versioning/versioning.service.d.ts +41 -0
  398. package/dist/cjs/versioning/versioning.service.d.ts.map +1 -0
  399. package/dist/cjs/versioning/versioning.service.js +366 -0
  400. package/dist/cjs/versioning/versioning.service.js.map +1 -0
  401. package/dist/cjs/websocket/decorators/websocket-controller.decorator.d.ts +10 -0
  402. package/dist/cjs/websocket/decorators/websocket-controller.decorator.d.ts.map +1 -1
  403. package/dist/cjs/websocket/decorators/websocket-controller.decorator.js +2 -2
  404. package/dist/cjs/websocket/decorators/websocket-controller.decorator.js.map +1 -1
  405. package/dist/cjs/websocket/decorators/websocket-route.decorator.d.ts +13 -1
  406. package/dist/cjs/websocket/decorators/websocket-route.decorator.d.ts.map +1 -1
  407. package/dist/cjs/websocket/decorators/websocket-route.decorator.js +3 -2
  408. package/dist/cjs/websocket/decorators/websocket-route.decorator.js.map +1 -1
  409. package/dist/cjs/websocket/models/connection/base-websocket-connection.model.d.ts +5 -0
  410. package/dist/cjs/websocket/models/connection/base-websocket-connection.model.d.ts.map +1 -1
  411. package/dist/cjs/websocket/models/connection/socket-io-websocket-connection.model.d.ts +3 -1
  412. package/dist/cjs/websocket/models/connection/socket-io-websocket-connection.model.d.ts.map +1 -1
  413. package/dist/cjs/websocket/models/connection/socket-io-websocket-connection.model.js +3 -1
  414. package/dist/cjs/websocket/models/connection/socket-io-websocket-connection.model.js.map +1 -1
  415. package/dist/cjs/websocket/models/websocket-controller-route-configuration.model.d.ts +6 -0
  416. package/dist/cjs/websocket/models/websocket-controller-route-configuration.model.d.ts.map +1 -1
  417. package/dist/cjs/websocket/models/websocket-message.model.d.ts +2 -2
  418. package/dist/cjs/websocket/models/websocket-message.model.d.ts.map +1 -1
  419. package/dist/cjs/websocket/models/websocket-message.model.js +1 -1
  420. package/dist/cjs/websocket/models/websocket-message.model.js.map +1 -1
  421. package/dist/cjs/websocket/models/websocket-request.model.d.ts +6 -12
  422. package/dist/cjs/websocket/models/websocket-request.model.d.ts.map +1 -1
  423. package/dist/cjs/websocket/models/websocket-request.model.js +1 -1
  424. package/dist/cjs/websocket/models/websocket-request.model.js.map +1 -1
  425. package/dist/cjs/websocket/services/websocket.service.d.ts +6 -4
  426. package/dist/cjs/websocket/services/websocket.service.d.ts.map +1 -1
  427. package/dist/cjs/websocket/services/websocket.service.js +122 -35
  428. package/dist/cjs/websocket/services/websocket.service.js.map +1 -1
  429. package/dist/esm/application.js +8 -3
  430. package/dist/esm/application.js.map +1 -1
  431. package/dist/esm/assets/asset.service.js +3 -1
  432. package/dist/esm/assets/asset.service.js.map +1 -1
  433. package/dist/esm/auth/2fa/methods/otp/otp-credentials.model.js.map +1 -1
  434. package/dist/esm/auth/2fa/methods/otp/otp.two-factor-method.js +1 -1
  435. package/dist/esm/auth/2fa/methods/otp/otp.two-factor-method.js.map +1 -1
  436. package/dist/esm/auth/encryption/encryption-key.model.js +9 -1
  437. package/dist/esm/auth/encryption/encryption-key.model.js.map +1 -1
  438. package/dist/esm/auth/strategies/cookie/cookie-auth.auth-strategy.js.map +1 -1
  439. package/dist/esm/auth/strategies/cookie/cookie-auth.controller.js +1 -1
  440. package/dist/esm/auth/strategies/cookie/cookie-auth.controller.js.map +1 -1
  441. package/dist/esm/auth/strategies/jwt/jwt-auth.controller.js +1 -1
  442. package/dist/esm/auth/strategies/jwt/jwt-auth.controller.js.map +1 -1
  443. package/dist/esm/auth/strategies/jwt/jwt-credentials.model.js +9 -1
  444. package/dist/esm/auth/strategies/jwt/jwt-credentials.model.js.map +1 -1
  445. package/dist/esm/auth/strategies/jwt/jwt.auth-strategy.js +3 -2
  446. package/dist/esm/auth/strategies/jwt/jwt.auth-strategy.js.map +1 -1
  447. package/dist/esm/backup/backup-resource-entity.model.js +9 -1
  448. package/dist/esm/backup/backup-resource-entity.model.js.map +1 -1
  449. package/dist/esm/backup/backup.service.js +2 -2
  450. package/dist/esm/backup/backup.service.js.map +1 -1
  451. package/dist/esm/caching/cache/base-cache.model.js.map +1 -1
  452. package/dist/esm/caching/cache/multi-tier.cache.js.map +1 -1
  453. package/dist/esm/caching/cache/read-aside/read-aside.cache.js.map +1 -1
  454. package/dist/esm/caching/cache/read-aside/write-around-read-aside.cache.js.map +1 -1
  455. package/dist/esm/caching/cache/read-aside/write-behind-read-aside.cache.js.map +1 -1
  456. package/dist/esm/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.js.map +1 -1
  457. package/dist/esm/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.js.map +1 -1
  458. package/dist/esm/caching/cache/read-aside/write-through-read-aside.cache.js.map +1 -1
  459. package/dist/esm/caching/cache/read-through/read-through.cache.js.map +1 -1
  460. package/dist/esm/caching/cache/read-through/write-around-read-through.cache.js.map +1 -1
  461. package/dist/esm/caching/cache/read-through/write-behind-read-through.cache.js.map +1 -1
  462. package/dist/esm/caching/cache/read-through/write-invalidate-read-through-args-only.cache.js.map +1 -1
  463. package/dist/esm/caching/cache/read-through/write-invalidate-read-through-with-result.cache.js.map +1 -1
  464. package/dist/esm/caching/cache/read-through/write-through-read-through.cache.js.map +1 -1
  465. package/dist/esm/change-sets/change-set-repository.js +16 -16
  466. package/dist/esm/change-sets/change-set-repository.js.map +1 -1
  467. package/dist/esm/change-sets/models/change-set-entity.model.js +29 -1
  468. package/dist/esm/change-sets/models/change-set-entity.model.js.map +1 -1
  469. package/dist/esm/change-sets/models/change-set.model.js +2 -2
  470. package/dist/esm/change-sets/models/change-set.model.js.map +1 -1
  471. package/dist/esm/change-sets/models/change.model.js +9 -1
  472. package/dist/esm/change-sets/models/change.model.js.map +1 -1
  473. package/dist/esm/change-sets/models/soft-delete-entity.model.js +26 -0
  474. package/dist/esm/change-sets/models/soft-delete-entity.model.js.map +1 -1
  475. package/dist/esm/change-sets/soft-delete-repository.js +22 -6
  476. package/dist/esm/change-sets/soft-delete-repository.js.map +1 -1
  477. package/dist/esm/context/als.utilities.js.map +1 -1
  478. package/dist/esm/context/cache/cache.context.js +61 -0
  479. package/dist/esm/context/cache/cache.context.js.map +1 -0
  480. package/dist/esm/context/request/request-context-token.model.js +1 -1
  481. package/dist/esm/context/request/request-context-token.model.js.map +1 -1
  482. package/dist/esm/cron/cron-job-entity.model.js.map +1 -1
  483. package/dist/esm/data-source/data-sources/data-source-initialization.error.js +14 -0
  484. package/dist/esm/data-source/data-sources/data-source-initialization.error.js.map +1 -0
  485. package/dist/esm/data-source/data-sources/data-source.interface.js.map +1 -1
  486. package/dist/esm/data-source/data-sources/postgres-typeorm-data-source.model.js +298 -0
  487. package/dist/esm/data-source/data-sources/postgres-typeorm-data-source.model.js.map +1 -0
  488. package/dist/esm/data-source/data-sources/sql-data-source.interface.js +3 -0
  489. package/dist/esm/data-source/data-sources/sql-data-source.interface.js.map +1 -0
  490. package/dist/esm/data-source/data-sources/typeorm-base-data-source.model.js +378 -0
  491. package/dist/esm/data-source/data-sources/typeorm-base-data-source.model.js.map +1 -0
  492. package/dist/esm/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js +373 -0
  493. package/dist/esm/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js.map +1 -0
  494. package/dist/esm/data-source/data-sources/where-converter/typeorm-where-filter.converter.js +250 -0
  495. package/dist/esm/data-source/data-sources/where-converter/typeorm-where-filter.converter.js.map +1 -0
  496. package/dist/esm/data-source/migration/migration-entity.model.js.map +1 -1
  497. package/dist/esm/data-source/models/where/where-filter-keys.model.js +39 -0
  498. package/dist/esm/data-source/models/where/where-filter-keys.model.js.map +1 -0
  499. package/dist/esm/data-source/query-failed.error.js +27 -1
  500. package/dist/esm/data-source/query-failed.error.js.map +1 -1
  501. package/dist/esm/data-source/repository.js +42 -16
  502. package/dist/esm/data-source/repository.js.map +1 -1
  503. package/dist/esm/di/decorators/inject-repository.decorator.js.map +1 -1
  504. package/dist/esm/di/default/zibri-di-providers.default.js +4 -0
  505. package/dist/esm/di/default/zibri-di-providers.default.js.map +1 -1
  506. package/dist/esm/di/default/zibri-di-tokens.default.js +2 -0
  507. package/dist/esm/di/default/zibri-di-tokens.default.js.map +1 -1
  508. package/dist/esm/email/email.service.js +8 -10
  509. package/dist/esm/email/email.service.js.map +1 -1
  510. package/dist/esm/email/models/email.model.js +5 -5
  511. package/dist/esm/email/models/email.model.js.map +1 -1
  512. package/dist/esm/entity/decorators/entity.decorator.js +6 -3
  513. package/dist/esm/entity/decorators/entity.decorator.js.map +1 -1
  514. package/dist/esm/entity/decorators/property.decorator.js +34 -20
  515. package/dist/esm/entity/decorators/property.decorator.js.map +1 -1
  516. package/dist/esm/entity/entity-metadata-missing.error.js +17 -0
  517. package/dist/esm/entity/entity-metadata-missing.error.js.map +1 -0
  518. package/dist/esm/entity/generation/generate-entity-file.function.js +1 -1
  519. package/dist/esm/entity/generation/generate-entity-file.function.js.map +1 -1
  520. package/dist/esm/entity/models/belongs-to-one-property-metadata.model.js +3 -0
  521. package/dist/esm/entity/models/belongs-to-one-property-metadata.model.js.map +1 -0
  522. package/dist/esm/entity/models/has-one-property-metadata.model.js +3 -0
  523. package/dist/esm/entity/models/has-one-property-metadata.model.js.map +1 -0
  524. package/dist/esm/entity/models/relation.enum.js +2 -1
  525. package/dist/esm/entity/models/relation.enum.js.map +1 -1
  526. package/dist/esm/entity/partial-class.model.js +1 -1
  527. package/dist/esm/entity/partial-class.model.js.map +1 -1
  528. package/dist/esm/event/event-cleanup.cron-job.js +4 -6
  529. package/dist/esm/event/event-cleanup.cron-job.js.map +1 -1
  530. package/dist/esm/event/event-subscriber-run.model.js +11 -18
  531. package/dist/esm/event/event-subscriber-run.model.js.map +1 -1
  532. package/dist/esm/event/event.model.js +1 -1
  533. package/dist/esm/event/event.model.js.map +1 -1
  534. package/dist/esm/event/event.service.js +6 -3
  535. package/dist/esm/event/event.service.js.map +1 -1
  536. package/dist/esm/global/model-registry/default-descriptor.js +2 -1
  537. package/dist/esm/global/model-registry/default-descriptor.js.map +1 -1
  538. package/dist/esm/global/model-registry/encryption-descriptor.js +2 -1
  539. package/dist/esm/global/model-registry/encryption-descriptor.js.map +1 -1
  540. package/dist/esm/global/model-registry/exclude-descriptor.js +2 -1
  541. package/dist/esm/global/model-registry/exclude-descriptor.js.map +1 -1
  542. package/dist/esm/global/model-registry/hash-descriptor.js +2 -1
  543. package/dist/esm/global/model-registry/hash-descriptor.js.map +1 -1
  544. package/dist/esm/http/known-header.enum.js +1 -0
  545. package/dist/esm/http/known-header.enum.js.map +1 -1
  546. package/dist/esm/http-client/http-client.js.map +1 -1
  547. package/dist/esm/index.js +20 -6
  548. package/dist/esm/index.js.map +1 -1
  549. package/dist/esm/localization/formatting/format-price.function.js.map +1 -1
  550. package/dist/esm/logging/log-context.model.js +9 -55
  551. package/dist/esm/logging/log-context.model.js.map +1 -1
  552. package/dist/esm/logging/logger.js +1 -1
  553. package/dist/esm/logging/logger.js.map +1 -1
  554. package/dist/esm/multithreading/models/thread-job-entity.model.js +4 -4
  555. package/dist/esm/multithreading/models/thread-job-entity.model.js.map +1 -1
  556. package/dist/esm/multithreading/services/thread-job.js.map +1 -1
  557. package/dist/esm/open-api/open-api.service.js +276 -150
  558. package/dist/esm/open-api/open-api.service.js.map +1 -1
  559. package/dist/esm/parsing/form-data/form-data.body-parser.js +2 -1
  560. package/dist/esm/parsing/form-data/form-data.body-parser.js.map +1 -1
  561. package/dist/esm/parsing/functions/parse-boolean.function.js.map +1 -1
  562. package/dist/esm/parsing/functions/parse-object.function.js +2 -1
  563. package/dist/esm/parsing/functions/parse-object.function.js.map +1 -1
  564. package/dist/esm/parsing/html/csp-options.model.js.map +1 -1
  565. package/dist/esm/parsing/parser.js +5 -4
  566. package/dist/esm/parsing/parser.js.map +1 -1
  567. package/dist/esm/plugin/invoicing/models/invoice-address.model.js +2 -2
  568. package/dist/esm/plugin/invoicing/models/invoice-address.model.js.map +1 -1
  569. package/dist/esm/plugin/invoicing/models/vat.model.js +1 -1
  570. package/dist/esm/plugin/invoicing/models/vat.model.js.map +1 -1
  571. package/dist/esm/plugin/mailing-list/mailing-list.controller.js +1 -1
  572. package/dist/esm/plugin/mailing-list/mailing-list.controller.js.map +1 -1
  573. package/dist/esm/plugin/mailing-list/models/mailing-list-subscriber.model.js +1 -1
  574. package/dist/esm/plugin/mailing-list/models/mailing-list-subscriber.model.js.map +1 -1
  575. package/dist/esm/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.js +1 -1
  576. package/dist/esm/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.js.map +1 -1
  577. package/dist/esm/plugin/payment/models/payment.model.js +1 -1
  578. package/dist/esm/plugin/payment/models/payment.model.js.map +1 -1
  579. package/dist/esm/plugin/payment/providers/pay-pal/pay-pal-client.js +17 -17
  580. package/dist/esm/plugin/payment/providers/pay-pal/pay-pal-client.js.map +1 -1
  581. package/dist/esm/plugin/payment/providers/pay-pal/pay-pal.payment-provider.js +1 -1
  582. package/dist/esm/plugin/payment/providers/pay-pal/pay-pal.payment-provider.js.map +1 -1
  583. package/dist/esm/preact/preact.utilities.js +1 -1
  584. package/dist/esm/preact/preact.utilities.js.map +1 -1
  585. package/dist/esm/preact/validate-email-templates.function.js +1 -1
  586. package/dist/esm/preact/validate-email-templates.function.js.map +1 -1
  587. package/dist/esm/rate-limiting/rate-limiter.js +22 -12
  588. package/dist/esm/rate-limiting/rate-limiter.js.map +1 -1
  589. package/dist/esm/routing/decorators/body.decorator.js +2 -1
  590. package/dist/esm/routing/decorators/body.decorator.js.map +1 -1
  591. package/dist/esm/routing/decorators/controller.decorator.js +3 -2
  592. package/dist/esm/routing/decorators/controller.decorator.js.map +1 -1
  593. package/dist/esm/routing/decorators/create-http-decorator.function.js +2 -2
  594. package/dist/esm/routing/decorators/create-http-decorator.function.js.map +1 -1
  595. package/dist/esm/routing/decorators/delete.decorator.js +3 -2
  596. package/dist/esm/routing/decorators/delete.decorator.js.map +1 -1
  597. package/dist/esm/routing/decorators/get.decorator.js +3 -2
  598. package/dist/esm/routing/decorators/get.decorator.js.map +1 -1
  599. package/dist/esm/routing/decorators/http-decorator-option-input.model.js +3 -0
  600. package/dist/esm/routing/decorators/http-decorator-option-input.model.js.map +1 -0
  601. package/dist/esm/routing/decorators/patch.decorator.js +3 -2
  602. package/dist/esm/routing/decorators/patch.decorator.js.map +1 -1
  603. package/dist/esm/routing/decorators/post.decorator.js +3 -2
  604. package/dist/esm/routing/decorators/post.decorator.js.map +1 -1
  605. package/dist/esm/routing/resolve-route-params.function.js +2 -1
  606. package/dist/esm/routing/resolve-route-params.function.js.map +1 -1
  607. package/dist/esm/routing/router.js +191 -70
  608. package/dist/esm/routing/router.js.map +1 -1
  609. package/dist/esm/utilities/fs.utilities.js +1 -1
  610. package/dist/esm/utilities/metadata-injection-keys.enum.js +1 -0
  611. package/dist/esm/utilities/metadata-injection-keys.enum.js.map +1 -1
  612. package/dist/esm/utilities/sem-ver.utilities.js +204 -0
  613. package/dist/esm/utilities/sem-ver.utilities.js.map +1 -0
  614. package/dist/esm/utilities/typeorm.utilities.js +47 -0
  615. package/dist/esm/utilities/typeorm.utilities.js.map +1 -0
  616. package/dist/esm/utilities/uuid.utilities.js +2 -2
  617. package/dist/esm/utilities/uuid.utilities.js.map +1 -1
  618. package/dist/esm/validation/validation-problem.model.js +4 -7
  619. package/dist/esm/validation/validation-problem.model.js.map +1 -1
  620. package/dist/esm/validation/validation.service.js +6 -4
  621. package/dist/esm/validation/validation.service.js.map +1 -1
  622. package/dist/esm/versioning/route-with-version-data.model.js +3 -0
  623. package/dist/esm/versioning/route-with-version-data.model.js.map +1 -0
  624. package/dist/esm/versioning/supported-versions-options.model.js +3 -0
  625. package/dist/esm/versioning/supported-versions-options.model.js.map +1 -0
  626. package/dist/esm/{types/version.type.js → versioning/version.model.js} +1 -1
  627. package/dist/esm/versioning/version.model.js.map +1 -0
  628. package/dist/esm/versioning/versioning-service.interface.js +3 -0
  629. package/dist/esm/versioning/versioning-service.interface.js.map +1 -0
  630. package/dist/esm/versioning/versioning.service.js +366 -0
  631. package/dist/esm/versioning/versioning.service.js.map +1 -0
  632. package/dist/esm/websocket/decorators/websocket-controller.decorator.js +2 -2
  633. package/dist/esm/websocket/decorators/websocket-controller.decorator.js.map +1 -1
  634. package/dist/esm/websocket/decorators/websocket-route.decorator.js +3 -2
  635. package/dist/esm/websocket/decorators/websocket-route.decorator.js.map +1 -1
  636. package/dist/esm/websocket/models/connection/socket-io-websocket-connection.model.js +3 -1
  637. package/dist/esm/websocket/models/connection/socket-io-websocket-connection.model.js.map +1 -1
  638. package/dist/esm/websocket/models/websocket-message.model.js +1 -1
  639. package/dist/esm/websocket/models/websocket-message.model.js.map +1 -1
  640. package/dist/esm/websocket/models/websocket-request.model.js +1 -1
  641. package/dist/esm/websocket/models/websocket-request.model.js.map +1 -1
  642. package/dist/esm/websocket/services/websocket.service.js +122 -35
  643. package/dist/esm/websocket/services/websocket.service.js.map +1 -1
  644. package/package.json +21 -23
  645. package/src/__testing__/mocks/entities/child.entity.ts +4 -1
  646. package/src/__testing__/mocks/entities/company.entity.ts +5 -2
  647. package/src/__testing__/mocks/entities/profile.entity.ts +5 -2
  648. package/src/__testing__/mocks/entities/role.entity.ts +1 -1
  649. package/src/__testing__/mocks/entities/user.entity.ts +1 -1
  650. package/src/__testing__/test-server/create-test-data-source.function.ts +5 -5
  651. package/src/__testing__/test-server/providers.ts +25 -1
  652. package/src/__testing__/test-server/start-test-server.function.ts +82 -12
  653. package/src/__testing__/test-server/user-repository.ts +4 -3
  654. package/src/application-options.model.ts +2 -2
  655. package/src/application.ts +8 -3
  656. package/src/assets/asset.service.ts +3 -1
  657. package/src/auth/2fa/methods/otp/otp-credentials.model.ts +1 -1
  658. package/src/auth/2fa/methods/otp/otp.two-factor-method.ts +1 -1
  659. package/src/auth/2fa/two-factor.service.test.ts +151 -0
  660. package/src/auth/auth.service.test.ts +381 -0
  661. package/src/auth/encryption/encryption-key.model.ts +7 -2
  662. package/src/auth/strategies/cookie/cookie-auth.auth-strategy.ts +3 -2
  663. package/src/auth/strategies/cookie/cookie-auth.controller.ts +1 -1
  664. package/src/auth/strategies/jwt/jwt-auth.controller.ts +1 -1
  665. package/src/auth/strategies/jwt/jwt-credentials.model.ts +7 -1
  666. package/src/auth/strategies/jwt/jwt.auth-strategy.ts +6 -4
  667. package/src/backup/backup-resource-entity.model.ts +8 -3
  668. package/src/backup/backup-service.test.ts +3 -2
  669. package/src/backup/backup.service.ts +1 -1
  670. package/src/caching/cache/base-cache.model.ts +3 -3
  671. package/src/caching/cache/multi-tier.cache.ts +3 -3
  672. package/src/caching/cache/read-aside/read-aside.cache.ts +2 -2
  673. package/src/caching/cache/read-aside/write-around-read-aside.cache.ts +2 -2
  674. package/src/caching/cache/read-aside/write-behind-read-aside.cache.ts +2 -2
  675. package/src/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.ts +2 -2
  676. package/src/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.ts +2 -2
  677. package/src/caching/cache/read-aside/write-through-read-aside.cache.ts +2 -2
  678. package/src/caching/cache/read-through/read-through.cache.ts +2 -2
  679. package/src/caching/cache/read-through/write-around-read-through.cache.ts +2 -2
  680. package/src/caching/cache/read-through/write-behind-read-through.cache.ts +2 -2
  681. package/src/caching/cache/read-through/write-invalidate-read-through-args-only.cache.ts +2 -2
  682. package/src/caching/cache/read-through/write-invalidate-read-through-with-result.cache.ts +2 -2
  683. package/src/caching/cache/read-through/write-through-read-through.cache.ts +2 -2
  684. package/src/change-sets/change-set-repository.test.ts +317 -0
  685. package/src/change-sets/change-set-repository.ts +17 -17
  686. package/src/change-sets/models/change-set-entity.model.ts +6 -4
  687. package/src/change-sets/models/change-set.model.ts +2 -2
  688. package/src/change-sets/models/change.model.ts +9 -4
  689. package/src/change-sets/models/soft-delete-entity.model.ts +5 -3
  690. package/src/change-sets/soft-delete-repository.test.ts +326 -0
  691. package/src/change-sets/soft-delete-repository.ts +29 -10
  692. package/src/context/als.utilities.ts +5 -5
  693. package/src/context/cache/cache.context.ts +33 -0
  694. package/src/context/request/request-context-token.model.ts +1 -1
  695. package/src/cron/cron-job-entity.model.ts +2 -2
  696. package/src/cron/cron.test.ts +421 -0
  697. package/src/data-source/array-where-filter.test.ts +332 -0
  698. package/src/data-source/data-sources/data-source-initialization.error.ts +9 -0
  699. package/src/data-source/data-sources/data-source.interface.ts +14 -1
  700. package/src/data-source/data-sources/postgres-typeorm-data-source.model.ts +340 -0
  701. package/src/data-source/data-sources/sql-data-source.interface.ts +35 -0
  702. package/src/data-source/data-sources/typeorm-base-data-source.model.ts +543 -0
  703. package/src/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.ts +484 -0
  704. package/src/data-source/data-sources/where-converter/typeorm-where-filter.converter.ts +389 -0
  705. package/src/data-source/exclude-property.test.ts +4 -1
  706. package/src/data-source/hooks/hooks.test.ts +268 -0
  707. package/src/data-source/migration/migration-entity.model.ts +2 -2
  708. package/src/data-source/migration/migration.model.ts +2 -2
  709. package/src/data-source/migration/migration.test.ts +6 -5
  710. package/src/data-source/models/options/count-options.model.ts +2 -7
  711. package/src/data-source/models/options/delete-all-options.model.ts +2 -4
  712. package/src/data-source/models/options/find-all-options.model.ts +2 -2
  713. package/src/data-source/models/options/find-by-id-options.model.ts +1 -6
  714. package/src/data-source/models/options/find-one-options.model.ts +2 -11
  715. package/src/data-source/models/options/update-all-options.model.ts +2 -5
  716. package/src/data-source/models/options/update-by-id-options.model.ts +2 -5
  717. package/src/data-source/models/where/array-where-filter.model.ts +147 -5
  718. package/src/data-source/models/where/base-where-filter.model.ts +19 -1
  719. package/src/data-source/models/where/boolean-where-filter.model.ts +7 -2
  720. package/src/data-source/models/where/date-where-filter.model.ts +17 -16
  721. package/src/data-source/models/where/number-where-filter.model.ts +9 -16
  722. package/src/data-source/models/where/object-where-filter.model.ts +66 -7
  723. package/src/data-source/models/where/string-where-filter.model.ts +27 -17
  724. package/src/data-source/models/where/where-filter-keys.model.ts +91 -0
  725. package/src/data-source/models/where/where-filter-to-find-options-where-function.test.ts +35 -13
  726. package/src/data-source/models/where/where-filter.model.ts +7 -4
  727. package/src/data-source/nested-where-filter.test.ts +349 -0
  728. package/src/data-source/query-failed.error.ts +38 -1
  729. package/src/data-source/repository-relation-pitfalls.test.ts +232 -0
  730. package/src/data-source/repository.test.ts +274 -37
  731. package/src/data-source/repository.ts +50 -16
  732. package/src/data-source/transaction/transaction.test.ts +1 -1
  733. package/src/data-source/where-filter.test.ts +489 -0
  734. package/src/di/decorators/inject-repository.decorator.ts +3 -2
  735. package/src/di/default/zibri-di-providers.default.ts +4 -0
  736. package/src/di/default/zibri-di-tokens.default.ts +5 -2
  737. package/src/email/email.service.test.ts +382 -0
  738. package/src/email/email.service.ts +9 -10
  739. package/src/email/models/email.model.ts +5 -5
  740. package/src/entity/decorators/entity.decorator.ts +44 -5
  741. package/src/entity/decorators/property.decorator.ts +54 -36
  742. package/src/entity/entity-metadata-missing.error.ts +15 -0
  743. package/src/entity/generation/generate-entity-file.function.ts +1 -1
  744. package/src/entity/models/base-relation-metadata.model.ts +1 -1
  745. package/src/entity/models/belongs-to-one-property-metadata.model.ts +34 -0
  746. package/src/entity/models/has-one-property-metadata.model.ts +20 -0
  747. package/src/entity/models/many-to-many-property-metadata.model.ts +3 -3
  748. package/src/entity/models/many-to-one-property-metadata.model.ts +17 -3
  749. package/src/entity/models/relation.enum.ts +2 -1
  750. package/src/entity/partial-class.model.ts +1 -1
  751. package/src/event/event-cleanup.cron-job.ts +4 -6
  752. package/src/event/event-subscriber-run.model.ts +9 -10
  753. package/src/event/event.model.ts +1 -1
  754. package/src/event/event.service.ts +6 -3
  755. package/src/global/global-registry.ts +2 -2
  756. package/src/global/model-registry/default-descriptor.ts +2 -1
  757. package/src/global/model-registry/encryption-descriptor.ts +2 -1
  758. package/src/global/model-registry/exclude-descriptor.ts +2 -1
  759. package/src/global/model-registry/hash-descriptor.ts +2 -1
  760. package/src/http/http-request.model.ts +2 -2
  761. package/src/http/known-header.enum.ts +1 -0
  762. package/src/http-client/http-client.ts +0 -1
  763. package/src/index.ts +24 -6
  764. package/src/localization/formatting/format-price.function.ts +2 -3
  765. package/src/logging/log-context.model.ts +8 -39
  766. package/src/logging/logger.ts +1 -1
  767. package/src/multithreading/models/thread-job-entity.model.ts +5 -5
  768. package/src/multithreading/services/thread-job.ts +4 -4
  769. package/src/open-api/open-api-service.interface.ts +2 -1
  770. package/src/open-api/open-api.service.ts +295 -154
  771. package/src/parsing/form-data/form-data.body-parser.ts +2 -1
  772. package/src/parsing/functions/parse-boolean.function.ts +0 -1
  773. package/src/parsing/functions/parse-object.function.ts +2 -1
  774. package/src/parsing/html/csp-options.model.ts +3 -0
  775. package/src/parsing/parser.ts +5 -4
  776. package/src/plugin/invoicing/models/invoice-address.model.ts +2 -2
  777. package/src/plugin/invoicing/models/vat.model.ts +1 -1
  778. package/src/plugin/mailing-list/mailing-list.controller.ts +1 -1
  779. package/src/plugin/mailing-list/models/mailing-list-subscriber.model.ts +1 -1
  780. package/src/plugin/mailing-list/models/mailing-list-subscription-confirmation-token.model.ts +1 -1
  781. package/src/plugin/payment/models/payment.model.ts +2 -2
  782. package/src/plugin/payment/providers/pay-pal/pay-pal-client.ts +17 -17
  783. package/src/plugin/payment/providers/pay-pal/pay-pal.payment-provider.test.ts +1 -1
  784. package/src/plugin/payment/providers/pay-pal/pay-pal.payment-provider.ts +1 -1
  785. package/src/preact/preact.utilities.ts +1 -1
  786. package/src/preact/validate-email-templates.function.ts +1 -1
  787. package/src/rate-limiting/rate-limiter.ts +23 -12
  788. package/src/routing/controller-route-configuration.model.ts +6 -1
  789. package/src/routing/decorators/body.decorator.ts +2 -1
  790. package/src/routing/decorators/controller.decorator.ts +8 -2
  791. package/src/routing/decorators/create-http-decorator.function.ts +3 -2
  792. package/src/routing/decorators/delete.decorator.ts +4 -2
  793. package/src/routing/decorators/get.decorator.ts +4 -2
  794. package/src/routing/decorators/http-decorator-option-input.model.ts +11 -0
  795. package/src/routing/decorators/patch.decorator.ts +4 -2
  796. package/src/routing/decorators/post.decorator.ts +4 -2
  797. package/src/routing/resolve-route-params.function.ts +2 -1
  798. package/src/routing/route-configuration.model.ts +13 -3
  799. package/src/routing/router.ts +266 -101
  800. package/src/utilities/fs.utilities.ts +1 -1
  801. package/src/utilities/metadata-injection-keys.enum.ts +1 -0
  802. package/src/utilities/sem-ver.utilities.ts +270 -0
  803. package/src/utilities/typeorm.utilities.ts +75 -0
  804. package/src/utilities/uuid.utilities.ts +2 -2
  805. package/src/validation/validation-problem.model.ts +7 -9
  806. package/src/validation/validation.service.ts +6 -4
  807. package/src/versioning/route-with-version-data.model.ts +15 -0
  808. package/src/versioning/supported-versions-options.model.ts +25 -0
  809. package/src/versioning/version.model.ts +30 -0
  810. package/src/versioning/versioning-service.interface.ts +39 -0
  811. package/src/versioning/versioning-websocket.test.ts +351 -0
  812. package/src/versioning/versioning.service.test.ts +582 -0
  813. package/src/versioning/versioning.service.ts +496 -0
  814. package/src/websocket/decorators/websocket-controller.decorator.ts +13 -3
  815. package/src/websocket/decorators/websocket-route.decorator.ts +15 -2
  816. package/src/websocket/models/connection/base-websocket-connection.model.ts +6 -0
  817. package/src/websocket/models/connection/socket-io-websocket-connection.model.ts +8 -1
  818. package/src/websocket/models/websocket-controller-route-configuration.model.ts +8 -1
  819. package/src/websocket/models/websocket-message.model.ts +3 -3
  820. package/src/websocket/models/websocket-request.model.ts +19 -10
  821. package/src/websocket/services/websocket.service.ts +144 -40
  822. package/dist/cjs/data-source/data-sources/postgres-data-source.model.d.ts +0 -129
  823. package/dist/cjs/data-source/data-sources/postgres-data-source.model.d.ts.map +0 -1
  824. package/dist/cjs/data-source/data-sources/postgres-data-source.model.js +0 -534
  825. package/dist/cjs/data-source/data-sources/postgres-data-source.model.js.map +0 -1
  826. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.d.ts +0 -11
  827. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.d.ts.map +0 -1
  828. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.js +0 -229
  829. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.js.map +0 -1
  830. package/dist/cjs/entity/models/one-to-one-property-metadata.model.d.ts +0 -30
  831. package/dist/cjs/entity/models/one-to-one-property-metadata.model.d.ts.map +0 -1
  832. package/dist/cjs/entity/models/one-to-one-property-metadata.model.js.map +0 -1
  833. package/dist/cjs/types/version.type.d.ts +0 -5
  834. package/dist/cjs/types/version.type.d.ts.map +0 -1
  835. package/dist/cjs/types/version.type.js.map +0 -1
  836. package/dist/cjs/utilities/compare-versions.function.d.ts +0 -9
  837. package/dist/cjs/utilities/compare-versions.function.d.ts.map +0 -1
  838. package/dist/cjs/utilities/compare-versions.function.js +0 -33
  839. package/dist/cjs/utilities/compare-versions.function.js.map +0 -1
  840. package/dist/cjs/utilities/is-version.function.d.ts +0 -7
  841. package/dist/cjs/utilities/is-version.function.d.ts.map +0 -1
  842. package/dist/cjs/utilities/is-version.function.js +0 -18
  843. package/dist/cjs/utilities/is-version.function.js.map +0 -1
  844. package/dist/esm/data-source/data-sources/postgres-data-source.model.js +0 -534
  845. package/dist/esm/data-source/data-sources/postgres-data-source.model.js.map +0 -1
  846. package/dist/esm/data-source/models/where/where-filter-to-find-options-where.function.js +0 -229
  847. package/dist/esm/data-source/models/where/where-filter-to-find-options-where.function.js.map +0 -1
  848. package/dist/esm/entity/models/one-to-one-property-metadata.model.js.map +0 -1
  849. package/dist/esm/types/version.type.js.map +0 -1
  850. package/dist/esm/utilities/compare-versions.function.js +0 -33
  851. package/dist/esm/utilities/compare-versions.function.js.map +0 -1
  852. package/dist/esm/utilities/is-version.function.js +0 -18
  853. package/dist/esm/utilities/is-version.function.js.map +0 -1
  854. package/src/data-source/data-sources/postgres-data-source.model.ts +0 -675
  855. package/src/data-source/models/where/where-filter-to-find-options-where.function.ts +0 -307
  856. package/src/entity/models/one-to-one-property-metadata.model.ts +0 -35
  857. package/src/types/version.type.ts +0 -4
  858. package/src/utilities/compare-versions.function.ts +0 -33
  859. package/src/utilities/is-version.function.ts +0 -16
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult, CacheSetDirectOptions } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -25,7 +25,7 @@ export abstract class WriteBehindReadAsideCache<K, V, N extends string, CacheTag
25
25
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
26
26
  ): (...args: TArgs) => Promise<V> {
27
27
  return async (...args) => {
28
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
28
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
29
 
30
30
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
31
31
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { CacheKeyProvider, CacheWrapWriteOptionsArgsOnly } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -25,7 +25,7 @@ export abstract class WriteInvalidateReadAsideArgsOnlyCache<K, V, N extends stri
25
25
  options?: CacheWrapWriteOptionsArgsOnly<TArgs, CacheTag>
26
26
  ): (...args: TArgs) => Promise<V> {
27
27
  return async (...args) => {
28
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
28
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
29
 
30
30
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
31
31
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -25,7 +25,7 @@ export abstract class WriteInvalidateReadAsideWithResultCache<K, V, N extends st
25
25
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
26
26
  ): (...args: TArgs) => Promise<V> {
27
27
  return async (...args) => {
28
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
28
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
29
 
30
30
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
31
31
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult, CacheSetDirectOptions } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -25,7 +25,7 @@ export abstract class WriteThroughReadAsideCache<K, V, N extends string, CacheTa
25
25
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
26
26
  ): (...args: TArgs) => Promise<V> {
27
27
  return async (...args) => {
28
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
28
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
29
 
30
30
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
31
31
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CachedValue } from '../../store/cached-value.model';
4
4
  import { BaseCache } from '../base-cache.model';
5
5
  import { CacheOperation } from '../cache-operation.enum';
@@ -22,7 +22,7 @@ export abstract class ReadThroughCache<
22
22
  options?: CacheWrapOptions<V, TArgs, CacheTag>
23
23
  ): (...args: TArgs) => Promise<V> {
24
24
  return async (...args) => {
25
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRAP };
25
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRAP };
26
26
  const label: Record<string, string> = { cache: this.name };
27
27
 
28
28
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { CacheKeyProvider, CacheWrapWriteOptionsArgsOnly } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -23,7 +23,7 @@ export abstract class WriteAroundReadThroughCache<K, V, N extends string, CacheT
23
23
  options?: CacheWrapWriteOptionsArgsOnly<TArgs, CacheTag>
24
24
  ): (...args: TArgs) => Promise<V> {
25
25
  return async (...args) => {
26
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
26
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
27
27
 
28
28
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
29
29
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult, CacheSetDirectOptions } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -26,7 +26,7 @@ export abstract class WriteBehindReadThroughCache<K, V, N extends string, CacheT
26
26
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
27
27
  ): (...args: TArgs) => Promise<V> {
28
28
  return async (...args) => {
29
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
30
30
 
31
31
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
32
32
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { CacheKeyProvider, CacheWrapWriteOptionsArgsOnly } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -26,7 +26,7 @@ export abstract class WriteInvalidateReadThroughArgsOnlyCache<K, V, N extends st
26
26
  options?: CacheWrapWriteOptionsArgsOnly<TArgs, CacheTag>
27
27
  ): (...args: TArgs) => Promise<V> {
28
28
  return async (...args) => {
29
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
30
30
 
31
31
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
32
32
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -25,7 +25,7 @@ export abstract class WriteInvalidateReadThroughWithResultCache<K, V, N extends
25
25
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
26
26
  ): (...args: TArgs) => Promise<V> {
27
27
  return async (...args) => {
28
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
28
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
29
29
 
30
30
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
31
31
  const sourceStart: number = performance.now();
@@ -1,5 +1,5 @@
1
1
  import { AlsUtilities } from '../../../context/als.utilities';
2
- import { LogCacheContext } from '../../../logging/log-context.model';
2
+ import { CacheContext } from '../../../context/cache/cache.context';
3
3
  import { CacheOperation } from '../cache-operation.enum';
4
4
  import { ResultCacheKeyProvider, CacheWrapWriteOptionsWithResult, CacheSetDirectOptions } from '../cache-options.model';
5
5
  import { CacheInterface } from '../cache.interface';
@@ -22,7 +22,7 @@ export abstract class WriteThroughReadThroughCache<K, V, N extends string, Cache
22
22
  options?: CacheWrapWriteOptionsWithResult<V, TArgs, CacheTag>
23
23
  ): (...args: TArgs) => Promise<V> {
24
24
  return async (...args) => {
25
- const cacheCtx: LogCacheContext = { cache: this.name, operation: CacheOperation.WRITE };
25
+ const cacheCtx: CacheContext = { cache: this.name, operation: CacheOperation.WRITE };
26
26
 
27
27
  return AlsUtilities.runWithCacheContext(cacheCtx, async () => {
28
28
  const sourceStart: number = performance.now();
@@ -0,0 +1,317 @@
1
+ import { afterAll, beforeAll, beforeEach, describe, expect, it } from '@jest/globals';
2
+
3
+ import { ChangeSetRepository, ResetChangeSetResult } from './change-set-repository';
4
+ import { ChangeSet, CreateChangeSetData } from './models/change-set.model';
5
+ import { Change } from './models/change.model';
6
+ import { Roles } from '../__testing__/mocks/entities/roles.enum';
7
+ import { createTestDataSource, defaultTestServerEntities } from '../__testing__/test-server/create-test-data-source.function';
8
+ import { startTestServer, StartedTestServer } from '../__testing__/test-server/start-test-server.function';
9
+ import { DefaultTestServerUserRepository } from '../__testing__/test-server/user-repository'; // adjust if needed
10
+ import { AuthServiceInterface } from '../auth/auth-service.interface';
11
+ import { Auth } from '../auth/decorators/auth.decorator';
12
+ import { BaseUserEntity } from '../auth/models/base-user.model';
13
+ import { JwtAuthData } from '../auth/strategies/jwt/jwt-auth-data.model';
14
+ import { JwtCredentials } from '../auth/strategies/jwt/jwt-credentials.model';
15
+ import { JwtAuthStrategy } from '../auth/strategies/jwt/jwt.auth-strategy';
16
+ import { Repository } from '../data-source/repository';
17
+ import { InjectRepository, repositoryTokenFor } from '../di/decorators/inject-repository.decorator';
18
+ import { ZIBRI_DI_TOKENS } from '../di/default/zibri-di-tokens.default';
19
+ import { inject } from '../di/inject.function';
20
+ import { BaseEntity } from '../entity/base-entity.model';
21
+ import { ChangeSetEntity } from './models/change-set-entity.model';
22
+ import { ChangeSetType } from './models/change-set-type.enum';
23
+ import { Entity } from '../entity/decorators/entity.decorator';
24
+ import { Property } from '../entity/decorators/property.decorator';
25
+ import { OmitClass } from '../entity/omit-class.model';
26
+ import { PartialClass } from '../entity/partial-class.model';
27
+ import { Body } from '../routing/decorators/body.decorator';
28
+ import { Controller } from '../routing/decorators/controller.decorator';
29
+ import { Delete } from '../routing/decorators/delete.decorator';
30
+ import { Param } from '../routing/decorators/param.decorator';
31
+ import { Patch } from '../routing/decorators/patch.decorator';
32
+ import { Post } from '../routing/decorators/post.decorator';
33
+ import { JsonUtilities } from '../utilities/json.utilities';
34
+
35
+ // ---- Test entity that extends ChangeSetEntity ----
36
+ @Entity()
37
+ class Widget extends BaseEntity implements ChangeSetEntity {
38
+ @Property.string()
39
+ name!: string;
40
+
41
+ @Property.number()
42
+ value!: number;
43
+
44
+ @Property.string({ excludeFromChangeSets: true })
45
+ internalNote!: string;
46
+
47
+ // required by ChangeSetEntity
48
+ @Property.oneToMany({ target: () => ChangeSet, inverseSide: 'changeSetEntityId' }) // dummy, real implementation may differ
49
+ changeSets!: ChangeSet[];
50
+ }
51
+
52
+ class CreateWidgetDto extends OmitClass(Widget, ['changeSets', 'id']) {}
53
+
54
+ class UpdateWidgetDto extends PartialClass(OmitClass(Widget, ['changeSets', 'id'])) {}
55
+
56
+ @Entity()
57
+ class TestUser extends BaseUserEntity(Roles) {
58
+ @Property.string({ hash: true })
59
+ password!: string;
60
+ }
61
+
62
+ // ---- Controller that uses the repository ----
63
+ @Controller('/widgets')
64
+ class WidgetController {
65
+ constructor(
66
+ @InjectRepository(Widget)
67
+ private readonly repo: ChangeSetRepository<Widget>
68
+ ) {}
69
+
70
+ @Post('/')
71
+ @Auth.isLoggedIn([JwtAuthStrategy])
72
+ async create(@Body(CreateWidgetDto) body: CreateWidgetDto): Promise<Widget> {
73
+ return await this.repo.create(body);
74
+ }
75
+
76
+ @Patch('/:id')
77
+ @Auth.isLoggedIn([JwtAuthStrategy])
78
+ async update(@Param.path('id') id: string, @Body(UpdateWidgetDto) body: UpdateWidgetDto): Promise<Widget> {
79
+ return this.repo.updateById(id, body);
80
+ }
81
+
82
+ @Delete('/:id')
83
+ @Auth.isLoggedIn([JwtAuthStrategy])
84
+ async delete(@Param.path('id') id: string): Promise<Widget> {
85
+ return this.repo.deleteById(id);
86
+ }
87
+
88
+ @Post('/:id/reset/:changeSetId')
89
+ @Auth.isLoggedIn([JwtAuthStrategy])
90
+ async resetSingle(
91
+ @Param.path('id') id: string,
92
+ @Param.path('changeSetId') changeSetId: string
93
+ ): Promise<ResetChangeSetResult<Widget>> {
94
+ const entity: Widget = await this.repo.findById(id);
95
+ return this.repo.resetSingleChangeSet(entity, changeSetId);
96
+ }
97
+
98
+ @Post('/:id/rollback/:changeSetId')
99
+ @Auth.isLoggedIn([JwtAuthStrategy])
100
+ async rollbackTo(
101
+ @Param.path('id') id: string,
102
+ @Param.path('changeSetId') changeSetId: string
103
+ ): Promise<Widget> {
104
+ const entity: Widget = await this.repo.findById(id);
105
+ return this.repo.rollbackToChangeSet(entity, changeSetId);
106
+ }
107
+ }
108
+
109
+ let server: StartedTestServer;
110
+ let baseUrl: string;
111
+ let accessToken: string;
112
+ let userId: string;
113
+
114
+ let changeSetRepo: Repository<ChangeSet, CreateChangeSetData>;
115
+ let changeRepo: Repository<Change>;
116
+ let widgetRepo: ChangeSetRepository<Widget>;
117
+
118
+ beforeAll(async () => {
119
+ server = await startTestServer({
120
+ dataSources: [
121
+ createTestDataSource({
122
+ entities: [...defaultTestServerEntities, Widget, TestUser]
123
+ })
124
+ ],
125
+ controllers: [WidgetController]
126
+ });
127
+ baseUrl = await server.start();
128
+
129
+ // Inject repository instances
130
+ changeSetRepo = inject(repositoryTokenFor(ChangeSet));
131
+ changeRepo = inject(repositoryTokenFor(Change));
132
+ widgetRepo = inject(repositoryTokenFor(Widget)) as ChangeSetRepository<Widget>;
133
+
134
+ // Create a user and login to get a token
135
+ const userRepo: DefaultTestServerUserRepository = inject(DefaultTestServerUserRepository);
136
+ const credentialsRepo: Repository<JwtCredentials> = inject(repositoryTokenFor(JwtCredentials));
137
+
138
+ const testEmail: string = 'widget-test@example.com';
139
+ const testPassword: string = 'test123';
140
+ await userRepo.create({ email: testEmail, roles: [Roles.USER] });
141
+ await credentialsRepo.create({ email: testEmail, password: testPassword, userId: (await userRepo.findOne({ where: { email: testEmail } }, true)).id });
142
+
143
+ userId = (await userRepo.findOne({ where: { email: testEmail } }, true)).id;
144
+
145
+ const authService: AuthServiceInterface = inject(ZIBRI_DI_TOKENS.AUTH_SERVICE);
146
+ const authData: JwtAuthData<Roles> = await authService.login(JwtAuthStrategy<Roles>, { email: testEmail, password: testPassword });
147
+ accessToken = authData.accessToken.value;
148
+ }, 15000);
149
+
150
+ afterAll(async () => {
151
+ await server.shutdown();
152
+ });
153
+
154
+ beforeEach(async () => {
155
+ await changeSetRepo.deleteAll({});
156
+ await changeRepo.deleteAll({});
157
+ await widgetRepo.deleteAll({});
158
+ });
159
+
160
+ // Helper for authorized requests
161
+ async function authFetch(path: string, options: RequestInit = {}): Promise<Response> {
162
+ const res: Response = await fetch(`${baseUrl}${path}`, {
163
+ ...options,
164
+ headers: {
165
+ ...options.headers,
166
+ Authorization: `Bearer ${accessToken}`,
167
+ 'Content-Type': 'application/json'
168
+ }
169
+ });
170
+
171
+ if (!res.ok) {
172
+ const body: unknown = await res.json();
173
+ throw new Error(`Request "${options.method ?? 'GET'} ${path}" failed:\n${JsonUtilities.stringify(body, undefined, 4)}`);
174
+ }
175
+
176
+ return res;
177
+ }
178
+
179
+ describe('ChangeSetRepository behavior', () => {
180
+ describe('on create', () => {
181
+ it('creates a CREATE change set with correct changes (excluding internalNote)', async () => {
182
+ const res: Response = await authFetch('/widgets', {
183
+ method: 'POST',
184
+ body: JSON.stringify({ name: 'TestWidget', value: 42, internalNote: 'secret' })
185
+ });
186
+ expect(res.status).toBe(200);
187
+ const widget: Widget = await res.json() as Widget;
188
+
189
+ const changeSets: ChangeSet[] = await changeSetRepo.findAll({ where: { changeSetEntityId: widget.id } });
190
+ expect(changeSets).toHaveLength(1);
191
+ const cs: ChangeSet = changeSets[0];
192
+ expect(cs.type).toBe(ChangeSetType.CREATE);
193
+ expect(cs.createdBy).toBe(userId);
194
+
195
+ const changes: Change[] = await changeRepo.findAll({ where: { changeSetId: cs.id } });
196
+ expect(changes).toHaveLength(3); // id, name and value. not internalNote
197
+ expect(changes.map(c => c.key).sort()).toEqual(['id', 'name', 'value']);
198
+ expect(changes.find(c => c.key === 'name')?.previousValue).toBeNull();
199
+ expect(changes.find(c => c.key === 'name')?.newValue).toBe('TestWidget');
200
+ });
201
+ });
202
+
203
+ describe('on update', () => {
204
+ let widgetId: string;
205
+
206
+ beforeEach(async () => {
207
+ const res: Response = await authFetch('/widgets', {
208
+ method: 'POST',
209
+ body: JSON.stringify({ name: 'Original', value: 100, internalNote: 'old-secret' })
210
+ });
211
+ const widget: Widget = await res.json() as Widget;
212
+ widgetId = widget.id;
213
+ // clear change sets from creation to isolate update test
214
+ await changeSetRepo.deleteAll({});
215
+ });
216
+
217
+ it('creates an UPDATE change set only with changed fields', async () => {
218
+ await authFetch(`/widgets/${widgetId}`, {
219
+ method: 'PATCH',
220
+ body: JSON.stringify({ name: 'Updated', value: 100 }) // value unchanged
221
+ });
222
+
223
+ const changeSets: ChangeSet[] = await changeSetRepo.findAll({ where: { changeSetEntityId: widgetId } });
224
+ expect(changeSets).toHaveLength(1);
225
+ expect(changeSets[0].type).toBe(ChangeSetType.UPDATE);
226
+
227
+ const changes: Change[] = await changeRepo.findAll({ where: { changeSetId: changeSets[0].id } });
228
+ expect(changes).toHaveLength(1); // only name changed
229
+ expect(changes[0].key).toBe('name');
230
+ expect(changes[0].previousValue).toBe('Original');
231
+ expect(changes[0].newValue).toBe('Updated');
232
+ });
233
+
234
+ it('does not create a change set when no values actually change', async () => {
235
+ await authFetch(`/widgets/${widgetId}`, {
236
+ method: 'PATCH',
237
+ body: JSON.stringify({ name: 'Original', value: 100 })
238
+ });
239
+
240
+ const changeSets: ChangeSet[] = await changeSetRepo.findAll({ where: { changeSetEntityId: widgetId } });
241
+ expect(changeSets).toHaveLength(0);
242
+ });
243
+ });
244
+
245
+ describe('resetSingleChangeSet', () => {
246
+ let widgetId: string;
247
+ let nameUpdateChangeSetId: string;
248
+
249
+ beforeEach(async () => {
250
+ // Create widget, this causes
251
+ const res1: Response = await authFetch('/widgets', {
252
+ method: 'POST',
253
+ body: JSON.stringify({ name: 'Initial', value: 10, internalNote: 'test' })
254
+ });
255
+ const w: Widget = await res1.json() as Widget;
256
+ widgetId = w.id;
257
+
258
+ // First update: change name
259
+ await authFetch(`/widgets/${widgetId}`, { method: 'PATCH', body: JSON.stringify({ name: 'FirstEdit' }) });
260
+
261
+ // Second update: change value
262
+ await authFetch(`/widgets/${widgetId}`, { method: 'PATCH', body: JSON.stringify({ value: 20 }) });
263
+
264
+ const sets: ChangeSet[] = await changeSetRepo.findAll({
265
+ where: { changeSetEntityId: widgetId },
266
+ order: { createdAt: 'ASC' },
267
+ relations: ['changes']
268
+ });
269
+ // sets[0] = CREATE, sets[1] = UPDATE name, sets[2] = UPDATE value
270
+ nameUpdateChangeSetId = sets[1].id; // target the name update
271
+ });
272
+
273
+ it('reverts only the targeted change, preserving later changes', async () => {
274
+ await authFetch(`/widgets/${widgetId}/reset/${nameUpdateChangeSetId}`, { method: 'POST' });
275
+
276
+ const widget: Widget = await widgetRepo.findById(widgetId);
277
+ expect(widget.name).toBe('Initial'); // reverted
278
+ expect(widget.value).toBe(20); // preserved (later change untouched)
279
+
280
+ // A new RESET change set was created
281
+ const allSets: ChangeSet[] = await changeSetRepo.findAll({ where: { changeSetEntityId: widgetId } });
282
+ expect(allSets.some(s => s.type === ChangeSetType.RESET)).toBe(true);
283
+ });
284
+ });
285
+
286
+ describe('rollbackToChangeSet', () => {
287
+ let widgetId: string;
288
+ let createSetId: string;
289
+
290
+ beforeEach(async () => {
291
+ const res: Response = await authFetch('/widgets', {
292
+ method: 'POST',
293
+ body: JSON.stringify({ name: 'Base', value: 1, internalNote: 'base' })
294
+ });
295
+ const w: Widget = await res.json() as Widget;
296
+ widgetId = w.id;
297
+ createSetId = (await changeSetRepo.findOne({ where: { changeSetEntityId: widgetId, type: ChangeSetType.CREATE } }, true)).id;
298
+
299
+ // Two subsequent updates
300
+ await authFetch(`/widgets/${widgetId}`, { method: 'PATCH', body: JSON.stringify({ name: 'Version2' }) });
301
+ await authFetch(`/widgets/${widgetId}`, { method: 'PATCH', body: JSON.stringify({ value: 99 }) });
302
+ });
303
+
304
+ it('rolls back all changes after the given change set', async () => {
305
+ await authFetch(`/widgets/${widgetId}/rollback/${createSetId}`, { method: 'POST' });
306
+
307
+ const widget: Widget = await widgetRepo.findById(widgetId);
308
+ expect(widget.name).toBe('Base');
309
+ expect(widget.value).toBe(1);
310
+
311
+ // Only the CREATE and the new RESET change set remain (intermediate ones deleted)
312
+ const remaining: ChangeSet[] = await changeSetRepo.findAll({ where: { changeSetEntityId: widgetId } });
313
+ expect(remaining).toHaveLength(2);
314
+ expect(remaining.map(s => s.type)).toEqual(expect.arrayContaining([ChangeSetType.CREATE, ChangeSetType.RESET]));
315
+ });
316
+ });
317
+ });
@@ -8,6 +8,7 @@ import { ChangeSetType } from './models/change-set-type.enum';
8
8
  import { ChangeSet, CreateChangeSetData } from './models/change-set.model';
9
9
  import { NewChange } from './models/change.model';
10
10
  import { BaseUser } from '../auth/models/base-user.model';
11
+ import { AlsUtilities } from '../context/als.utilities';
11
12
  import { HttpRequestContext } from '../context/request/http-request.context';
12
13
  import { WebsocketRequestContext } from '../context/request/websocket-request.context';
13
14
  import { DataSourceInterface } from '../data-source/data-sources/data-source.interface';
@@ -20,9 +21,6 @@ import { UpdateAllOptions } from '../data-source/models/options/update-all-optio
20
21
  import { UpdateByIdOptions } from '../data-source/models/options/update-by-id-options.model';
21
22
  import { Where } from '../data-source/models/where/where-filter.model';
22
23
  import { Repository } from '../data-source/repository';
23
- import { repositoryTokenFor } from '../di/decorators/inject-repository.decorator';
24
- import { ZIBRI_DI_TOKENS } from '../di/default/zibri-di-tokens.default';
25
- import { inject } from '../di/inject.function';
26
24
  import { PropertyMetadata } from '../entity/decorators/property.decorator';
27
25
  import { BadRequestError } from '../error-handling/errors/bad-request.error';
28
26
  import { removeExcludeProperties } from '../global/model-registry/remove-exclude-properties.function';
@@ -64,22 +62,19 @@ export class ChangeSetRepository<
64
62
  */
65
63
  protected readonly keysToExcludeFromChangeSets: Set<keyof T> = new Set();
66
64
 
67
- private readonly changeSetRepository: Repository<ChangeSet, CreateChangeSetData>;
68
- private readonly authService: AuthServiceInterface;
69
-
70
65
  constructor(
71
66
  entityClass: Newable<T>,
72
67
  repo: TORepository<T> | Repository<T>,
73
68
  logger: LoggerInterface,
74
69
  dataSource: DataSourceInterface,
75
70
  beforeSave: BeforeSaveHook<T, CreateData, UpdateData>,
76
- beforeReturn: BeforeReturnHook<T>
71
+ beforeReturn: BeforeReturnHook<T>,
72
+ private readonly authService: AuthServiceInterface,
73
+ private readonly changeSetRepository: Repository<ChangeSet, CreateChangeSetData>
74
+
77
75
  ) {
78
76
  super(entityClass, repo, logger, dataSource, beforeSave, beforeReturn);
79
77
 
80
- this.authService = inject(ZIBRI_DI_TOKENS.AUTH_SERVICE);
81
- this.changeSetRepository = inject(repositoryTokenFor(ChangeSet));
82
-
83
78
  this.keysToExcludeFromChangeSets.add('changeSets');
84
79
  const props: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(entityClass);
85
80
  for (const [key, m] of ObjectUtilities.entries(props)) {
@@ -102,14 +97,16 @@ export class ChangeSetRepository<
102
97
  }
103
98
 
104
99
  override async updateById(id: T['id'], data: UpdateData, options?: UpdateByIdOptions): Promise<T> {
100
+ const original: T = await this.findById(id, options);
105
101
  const res: T = await super.updateById(id, data, options);
106
- await this.createChangeSet(res, data, ChangeSetType.UPDATE, options);
102
+ await this.createChangeSet(original, data, ChangeSetType.UPDATE, options);
107
103
  return res;
108
104
  }
109
105
 
110
106
  override async updateAll(where: Where<T>, data: UpdateData, options?: UpdateAllOptions): Promise<T[]> {
107
+ const original: T[] = await this.findAll({ where, ...options });
111
108
  const res: T[] = await super.updateAll(where, data, options);
112
- await this.createAllChangeSets(res, res.map(() => data), ChangeSetType.UPDATE, options);
109
+ await this.createAllChangeSets(original, original.map(() => data), ChangeSetType.UPDATE, options);
113
110
  return res;
114
111
  }
115
112
 
@@ -275,8 +272,7 @@ export class ChangeSetRepository<
275
272
  ): Promise<T> {
276
273
  const changeSets: ChangeSet[] = await this.changeSetRepository.findAll({
277
274
  where: { changeSetEntityId: entity.id, createdAt: { greaterThan: timestampInNs } },
278
- relations: ['changes'],
279
- order: { createdAt: 'ASC' }
275
+ relations: ['changes']
280
276
  });
281
277
  let data: DeepPartial<T> = {} as DeepPartial<T>;
282
278
  for (const changeSet of changeSets) {
@@ -455,9 +451,9 @@ export class ChangeSetRepository<
455
451
  * @returns The id of the currently logged in user or undefined if that didn't work.
456
452
  */
457
453
  protected async getCreatedBy(): Promise<string | undefined> {
458
- const context: HttpRequestContext | WebsocketRequestContext | undefined = inject(ZIBRI_DI_TOKENS.CURRENT_REQUEST_CONTEXT);
454
+ const context: HttpRequestContext | WebsocketRequestContext | undefined = AlsUtilities.getCurrentRequestContext();
459
455
  if (!context) {
460
- throw new Error('No request in context');
456
+ return undefined;
461
457
  }
462
458
  const user: BaseUser<string> | undefined = await this.authService.getCurrentUser(
463
459
  context,
@@ -477,7 +473,11 @@ export class ChangeSetRepository<
477
473
  ): (keyof (CreateData | UpdateData | DeepPartial<T>))[] {
478
474
  const keys: (keyof (CreateData | UpdateData | DeepPartial<T>))[] = [];
479
475
  for (const key in data) {
480
- if (!this.keysToExcludeFromChangeSets.has(key as keyof T)) {
476
+ if (
477
+ !this.keysToExcludeFromChangeSets.has(key as keyof T)
478
+ // we need to use triple equals here, setting a value to null is valid and should be tracked
479
+ && data[key as keyof (CreateData | UpdateData | DeepPartial<T>)] !== undefined
480
+ ) {
481
481
  keys.push(key as keyof (CreateData | UpdateData | DeepPartial<T>));
482
482
  }
483
483
  }
@@ -1,5 +1,6 @@
1
1
  import { ChangeSet } from './change-set.model';
2
2
  import { BaseEntity } from '../../entity/base-entity.model';
3
+ import { Property } from '../../entity/decorators/property.decorator';
3
4
  import { Newable } from '../../types/newable.type';
4
5
  import { MetadataUtilities } from '../../utilities/metadata.utilities';
5
6
 
@@ -7,12 +8,13 @@ import { MetadataUtilities } from '../../utilities/metadata.utilities';
7
8
  * An entity that can be handled by the ChangeSetRepository.
8
9
  * Has an uuid id and a relation to all its changeSets.
9
10
  */
10
- export type ChangeSetEntity = BaseEntity & {
11
+ export class ChangeSetEntity extends BaseEntity {
11
12
  /**
12
13
  * The change sets of the entity.
13
14
  */
14
- changeSets: ChangeSet[]
15
- };
15
+ @Property.oneToMany({ target: () => ChangeSet, inverseSide: 'changeSetEntityId' })
16
+ changeSets!: ChangeSet[];
17
+ }
16
18
 
17
19
  /**
18
20
  * Checks whether the given class is a ChangeSetEntity class.
@@ -20,5 +22,5 @@ export type ChangeSetEntity = BaseEntity & {
20
22
  * @returns True if it has a changeSets property of type array.
21
23
  */
22
24
  export function isChangeSetEntityNewable(cls: Newable<unknown>): cls is Newable<ChangeSetEntity> {
23
- return MetadataUtilities.getModelProperties(cls)['changeSets']?.type === 'array';
25
+ return MetadataUtilities.getModelProperties(cls)['changeSets'] !== undefined;
24
26
  }
@@ -10,7 +10,7 @@ import { OmitStrict } from '../../types/omit-strict.type';
10
10
  * A single change set.
11
11
  * Gets automatically created for configured entities whenever they are changed.
12
12
  */
13
- @Entity()
13
+ @Entity({ defaultOrder: { createdAt: 'ASC' }, defaultRelations: { changes: true } })
14
14
  export class ChangeSet extends BaseEntity {
15
15
  /**
16
16
  * Whether this change set was initialized on creating, updating or deleting the entity.
@@ -26,7 +26,7 @@ export class ChangeSet extends BaseEntity {
26
26
  * The id of the user that changed something.
27
27
  */
28
28
  @Property.string({ format: 'uuid', required: false })
29
- createdBy?: string;
29
+ createdBy?: string | null;
30
30
  /**
31
31
  * The things that have been changed.
32
32
  */