zibri 2.4.0 → 2.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (517) hide show
  1. package/dist/cjs/application.d.ts.map +1 -1
  2. package/dist/cjs/application.js +8 -2
  3. package/dist/cjs/application.js.map +1 -1
  4. package/dist/cjs/auth/encryption/encryption-key.model.d.ts +5 -1
  5. package/dist/cjs/auth/encryption/encryption-key.model.d.ts.map +1 -1
  6. package/dist/cjs/auth/encryption/encryption-key.model.js +9 -1
  7. package/dist/cjs/auth/encryption/encryption-key.model.js.map +1 -1
  8. package/dist/cjs/auth/strategies/cookie/cookie-auth.auth-strategy.d.ts.map +1 -1
  9. package/dist/cjs/auth/strategies/cookie/cookie-auth.auth-strategy.js.map +1 -1
  10. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.d.ts +5 -1
  11. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.d.ts.map +1 -1
  12. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.js +9 -1
  13. package/dist/cjs/auth/strategies/jwt/jwt-credentials.model.js.map +1 -1
  14. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.d.ts.map +1 -1
  15. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.js +2 -1
  16. package/dist/cjs/auth/strategies/jwt/jwt.auth-strategy.js.map +1 -1
  17. package/dist/cjs/backup/backup-resource-entity.model.d.ts +5 -1
  18. package/dist/cjs/backup/backup-resource-entity.model.d.ts.map +1 -1
  19. package/dist/cjs/backup/backup-resource-entity.model.js +9 -1
  20. package/dist/cjs/backup/backup-resource-entity.model.js.map +1 -1
  21. package/dist/cjs/backup/backup.service.js +2 -2
  22. package/dist/cjs/backup/backup.service.js.map +1 -1
  23. package/dist/cjs/caching/cache/base-cache.model.js.map +1 -1
  24. package/dist/cjs/caching/cache/multi-tier.cache.js.map +1 -1
  25. package/dist/cjs/caching/cache/read-aside/read-aside.cache.js.map +1 -1
  26. package/dist/cjs/caching/cache/read-aside/write-around-read-aside.cache.js.map +1 -1
  27. package/dist/cjs/caching/cache/read-aside/write-behind-read-aside.cache.js.map +1 -1
  28. package/dist/cjs/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.js.map +1 -1
  29. package/dist/cjs/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.js.map +1 -1
  30. package/dist/cjs/caching/cache/read-aside/write-through-read-aside.cache.js.map +1 -1
  31. package/dist/cjs/caching/cache/read-through/read-through.cache.js.map +1 -1
  32. package/dist/cjs/caching/cache/read-through/write-around-read-through.cache.js.map +1 -1
  33. package/dist/cjs/caching/cache/read-through/write-behind-read-through.cache.js.map +1 -1
  34. package/dist/cjs/caching/cache/read-through/write-invalidate-read-through-args-only.cache.js.map +1 -1
  35. package/dist/cjs/caching/cache/read-through/write-invalidate-read-through-with-result.cache.js.map +1 -1
  36. package/dist/cjs/caching/cache/read-through/write-through-read-through.cache.js.map +1 -1
  37. package/dist/cjs/change-sets/change-set-repository.d.ts +5 -3
  38. package/dist/cjs/change-sets/change-set-repository.d.ts.map +1 -1
  39. package/dist/cjs/change-sets/change-set-repository.js +16 -16
  40. package/dist/cjs/change-sets/change-set-repository.js.map +1 -1
  41. package/dist/cjs/change-sets/models/change-set-entity.model.d.ts +2 -2
  42. package/dist/cjs/change-sets/models/change-set-entity.model.d.ts.map +1 -1
  43. package/dist/cjs/change-sets/models/change-set-entity.model.js +29 -1
  44. package/dist/cjs/change-sets/models/change-set-entity.model.js.map +1 -1
  45. package/dist/cjs/change-sets/models/change-set.model.js +1 -1
  46. package/dist/cjs/change-sets/models/change-set.model.js.map +1 -1
  47. package/dist/cjs/change-sets/models/change.model.d.ts +5 -1
  48. package/dist/cjs/change-sets/models/change.model.d.ts.map +1 -1
  49. package/dist/cjs/change-sets/models/change.model.js +9 -1
  50. package/dist/cjs/change-sets/models/change.model.js.map +1 -1
  51. package/dist/cjs/change-sets/models/soft-delete-entity.model.d.ts +2 -2
  52. package/dist/cjs/change-sets/models/soft-delete-entity.model.d.ts.map +1 -1
  53. package/dist/cjs/change-sets/models/soft-delete-entity.model.js +26 -0
  54. package/dist/cjs/change-sets/models/soft-delete-entity.model.js.map +1 -1
  55. package/dist/cjs/change-sets/soft-delete-repository.d.ts +6 -5
  56. package/dist/cjs/change-sets/soft-delete-repository.d.ts.map +1 -1
  57. package/dist/cjs/change-sets/soft-delete-repository.js +22 -6
  58. package/dist/cjs/change-sets/soft-delete-repository.js.map +1 -1
  59. package/dist/cjs/context/als.utilities.d.ts +3 -3
  60. package/dist/cjs/context/als.utilities.d.ts.map +1 -1
  61. package/dist/cjs/context/als.utilities.js.map +1 -1
  62. package/dist/cjs/context/cache/cache.context.d.ts +27 -0
  63. package/dist/cjs/context/cache/cache.context.d.ts.map +1 -0
  64. package/dist/cjs/context/cache/cache.context.js +61 -0
  65. package/dist/cjs/context/cache/cache.context.js.map +1 -0
  66. package/dist/cjs/data-source/data-sources/data-source-initialization.error.d.ts +7 -0
  67. package/dist/cjs/data-source/data-sources/data-source-initialization.error.d.ts.map +1 -0
  68. package/dist/cjs/data-source/data-sources/data-source-initialization.error.js +14 -0
  69. package/dist/cjs/data-source/data-sources/data-source-initialization.error.js.map +1 -0
  70. package/dist/cjs/data-source/data-sources/data-source.interface.d.ts +9 -1
  71. package/dist/cjs/data-source/data-sources/data-source.interface.d.ts.map +1 -1
  72. package/dist/cjs/data-source/data-sources/data-source.interface.js.map +1 -1
  73. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.d.ts +44 -0
  74. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.d.ts.map +1 -0
  75. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.js +289 -0
  76. package/dist/cjs/data-source/data-sources/postgres-typeorm-data-source.model.js.map +1 -0
  77. package/dist/cjs/data-source/data-sources/sql-data-source.interface.d.ts +32 -0
  78. package/dist/cjs/data-source/data-sources/sql-data-source.interface.d.ts.map +1 -0
  79. package/dist/cjs/{entity/models/one-to-one-property-metadata.model.js → data-source/data-sources/sql-data-source.interface.js} +1 -1
  80. package/dist/cjs/data-source/data-sources/sql-data-source.interface.js.map +1 -0
  81. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.d.ts +156 -0
  82. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.d.ts.map +1 -0
  83. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.js +378 -0
  84. package/dist/cjs/data-source/data-sources/typeorm-base-data-source.model.js.map +1 -0
  85. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.d.ts +25 -0
  86. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.d.ts.map +1 -0
  87. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js +353 -0
  88. package/dist/cjs/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js.map +1 -0
  89. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.d.ts +70 -0
  90. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.d.ts.map +1 -0
  91. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.js +248 -0
  92. package/dist/cjs/data-source/data-sources/where-converter/typeorm-where-filter.converter.js.map +1 -0
  93. package/dist/cjs/data-source/models/options/count-options.model.d.ts +2 -7
  94. package/dist/cjs/data-source/models/options/count-options.model.d.ts.map +1 -1
  95. package/dist/cjs/data-source/models/options/delete-all-options.model.d.ts +2 -4
  96. package/dist/cjs/data-source/models/options/delete-all-options.model.d.ts.map +1 -1
  97. package/dist/cjs/data-source/models/options/find-all-options.model.d.ts +2 -2
  98. package/dist/cjs/data-source/models/options/find-all-options.model.d.ts.map +1 -1
  99. package/dist/cjs/data-source/models/options/find-by-id-options.model.d.ts +1 -6
  100. package/dist/cjs/data-source/models/options/find-by-id-options.model.d.ts.map +1 -1
  101. package/dist/cjs/data-source/models/options/find-one-options.model.d.ts +2 -11
  102. package/dist/cjs/data-source/models/options/find-one-options.model.d.ts.map +1 -1
  103. package/dist/cjs/data-source/models/options/update-all-options.model.d.ts +1 -7
  104. package/dist/cjs/data-source/models/options/update-all-options.model.d.ts.map +1 -1
  105. package/dist/cjs/data-source/models/options/update-by-id-options.model.d.ts +1 -7
  106. package/dist/cjs/data-source/models/options/update-by-id-options.model.d.ts.map +1 -1
  107. package/dist/cjs/data-source/models/where/array-where-filter.model.d.ts +142 -3
  108. package/dist/cjs/data-source/models/where/array-where-filter.model.d.ts.map +1 -1
  109. package/dist/cjs/data-source/models/where/base-where-filter.model.d.ts +18 -1
  110. package/dist/cjs/data-source/models/where/base-where-filter.model.d.ts.map +1 -1
  111. package/dist/cjs/data-source/models/where/boolean-where-filter.model.d.ts +4 -2
  112. package/dist/cjs/data-source/models/where/boolean-where-filter.model.d.ts.map +1 -1
  113. package/dist/cjs/data-source/models/where/date-where-filter.model.d.ts +8 -15
  114. package/dist/cjs/data-source/models/where/date-where-filter.model.d.ts.map +1 -1
  115. package/dist/cjs/data-source/models/where/number-where-filter.model.d.ts +8 -15
  116. package/dist/cjs/data-source/models/where/number-where-filter.model.d.ts.map +1 -1
  117. package/dist/cjs/data-source/models/where/object-where-filter.model.d.ts +52 -7
  118. package/dist/cjs/data-source/models/where/object-where-filter.model.d.ts.map +1 -1
  119. package/dist/cjs/data-source/models/where/string-where-filter.model.d.ts +8 -15
  120. package/dist/cjs/data-source/models/where/string-where-filter.model.d.ts.map +1 -1
  121. package/dist/cjs/data-source/models/where/where-filter-keys.model.d.ts +46 -0
  122. package/dist/cjs/data-source/models/where/where-filter-keys.model.d.ts.map +1 -0
  123. package/dist/cjs/data-source/models/where/where-filter-keys.model.js +36 -0
  124. package/dist/cjs/data-source/models/where/where-filter-keys.model.js.map +1 -0
  125. package/dist/cjs/data-source/models/where/where-filter.model.d.ts +2 -2
  126. package/dist/cjs/data-source/models/where/where-filter.model.d.ts.map +1 -1
  127. package/dist/cjs/data-source/query-failed.error.js +27 -1
  128. package/dist/cjs/data-source/query-failed.error.js.map +1 -1
  129. package/dist/cjs/data-source/repository.d.ts +8 -3
  130. package/dist/cjs/data-source/repository.d.ts.map +1 -1
  131. package/dist/cjs/data-source/repository.js +42 -16
  132. package/dist/cjs/data-source/repository.js.map +1 -1
  133. package/dist/cjs/di/decorators/inject-repository.decorator.d.ts +2 -2
  134. package/dist/cjs/di/decorators/inject-repository.decorator.d.ts.map +1 -1
  135. package/dist/cjs/di/decorators/inject-repository.decorator.js.map +1 -1
  136. package/dist/cjs/di/default/zibri-di-tokens.default.d.ts +2 -2
  137. package/dist/cjs/di/default/zibri-di-tokens.default.d.ts.map +1 -1
  138. package/dist/cjs/di/default/zibri-di-tokens.default.js.map +1 -1
  139. package/dist/cjs/email/email.service.d.ts +2 -2
  140. package/dist/cjs/email/email.service.d.ts.map +1 -1
  141. package/dist/cjs/email/email.service.js +4 -6
  142. package/dist/cjs/email/email.service.js.map +1 -1
  143. package/dist/cjs/email/models/email.model.js +1 -1
  144. package/dist/cjs/email/models/email.model.js.map +1 -1
  145. package/dist/cjs/entity/decorators/entity.decorator.d.ts +28 -1
  146. package/dist/cjs/entity/decorators/entity.decorator.d.ts.map +1 -1
  147. package/dist/cjs/entity/decorators/entity.decorator.js +6 -3
  148. package/dist/cjs/entity/decorators/entity.decorator.js.map +1 -1
  149. package/dist/cjs/entity/decorators/property.decorator.d.ts +5 -8
  150. package/dist/cjs/entity/decorators/property.decorator.d.ts.map +1 -1
  151. package/dist/cjs/entity/decorators/property.decorator.js +34 -20
  152. package/dist/cjs/entity/decorators/property.decorator.js.map +1 -1
  153. package/dist/cjs/entity/entity-metadata-missing.error.d.ts +9 -0
  154. package/dist/cjs/entity/entity-metadata-missing.error.d.ts.map +1 -0
  155. package/dist/cjs/entity/entity-metadata-missing.error.js +17 -0
  156. package/dist/cjs/entity/entity-metadata-missing.error.js.map +1 -0
  157. package/dist/cjs/entity/models/base-relation-metadata.model.d.ts +1 -1
  158. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.d.ts +28 -0
  159. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.d.ts.map +1 -0
  160. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.js +3 -0
  161. package/dist/cjs/entity/models/belongs-to-one-property-metadata.model.js.map +1 -0
  162. package/dist/cjs/entity/models/has-one-property-metadata.model.d.ts +18 -0
  163. package/dist/cjs/entity/models/has-one-property-metadata.model.d.ts.map +1 -0
  164. package/dist/{esm/entity/models/one-to-one-property-metadata.model.js → cjs/entity/models/has-one-property-metadata.model.js} +1 -1
  165. package/dist/cjs/entity/models/has-one-property-metadata.model.js.map +1 -0
  166. package/dist/cjs/entity/models/many-to-many-property-metadata.model.d.ts +3 -3
  167. package/dist/cjs/entity/models/many-to-many-property-metadata.model.d.ts.map +1 -1
  168. package/dist/cjs/entity/models/many-to-one-property-metadata.model.d.ts +11 -1
  169. package/dist/cjs/entity/models/many-to-one-property-metadata.model.d.ts.map +1 -1
  170. package/dist/cjs/entity/models/relation.enum.d.ts +2 -1
  171. package/dist/cjs/entity/models/relation.enum.d.ts.map +1 -1
  172. package/dist/cjs/entity/models/relation.enum.js +2 -1
  173. package/dist/cjs/entity/models/relation.enum.js.map +1 -1
  174. package/dist/cjs/entity/partial-class.model.js +1 -1
  175. package/dist/cjs/entity/partial-class.model.js.map +1 -1
  176. package/dist/cjs/event/event-cleanup.cron-job.d.ts.map +1 -1
  177. package/dist/cjs/event/event-cleanup.cron-job.js +4 -6
  178. package/dist/cjs/event/event-cleanup.cron-job.js.map +1 -1
  179. package/dist/cjs/event/event-subscriber-run.model.d.ts +6 -8
  180. package/dist/cjs/event/event-subscriber-run.model.d.ts.map +1 -1
  181. package/dist/cjs/event/event-subscriber-run.model.js +10 -17
  182. package/dist/cjs/event/event-subscriber-run.model.js.map +1 -1
  183. package/dist/cjs/event/event.model.js +1 -1
  184. package/dist/cjs/event/event.model.js.map +1 -1
  185. package/dist/cjs/event/event.service.d.ts.map +1 -1
  186. package/dist/cjs/event/event.service.js +6 -3
  187. package/dist/cjs/event/event.service.js.map +1 -1
  188. package/dist/cjs/global/model-registry/default-descriptor.d.ts.map +1 -1
  189. package/dist/cjs/global/model-registry/default-descriptor.js +2 -1
  190. package/dist/cjs/global/model-registry/default-descriptor.js.map +1 -1
  191. package/dist/cjs/global/model-registry/encryption-descriptor.d.ts.map +1 -1
  192. package/dist/cjs/global/model-registry/encryption-descriptor.js +2 -1
  193. package/dist/cjs/global/model-registry/encryption-descriptor.js.map +1 -1
  194. package/dist/cjs/global/model-registry/exclude-descriptor.d.ts.map +1 -1
  195. package/dist/cjs/global/model-registry/exclude-descriptor.js +2 -1
  196. package/dist/cjs/global/model-registry/exclude-descriptor.js.map +1 -1
  197. package/dist/cjs/global/model-registry/hash-descriptor.d.ts.map +1 -1
  198. package/dist/cjs/global/model-registry/hash-descriptor.js +2 -1
  199. package/dist/cjs/global/model-registry/hash-descriptor.js.map +1 -1
  200. package/dist/cjs/index.d.ts +12 -3
  201. package/dist/cjs/index.d.ts.map +1 -1
  202. package/dist/cjs/index.js +12 -3
  203. package/dist/cjs/index.js.map +1 -1
  204. package/dist/cjs/logging/log-context.model.d.ts +2 -27
  205. package/dist/cjs/logging/log-context.model.d.ts.map +1 -1
  206. package/dist/cjs/logging/log-context.model.js +3 -49
  207. package/dist/cjs/logging/log-context.model.js.map +1 -1
  208. package/dist/cjs/open-api/open-api.service.d.ts.map +1 -1
  209. package/dist/cjs/open-api/open-api.service.js +20 -11
  210. package/dist/cjs/open-api/open-api.service.js.map +1 -1
  211. package/dist/cjs/parsing/form-data/form-data.body-parser.d.ts.map +1 -1
  212. package/dist/cjs/parsing/form-data/form-data.body-parser.js +2 -1
  213. package/dist/cjs/parsing/form-data/form-data.body-parser.js.map +1 -1
  214. package/dist/cjs/parsing/functions/parse-boolean.function.d.ts.map +1 -1
  215. package/dist/cjs/parsing/functions/parse-boolean.function.js.map +1 -1
  216. package/dist/cjs/parsing/functions/parse-object.function.d.ts.map +1 -1
  217. package/dist/cjs/parsing/functions/parse-object.function.js +2 -1
  218. package/dist/cjs/parsing/functions/parse-object.function.js.map +1 -1
  219. package/dist/cjs/parsing/parser.d.ts.map +1 -1
  220. package/dist/cjs/parsing/parser.js +2 -1
  221. package/dist/cjs/parsing/parser.js.map +1 -1
  222. package/dist/cjs/routing/decorators/body.decorator.js +2 -1
  223. package/dist/cjs/routing/decorators/body.decorator.js.map +1 -1
  224. package/dist/cjs/routing/resolve-route-params.function.js +1 -1
  225. package/dist/cjs/routing/resolve-route-params.function.js.map +1 -1
  226. package/dist/cjs/routing/router.d.ts.map +1 -1
  227. package/dist/cjs/routing/router.js +38 -2
  228. package/dist/cjs/routing/router.js.map +1 -1
  229. package/dist/cjs/utilities/metadata-injection-keys.enum.d.ts +1 -0
  230. package/dist/cjs/utilities/metadata-injection-keys.enum.d.ts.map +1 -1
  231. package/dist/cjs/utilities/metadata-injection-keys.enum.js +1 -0
  232. package/dist/cjs/utilities/metadata-injection-keys.enum.js.map +1 -1
  233. package/dist/cjs/utilities/typeorm.utilities.d.ts +39 -0
  234. package/dist/cjs/utilities/typeorm.utilities.d.ts.map +1 -0
  235. package/dist/cjs/utilities/typeorm.utilities.js +47 -0
  236. package/dist/cjs/utilities/typeorm.utilities.js.map +1 -0
  237. package/dist/cjs/validation/validation-problem.model.d.ts.map +1 -1
  238. package/dist/cjs/validation/validation-problem.model.js +4 -7
  239. package/dist/cjs/validation/validation-problem.model.js.map +1 -1
  240. package/dist/cjs/validation/validation.service.d.ts.map +1 -1
  241. package/dist/cjs/validation/validation.service.js +6 -4
  242. package/dist/cjs/validation/validation.service.js.map +1 -1
  243. package/dist/cjs/websocket/models/websocket-message.model.js +1 -1
  244. package/dist/cjs/websocket/models/websocket-message.model.js.map +1 -1
  245. package/dist/cjs/websocket/models/websocket-request.model.d.ts +5 -11
  246. package/dist/cjs/websocket/models/websocket-request.model.d.ts.map +1 -1
  247. package/dist/cjs/websocket/models/websocket-request.model.js.map +1 -1
  248. package/dist/cjs/websocket/services/websocket.service.d.ts.map +1 -1
  249. package/dist/cjs/websocket/services/websocket.service.js +1 -2
  250. package/dist/cjs/websocket/services/websocket.service.js.map +1 -1
  251. package/dist/esm/application.js +8 -2
  252. package/dist/esm/application.js.map +1 -1
  253. package/dist/esm/auth/encryption/encryption-key.model.js +9 -1
  254. package/dist/esm/auth/encryption/encryption-key.model.js.map +1 -1
  255. package/dist/esm/auth/strategies/cookie/cookie-auth.auth-strategy.js.map +1 -1
  256. package/dist/esm/auth/strategies/jwt/jwt-credentials.model.js +9 -1
  257. package/dist/esm/auth/strategies/jwt/jwt-credentials.model.js.map +1 -1
  258. package/dist/esm/auth/strategies/jwt/jwt.auth-strategy.js +2 -1
  259. package/dist/esm/auth/strategies/jwt/jwt.auth-strategy.js.map +1 -1
  260. package/dist/esm/backup/backup-resource-entity.model.js +9 -1
  261. package/dist/esm/backup/backup-resource-entity.model.js.map +1 -1
  262. package/dist/esm/backup/backup.service.js +2 -2
  263. package/dist/esm/backup/backup.service.js.map +1 -1
  264. package/dist/esm/caching/cache/base-cache.model.js.map +1 -1
  265. package/dist/esm/caching/cache/multi-tier.cache.js.map +1 -1
  266. package/dist/esm/caching/cache/read-aside/read-aside.cache.js.map +1 -1
  267. package/dist/esm/caching/cache/read-aside/write-around-read-aside.cache.js.map +1 -1
  268. package/dist/esm/caching/cache/read-aside/write-behind-read-aside.cache.js.map +1 -1
  269. package/dist/esm/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.js.map +1 -1
  270. package/dist/esm/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.js.map +1 -1
  271. package/dist/esm/caching/cache/read-aside/write-through-read-aside.cache.js.map +1 -1
  272. package/dist/esm/caching/cache/read-through/read-through.cache.js.map +1 -1
  273. package/dist/esm/caching/cache/read-through/write-around-read-through.cache.js.map +1 -1
  274. package/dist/esm/caching/cache/read-through/write-behind-read-through.cache.js.map +1 -1
  275. package/dist/esm/caching/cache/read-through/write-invalidate-read-through-args-only.cache.js.map +1 -1
  276. package/dist/esm/caching/cache/read-through/write-invalidate-read-through-with-result.cache.js.map +1 -1
  277. package/dist/esm/caching/cache/read-through/write-through-read-through.cache.js.map +1 -1
  278. package/dist/esm/change-sets/change-set-repository.js +16 -16
  279. package/dist/esm/change-sets/change-set-repository.js.map +1 -1
  280. package/dist/esm/change-sets/models/change-set-entity.model.js +29 -1
  281. package/dist/esm/change-sets/models/change-set-entity.model.js.map +1 -1
  282. package/dist/esm/change-sets/models/change-set.model.js +1 -1
  283. package/dist/esm/change-sets/models/change-set.model.js.map +1 -1
  284. package/dist/esm/change-sets/models/change.model.js +9 -1
  285. package/dist/esm/change-sets/models/change.model.js.map +1 -1
  286. package/dist/esm/change-sets/models/soft-delete-entity.model.js +26 -0
  287. package/dist/esm/change-sets/models/soft-delete-entity.model.js.map +1 -1
  288. package/dist/esm/change-sets/soft-delete-repository.js +22 -6
  289. package/dist/esm/change-sets/soft-delete-repository.js.map +1 -1
  290. package/dist/esm/context/als.utilities.js.map +1 -1
  291. package/dist/esm/context/cache/cache.context.js +61 -0
  292. package/dist/esm/context/cache/cache.context.js.map +1 -0
  293. package/dist/esm/data-source/data-sources/data-source-initialization.error.js +14 -0
  294. package/dist/esm/data-source/data-sources/data-source-initialization.error.js.map +1 -0
  295. package/dist/esm/data-source/data-sources/data-source.interface.js.map +1 -1
  296. package/dist/esm/data-source/data-sources/postgres-typeorm-data-source.model.js +289 -0
  297. package/dist/esm/data-source/data-sources/postgres-typeorm-data-source.model.js.map +1 -0
  298. package/dist/esm/data-source/data-sources/sql-data-source.interface.js +3 -0
  299. package/dist/esm/data-source/data-sources/sql-data-source.interface.js.map +1 -0
  300. package/dist/esm/data-source/data-sources/typeorm-base-data-source.model.js +378 -0
  301. package/dist/esm/data-source/data-sources/typeorm-base-data-source.model.js.map +1 -0
  302. package/dist/esm/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js +353 -0
  303. package/dist/esm/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.js.map +1 -0
  304. package/dist/esm/data-source/data-sources/where-converter/typeorm-where-filter.converter.js +248 -0
  305. package/dist/esm/data-source/data-sources/where-converter/typeorm-where-filter.converter.js.map +1 -0
  306. package/dist/esm/data-source/models/where/where-filter-keys.model.js +36 -0
  307. package/dist/esm/data-source/models/where/where-filter-keys.model.js.map +1 -0
  308. package/dist/esm/data-source/query-failed.error.js +27 -1
  309. package/dist/esm/data-source/query-failed.error.js.map +1 -1
  310. package/dist/esm/data-source/repository.js +42 -16
  311. package/dist/esm/data-source/repository.js.map +1 -1
  312. package/dist/esm/di/decorators/inject-repository.decorator.js.map +1 -1
  313. package/dist/esm/di/default/zibri-di-tokens.default.js.map +1 -1
  314. package/dist/esm/email/email.service.js +4 -6
  315. package/dist/esm/email/email.service.js.map +1 -1
  316. package/dist/esm/email/models/email.model.js +1 -1
  317. package/dist/esm/email/models/email.model.js.map +1 -1
  318. package/dist/esm/entity/decorators/entity.decorator.js +6 -3
  319. package/dist/esm/entity/decorators/entity.decorator.js.map +1 -1
  320. package/dist/esm/entity/decorators/property.decorator.js +34 -20
  321. package/dist/esm/entity/decorators/property.decorator.js.map +1 -1
  322. package/dist/esm/entity/entity-metadata-missing.error.js +17 -0
  323. package/dist/esm/entity/entity-metadata-missing.error.js.map +1 -0
  324. package/dist/esm/entity/models/belongs-to-one-property-metadata.model.js +3 -0
  325. package/dist/esm/entity/models/belongs-to-one-property-metadata.model.js.map +1 -0
  326. package/dist/esm/entity/models/has-one-property-metadata.model.js +3 -0
  327. package/dist/esm/entity/models/has-one-property-metadata.model.js.map +1 -0
  328. package/dist/esm/entity/models/relation.enum.js +2 -1
  329. package/dist/esm/entity/models/relation.enum.js.map +1 -1
  330. package/dist/esm/entity/partial-class.model.js +1 -1
  331. package/dist/esm/entity/partial-class.model.js.map +1 -1
  332. package/dist/esm/event/event-cleanup.cron-job.js +4 -6
  333. package/dist/esm/event/event-cleanup.cron-job.js.map +1 -1
  334. package/dist/esm/event/event-subscriber-run.model.js +10 -17
  335. package/dist/esm/event/event-subscriber-run.model.js.map +1 -1
  336. package/dist/esm/event/event.model.js +1 -1
  337. package/dist/esm/event/event.model.js.map +1 -1
  338. package/dist/esm/event/event.service.js +6 -3
  339. package/dist/esm/event/event.service.js.map +1 -1
  340. package/dist/esm/global/model-registry/default-descriptor.js +2 -1
  341. package/dist/esm/global/model-registry/default-descriptor.js.map +1 -1
  342. package/dist/esm/global/model-registry/encryption-descriptor.js +2 -1
  343. package/dist/esm/global/model-registry/encryption-descriptor.js.map +1 -1
  344. package/dist/esm/global/model-registry/exclude-descriptor.js +2 -1
  345. package/dist/esm/global/model-registry/exclude-descriptor.js.map +1 -1
  346. package/dist/esm/global/model-registry/hash-descriptor.js +2 -1
  347. package/dist/esm/global/model-registry/hash-descriptor.js.map +1 -1
  348. package/dist/esm/index.js +12 -3
  349. package/dist/esm/index.js.map +1 -1
  350. package/dist/esm/logging/log-context.model.js +3 -49
  351. package/dist/esm/logging/log-context.model.js.map +1 -1
  352. package/dist/esm/open-api/open-api.service.js +20 -11
  353. package/dist/esm/open-api/open-api.service.js.map +1 -1
  354. package/dist/esm/parsing/form-data/form-data.body-parser.js +2 -1
  355. package/dist/esm/parsing/form-data/form-data.body-parser.js.map +1 -1
  356. package/dist/esm/parsing/functions/parse-boolean.function.js.map +1 -1
  357. package/dist/esm/parsing/functions/parse-object.function.js +2 -1
  358. package/dist/esm/parsing/functions/parse-object.function.js.map +1 -1
  359. package/dist/esm/parsing/parser.js +2 -1
  360. package/dist/esm/parsing/parser.js.map +1 -1
  361. package/dist/esm/routing/decorators/body.decorator.js +2 -1
  362. package/dist/esm/routing/decorators/body.decorator.js.map +1 -1
  363. package/dist/esm/routing/resolve-route-params.function.js +1 -1
  364. package/dist/esm/routing/resolve-route-params.function.js.map +1 -1
  365. package/dist/esm/routing/router.js +38 -2
  366. package/dist/esm/routing/router.js.map +1 -1
  367. package/dist/esm/utilities/metadata-injection-keys.enum.js +1 -0
  368. package/dist/esm/utilities/metadata-injection-keys.enum.js.map +1 -1
  369. package/dist/esm/utilities/typeorm.utilities.js +47 -0
  370. package/dist/esm/utilities/typeorm.utilities.js.map +1 -0
  371. package/dist/esm/validation/validation-problem.model.js +4 -7
  372. package/dist/esm/validation/validation-problem.model.js.map +1 -1
  373. package/dist/esm/validation/validation.service.js +6 -4
  374. package/dist/esm/validation/validation.service.js.map +1 -1
  375. package/dist/esm/websocket/models/websocket-message.model.js +1 -1
  376. package/dist/esm/websocket/models/websocket-message.model.js.map +1 -1
  377. package/dist/esm/websocket/models/websocket-request.model.js.map +1 -1
  378. package/dist/esm/websocket/services/websocket.service.js +1 -2
  379. package/dist/esm/websocket/services/websocket.service.js.map +1 -1
  380. package/package.json +9 -9
  381. package/src/__testing__/mocks/entities/child.entity.ts +4 -1
  382. package/src/__testing__/mocks/entities/company.entity.ts +5 -2
  383. package/src/__testing__/mocks/entities/profile.entity.ts +5 -2
  384. package/src/__testing__/mocks/entities/role.entity.ts +1 -1
  385. package/src/__testing__/mocks/entities/user.entity.ts +1 -1
  386. package/src/__testing__/test-server/create-test-data-source.function.ts +5 -5
  387. package/src/__testing__/test-server/start-test-server.function.ts +8 -6
  388. package/src/__testing__/test-server/user-repository.ts +4 -3
  389. package/src/application.ts +8 -2
  390. package/src/auth/2fa/two-factor.service.test.ts +151 -0
  391. package/src/auth/auth.service.test.ts +381 -0
  392. package/src/auth/encryption/encryption-key.model.ts +7 -2
  393. package/src/auth/strategies/cookie/cookie-auth.auth-strategy.ts +3 -2
  394. package/src/auth/strategies/jwt/jwt-credentials.model.ts +7 -1
  395. package/src/auth/strategies/jwt/jwt.auth-strategy.ts +5 -3
  396. package/src/backup/backup-resource-entity.model.ts +7 -2
  397. package/src/backup/backup-service.test.ts +1 -1
  398. package/src/backup/backup.service.ts +1 -1
  399. package/src/caching/cache/base-cache.model.ts +3 -3
  400. package/src/caching/cache/multi-tier.cache.ts +3 -3
  401. package/src/caching/cache/read-aside/read-aside.cache.ts +2 -2
  402. package/src/caching/cache/read-aside/write-around-read-aside.cache.ts +2 -2
  403. package/src/caching/cache/read-aside/write-behind-read-aside.cache.ts +2 -2
  404. package/src/caching/cache/read-aside/write-invalidate-read-aside-args-only.cache.ts +2 -2
  405. package/src/caching/cache/read-aside/write-invalidate-read-aside-with-result.cache.ts +2 -2
  406. package/src/caching/cache/read-aside/write-through-read-aside.cache.ts +2 -2
  407. package/src/caching/cache/read-through/read-through.cache.ts +2 -2
  408. package/src/caching/cache/read-through/write-around-read-through.cache.ts +2 -2
  409. package/src/caching/cache/read-through/write-behind-read-through.cache.ts +2 -2
  410. package/src/caching/cache/read-through/write-invalidate-read-through-args-only.cache.ts +2 -2
  411. package/src/caching/cache/read-through/write-invalidate-read-through-with-result.cache.ts +2 -2
  412. package/src/caching/cache/read-through/write-through-read-through.cache.ts +2 -2
  413. package/src/change-sets/change-set-repository.test.ts +317 -0
  414. package/src/change-sets/change-set-repository.ts +17 -17
  415. package/src/change-sets/models/change-set-entity.model.ts +6 -4
  416. package/src/change-sets/models/change-set.model.ts +1 -1
  417. package/src/change-sets/models/change.model.ts +7 -2
  418. package/src/change-sets/models/soft-delete-entity.model.ts +5 -3
  419. package/src/change-sets/soft-delete-repository.test.ts +326 -0
  420. package/src/change-sets/soft-delete-repository.ts +29 -10
  421. package/src/context/als.utilities.ts +5 -5
  422. package/src/context/cache/cache.context.ts +33 -0
  423. package/src/cron/cron.test.ts +421 -0
  424. package/src/data-source/array-where-filter.test.ts +332 -0
  425. package/src/data-source/data-sources/data-source-initialization.error.ts +9 -0
  426. package/src/data-source/data-sources/data-source.interface.ts +14 -1
  427. package/src/data-source/data-sources/postgres-typeorm-data-source.model.ts +330 -0
  428. package/src/data-source/data-sources/sql-data-source.interface.ts +35 -0
  429. package/src/data-source/data-sources/typeorm-base-data-source.model.ts +544 -0
  430. package/src/data-source/data-sources/where-converter/postgres-typeorm-where-filter.converter.ts +451 -0
  431. package/src/data-source/data-sources/where-converter/typeorm-where-filter.converter.ts +376 -0
  432. package/src/data-source/exclude-property.test.ts +4 -1
  433. package/src/data-source/hooks/hooks.test.ts +268 -0
  434. package/src/data-source/migration/migration.test.ts +4 -3
  435. package/src/data-source/models/options/count-options.model.ts +2 -7
  436. package/src/data-source/models/options/delete-all-options.model.ts +2 -4
  437. package/src/data-source/models/options/find-all-options.model.ts +2 -2
  438. package/src/data-source/models/options/find-by-id-options.model.ts +1 -6
  439. package/src/data-source/models/options/find-one-options.model.ts +2 -11
  440. package/src/data-source/models/options/update-all-options.model.ts +2 -5
  441. package/src/data-source/models/options/update-by-id-options.model.ts +2 -5
  442. package/src/data-source/models/where/array-where-filter.model.ts +147 -5
  443. package/src/data-source/models/where/base-where-filter.model.ts +19 -1
  444. package/src/data-source/models/where/boolean-where-filter.model.ts +7 -2
  445. package/src/data-source/models/where/date-where-filter.model.ts +9 -16
  446. package/src/data-source/models/where/number-where-filter.model.ts +9 -16
  447. package/src/data-source/models/where/object-where-filter.model.ts +66 -7
  448. package/src/data-source/models/where/string-where-filter.model.ts +9 -16
  449. package/src/data-source/models/where/where-filter-keys.model.ts +88 -0
  450. package/src/data-source/models/where/where-filter-to-find-options-where-function.test.ts +35 -13
  451. package/src/data-source/models/where/where-filter.model.ts +7 -4
  452. package/src/data-source/nested-where-filter.test.ts +344 -0
  453. package/src/data-source/query-failed.error.ts +38 -1
  454. package/src/data-source/repository-relation-pitfalls.test.ts +232 -0
  455. package/src/data-source/repository.test.ts +274 -37
  456. package/src/data-source/repository.ts +50 -16
  457. package/src/data-source/transaction/transaction.test.ts +1 -1
  458. package/src/data-source/where-filter.test.ts +479 -0
  459. package/src/di/decorators/inject-repository.decorator.ts +3 -2
  460. package/src/di/default/zibri-di-tokens.default.ts +2 -2
  461. package/src/email/email.service.test.ts +382 -0
  462. package/src/email/email.service.ts +4 -5
  463. package/src/email/models/email.model.ts +1 -1
  464. package/src/entity/decorators/entity.decorator.ts +44 -5
  465. package/src/entity/decorators/property.decorator.ts +54 -36
  466. package/src/entity/entity-metadata-missing.error.ts +15 -0
  467. package/src/entity/models/base-relation-metadata.model.ts +1 -1
  468. package/src/entity/models/belongs-to-one-property-metadata.model.ts +34 -0
  469. package/src/entity/models/has-one-property-metadata.model.ts +20 -0
  470. package/src/entity/models/many-to-many-property-metadata.model.ts +3 -3
  471. package/src/entity/models/many-to-one-property-metadata.model.ts +17 -3
  472. package/src/entity/models/relation.enum.ts +2 -1
  473. package/src/entity/partial-class.model.ts +1 -1
  474. package/src/event/event-cleanup.cron-job.ts +4 -6
  475. package/src/event/event-subscriber-run.model.ts +8 -9
  476. package/src/event/event.model.ts +1 -1
  477. package/src/event/event.service.ts +6 -3
  478. package/src/global/model-registry/default-descriptor.ts +2 -1
  479. package/src/global/model-registry/encryption-descriptor.ts +2 -1
  480. package/src/global/model-registry/exclude-descriptor.ts +2 -1
  481. package/src/global/model-registry/hash-descriptor.ts +2 -1
  482. package/src/index.ts +15 -3
  483. package/src/logging/log-context.model.ts +3 -34
  484. package/src/open-api/open-api.service.ts +32 -13
  485. package/src/parsing/form-data/form-data.body-parser.ts +2 -1
  486. package/src/parsing/functions/parse-boolean.function.ts +0 -1
  487. package/src/parsing/functions/parse-object.function.ts +2 -1
  488. package/src/parsing/parser.ts +2 -1
  489. package/src/routing/decorators/body.decorator.ts +2 -1
  490. package/src/routing/resolve-route-params.function.ts +1 -1
  491. package/src/routing/router.ts +41 -7
  492. package/src/utilities/metadata-injection-keys.enum.ts +1 -0
  493. package/src/utilities/typeorm.utilities.ts +75 -0
  494. package/src/validation/validation-problem.model.ts +7 -9
  495. package/src/validation/validation.service.ts +6 -4
  496. package/src/websocket/models/websocket-message.model.ts +1 -1
  497. package/src/websocket/models/websocket-request.model.ts +17 -9
  498. package/src/websocket/services/websocket.service.ts +1 -2
  499. package/dist/cjs/data-source/data-sources/postgres-data-source.model.d.ts +0 -129
  500. package/dist/cjs/data-source/data-sources/postgres-data-source.model.d.ts.map +0 -1
  501. package/dist/cjs/data-source/data-sources/postgres-data-source.model.js +0 -534
  502. package/dist/cjs/data-source/data-sources/postgres-data-source.model.js.map +0 -1
  503. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.d.ts +0 -11
  504. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.d.ts.map +0 -1
  505. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.js +0 -229
  506. package/dist/cjs/data-source/models/where/where-filter-to-find-options-where.function.js.map +0 -1
  507. package/dist/cjs/entity/models/one-to-one-property-metadata.model.d.ts +0 -30
  508. package/dist/cjs/entity/models/one-to-one-property-metadata.model.d.ts.map +0 -1
  509. package/dist/cjs/entity/models/one-to-one-property-metadata.model.js.map +0 -1
  510. package/dist/esm/data-source/data-sources/postgres-data-source.model.js +0 -534
  511. package/dist/esm/data-source/data-sources/postgres-data-source.model.js.map +0 -1
  512. package/dist/esm/data-source/models/where/where-filter-to-find-options-where.function.js +0 -229
  513. package/dist/esm/data-source/models/where/where-filter-to-find-options-where.function.js.map +0 -1
  514. package/dist/esm/entity/models/one-to-one-property-metadata.model.js.map +0 -1
  515. package/src/data-source/data-sources/postgres-data-source.model.ts +0 -675
  516. package/src/data-source/models/where/where-filter-to-find-options-where.function.ts +0 -307
  517. package/src/entity/models/one-to-one-property-metadata.model.ts +0 -35
@@ -0,0 +1,479 @@
1
+ /* eslint-disable unicorn/no-null */
2
+ import { afterAll, beforeAll, beforeEach, describe, expect, it } from '@jest/globals';
3
+
4
+ import { createTestDataSource, defaultTestServerEntities } from '../__testing__/test-server/create-test-data-source.function';
5
+ import { startTestServer, StartedTestServer } from '../__testing__/test-server/start-test-server.function';
6
+ import { WhereFilter } from '../data-source/models/where/where-filter.model';
7
+ import { Repository } from '../data-source/repository';
8
+ import { repositoryTokenFor } from '../di/decorators/inject-repository.decorator';
9
+ import { inject } from '../di/inject.function';
10
+ import { BaseEntity } from '../entity/base-entity.model';
11
+ import { Entity } from '../entity/decorators/entity.decorator';
12
+ import { Property } from '../entity/decorators/property.decorator';
13
+ import { DeepPartial } from '../types/deep-partial.type';
14
+
15
+ // ---------- Test entities ----------
16
+
17
+ @Entity()
18
+ class Category extends BaseEntity {
19
+ @Property.string()
20
+ name!: string;
21
+
22
+ @Property.oneToMany({ target: () => Product, inverseSide: 'category' })
23
+ products!: Product[];
24
+ }
25
+
26
+ @Entity()
27
+ class Review extends BaseEntity { // used as an object type for array-of-objects
28
+ @Property.number()
29
+ rating!: number;
30
+
31
+ @Property.string()
32
+ comment!: string;
33
+ }
34
+
35
+ class Metadata { // plain object embedded inside Product
36
+ @Property.string()
37
+ color!: string;
38
+
39
+ @Property.number()
40
+ weight!: number;
41
+ }
42
+
43
+ @Entity()
44
+ class Product extends BaseEntity {
45
+ @Property.string({ required: false })
46
+ name: string | undefined | null;
47
+
48
+ @Property.number({ required: false })
49
+ price: number | undefined | null;
50
+
51
+ @Property.boolean({ required: false })
52
+ inStock: boolean | undefined | null;
53
+
54
+ @Property.date({ default: () => new Date(), required: false })
55
+ createdAt: Date | undefined | null;
56
+
57
+ @Property.array({ items: { type: 'string' }, required: false })
58
+ tags: string[] | undefined | null;
59
+
60
+ @Property.object({ cls: () => Metadata, required: false })
61
+ metadata: Metadata | undefined | null;
62
+
63
+ @Property.manyToOne({ target: () => Category, inverseSide: 'products', joinColumn: 'categoryId' })
64
+ category!: Category;
65
+
66
+ @Property.string({ format: 'uuid' })
67
+ categoryId!: string;
68
+
69
+ @Property.array({ items: { type: 'object', cls: () => Review }, required: false })
70
+ reviews: Review[] | undefined | null;
71
+ }
72
+
73
+ let server: StartedTestServer;
74
+ let productRepo: Repository<Product>;
75
+ let categoryRepo: Repository<Category>;
76
+
77
+ beforeAll(async () => {
78
+ server = await startTestServer({
79
+ dataSources: [
80
+ createTestDataSource({
81
+ entities: [...defaultTestServerEntities, Product, Category, Review]
82
+ })
83
+ ]
84
+ });
85
+ productRepo = inject(repositoryTokenFor(Product));
86
+ categoryRepo = inject(repositoryTokenFor(Category));
87
+ }, 15000);
88
+
89
+ afterAll(async () => {
90
+ await server.shutdown();
91
+ });
92
+
93
+ beforeEach(async () => {
94
+ await productRepo.deleteAll({});
95
+ await categoryRepo.deleteAll({});
96
+ });
97
+
98
+ // ---------- Helper to create test data ----------
99
+ async function seedProducts(...products: DeepPartial<Product>[]): Promise<Product[]> {
100
+ for (const p of products) {
101
+ if (p.category) {
102
+ const cat: Category = await categoryRepo.create(p.category);
103
+ p.categoryId = cat.id;
104
+ }
105
+ }
106
+ const defaultCategory: Category = (await categoryRepo.findAllPaginated(1, 1)).items.at(0) ?? await categoryRepo.create({ name: 'default' });
107
+ return Promise.all(products.map(p => productRepo.create({ tags: [], reviews: [], inStock: true, categoryId: defaultCategory.id, ...p })));
108
+ }
109
+
110
+ // ---------- Tests ----------
111
+ describe('Where filters', () => {
112
+
113
+ // =================== STRING ===================
114
+ describe('string', () => {
115
+ let prodA: Product;
116
+ let prodB: Product;
117
+
118
+ beforeEach(async () => {
119
+ [prodA, prodB] = await seedProducts(
120
+ { name: 'Alpha', price: 10 },
121
+ { name: 'Beta', price: 20 }
122
+ );
123
+ });
124
+
125
+ it('equals', async () => {
126
+ const res: Product[] = await productRepo.findAll({ where: { name: 'Alpha' } });
127
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
128
+ });
129
+
130
+ it('not', async () => {
131
+ const res: Product[] = await productRepo.findAll({ where: { name: { not: 'Alpha' } } });
132
+ expect(res.map(p => p.id).sort()).toEqual([prodB.id].sort());
133
+ });
134
+
135
+ it('oneOf', async () => {
136
+ const res: Product[] = await productRepo.findAll({ where: { name: { oneOf: ['Alpha', 'Beta'] } } });
137
+ expect(res.map(p => p.id).sort()).toEqual([prodA.id, prodB.id].sort());
138
+ });
139
+
140
+ it('notOneOf', async () => {
141
+ const res: Product[] = await productRepo.findAll({ where: { name: { notOneOf: ['Alpha'] } } });
142
+ expect(res.map(p => p.id)).toEqual([prodB.id]);
143
+ });
144
+
145
+ it('like', async () => {
146
+ const res: Product[] = await productRepo.findAll({ where: { name: { like: 'Al%' } } });
147
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
148
+ });
149
+
150
+ it('iLike', async () => {
151
+ const res: Product[] = await productRepo.findAll({ where: { name: { iLike: 'al%' } } });
152
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
153
+ });
154
+
155
+ it('null', async () => {
156
+ await productRepo.updateById(prodA.id, { name: null }); // set to null
157
+ const res: Product[] = await productRepo.findAll({ where: { name: null } });
158
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
159
+ });
160
+ });
161
+
162
+ // =================== NUMBER ===================
163
+ describe('number', () => {
164
+ let cheap: Product;
165
+ let mid: Product;
166
+ let expensive: Product;
167
+
168
+ beforeEach(async () => {
169
+ [cheap, mid, expensive] = await seedProducts(
170
+ { name: 'c', price: 10 },
171
+ { name: 'm', price: 50 },
172
+ { name: 'e', price: 100 }
173
+ );
174
+ });
175
+
176
+ it('equals', async () => {
177
+ const res: Product[] = await productRepo.findAll({ where: { price: 50 } });
178
+ expect(res.map(p => p.id)).toEqual([mid.id]);
179
+ });
180
+
181
+ it('not', async () => {
182
+ const res: Product[] = await productRepo.findAll({ where: { price: { not: 50 } } });
183
+ expect(res.map(p => p.id).sort()).toEqual([cheap.id, expensive.id].sort());
184
+ });
185
+
186
+ it('oneOf', async () => {
187
+ const res: Product[] = await productRepo.findAll({ where: { price: { oneOf: [10, 100] } } });
188
+ expect(res.map(p => p.id).sort()).toEqual([cheap.id, expensive.id].sort());
189
+ });
190
+
191
+ it('notOneOf', async () => {
192
+ const res: Product[] = await productRepo.findAll({ where: { price: { notOneOf: [10, 100] } } });
193
+ expect(res.map(p => p.id)).toEqual([mid.id]);
194
+ });
195
+
196
+ it('greaterThan', async () => {
197
+ const res: Product[] = await productRepo.findAll({ where: { price: { greaterThan: 50 } } });
198
+ expect(res.map(p => p.id)).toEqual([expensive.id]);
199
+ });
200
+
201
+ it('greaterThanEquals', async () => {
202
+ const res: Product[] = await productRepo.findAll({ where: { price: { greaterThanEquals: 50 } } });
203
+ expect(res.map(p => p.id).sort()).toEqual([mid.id, expensive.id].sort());
204
+ });
205
+
206
+ it('lesserThan', async () => {
207
+ const res: Product[] = await productRepo.findAll({ where: { price: { lesserThan: 50 } } });
208
+ expect(res.map(p => p.id)).toEqual([cheap.id]);
209
+ });
210
+
211
+ it('lesserThanEquals', async () => {
212
+ const res: Product[] = await productRepo.findAll({ where: { price: { lesserThanEquals: 50 } } });
213
+ expect(res.map(p => p.id).sort()).toEqual([cheap.id, mid.id].sort());
214
+ });
215
+
216
+ it('null', async () => {
217
+ await productRepo.updateById(cheap.id, { price: null });
218
+ const res: Product[] = await productRepo.findAll({ where: { price: null } });
219
+ expect(res.map(p => p.id)).toEqual([cheap.id]);
220
+ });
221
+ });
222
+
223
+ // =================== BOOLEAN ===================
224
+ describe('boolean', () => {
225
+ let inStock: Product;
226
+ let outOfStock: Product;
227
+
228
+ beforeEach(async () => {
229
+ [inStock, outOfStock] = await seedProducts(
230
+ { name: 'a', price: 1, inStock: true },
231
+ { name: 'b', price: 2, inStock: false }
232
+ );
233
+ });
234
+
235
+ it('true', async () => {
236
+ const res: Product[] = await productRepo.findAll({ where: { inStock: true } });
237
+ expect(res.map(p => p.id)).toEqual([inStock.id]);
238
+ });
239
+
240
+ it('false', async () => {
241
+ const res: Product[] = await productRepo.findAll({ where: { inStock: false } });
242
+ expect(res.map(p => p.id)).toEqual([outOfStock.id]);
243
+ });
244
+
245
+ it('null', async () => {
246
+ await productRepo.updateById(inStock.id, { inStock: null });
247
+ const res: Product[] = await productRepo.findAll({ where: { inStock: null } });
248
+ expect(res.map(p => p.id)).toEqual([inStock.id]);
249
+ });
250
+ });
251
+
252
+ // =================== DATE ===================
253
+ describe('date', () => {
254
+ let early: Product;
255
+ let late: Product;
256
+ const earlyCreatedAt: Date = new Date('2025-01-01');
257
+ const lateCreatedAt: Date = new Date('2026-01-01');
258
+
259
+ beforeEach(async () => {
260
+ [early, late] = await seedProducts(
261
+ { name: 'early', price: 1, createdAt: earlyCreatedAt },
262
+ { name: 'late', price: 2, createdAt: lateCreatedAt }
263
+ );
264
+ });
265
+
266
+ it('equals', async () => {
267
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: early.createdAt } });
268
+ expect(res.map(p => p.id)).toEqual([early.id]);
269
+ });
270
+
271
+ it('not', async () => {
272
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: { not: early.createdAt } } });
273
+ expect(res.map(p => p.id)).toEqual([late.id]);
274
+ });
275
+
276
+ it('oneOf', async () => {
277
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: { oneOf: [earlyCreatedAt, lateCreatedAt] } } });
278
+ expect(res.map(p => p.id).sort()).toEqual([early.id, late.id].sort());
279
+ });
280
+
281
+ it('notOneOf', async () => {
282
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: { notOneOf: [earlyCreatedAt] } } });
283
+ expect(res.map(p => p.id)).toEqual([late.id]);
284
+ });
285
+
286
+ it('after', async () => {
287
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: { after: earlyCreatedAt } } });
288
+ expect(res.map(p => p.id)).toEqual([late.id]);
289
+ });
290
+
291
+ it('before', async () => {
292
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: { before: lateCreatedAt } } });
293
+ expect(res.map(p => p.id)).toEqual([early.id]);
294
+ });
295
+
296
+ it('null', async () => {
297
+ await productRepo.updateById(early.id, { createdAt: null });
298
+ const res: Product[] = await productRepo.findAll({ where: { createdAt: null } });
299
+ expect(res.map(p => p.id)).toEqual([early.id]);
300
+ });
301
+ });
302
+
303
+ // =================== ARRAY (of strings) ===================
304
+ describe('array (string)', () => {
305
+ let prodA: Product;
306
+
307
+ beforeEach(async () => {
308
+ [prodA] = await seedProducts(
309
+ { name: 'a', price: 1, tags: ['tag1', 'tag2'] },
310
+ { name: 'b', price: 2, tags: ['tag3'] }
311
+ );
312
+ });
313
+
314
+ it('equals (exact array)', async () => {
315
+ const res: Product[] = await productRepo.findAll({ where: { tags: ['tag1', 'tag2'] } });
316
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
317
+ });
318
+
319
+ it('includes (contains all specified items)', async () => {
320
+ const res: Product[] = await productRepo.findAll({ where: { tags: { includes: ['tag1'] } } });
321
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
322
+ });
323
+
324
+ it('isIncludedIn (all items of the property are subset of given list)', async () => {
325
+ const res: Product[] = await productRepo.findAll({ where: { tags: { isIncludedIn: ['tag1', 'tag2', 'extra'] } } });
326
+ expect(res.map(p => p.id)).toEqual([prodA.id]); // prodA's tags are subset
327
+ // prodB has ['tag3'] which is not subset of ['tag1','tag2','extra'] -> not returned
328
+ });
329
+
330
+ it('null', async () => {
331
+ await productRepo.updateById(prodA.id, { tags: null });
332
+ const res: Product[] = await productRepo.findAll({ where: { tags: null } });
333
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
334
+ });
335
+ });
336
+
337
+ // =================== OBJECT (embedded) ===================
338
+ describe('object (Metadata)', () => {
339
+ let prodRed: Product;
340
+ let prodBlue: Product;
341
+
342
+ beforeEach(async () => {
343
+ [prodRed, prodBlue] = await seedProducts(
344
+ { name: 'red', price: 1, metadata: { color: 'red', weight: 100 } },
345
+ { name: 'blue', price: 2, metadata: { color: 'blue', weight: 200 } }
346
+ );
347
+ });
348
+
349
+ it('equals (exact match)', async () => {
350
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { is: { color: 'red', weight: 100 } } } });
351
+ expect(res.map(p => p.id)).toEqual([prodRed.id]);
352
+ });
353
+
354
+ it('where (nested filter)', async () => {
355
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { where: { color: 'red' } } } });
356
+ // Should treat the nested where as filtering on the JSON's properties
357
+ // That depends on how TypeORM handles JSON columns; we assume the framework maps it correctly.
358
+ // In a strict behavioral test, we just validate the result.
359
+ expect(res.map(p => p.id)).toEqual([prodRed.id]);
360
+ });
361
+
362
+ it('not', async () => {
363
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { not: { color: 'red', weight: 100 } } } });
364
+ expect(res.map(p => p.id)).toEqual([prodBlue.id]);
365
+ });
366
+
367
+ it('oneOf', async () => {
368
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { oneOf: [{ color: 'red', weight: 100 }, { color: 'blue', weight: 200 }] } } });
369
+ expect(res.map(p => p.id).sort()).toEqual([prodRed.id, prodBlue.id].sort());
370
+ });
371
+
372
+ it('notOneOf', async () => {
373
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { notOneOf: [{ color: 'red', weight: 100 }] } } });
374
+ expect(res.map(p => p.id)).toEqual([prodBlue.id]);
375
+ });
376
+
377
+ it('null', async () => {
378
+ await productRepo.updateById(prodRed.id, { metadata: null });
379
+ const res: Product[] = await productRepo.findAll({ where: { metadata: { is: null } } });
380
+ expect(res.map(p => p.id)).toEqual([prodRed.id]);
381
+ });
382
+ });
383
+
384
+ // =================== RELATION (Category) ===================
385
+ describe('relation (Category)', () => {
386
+ let catFood: Category;
387
+ let catToys: Category;
388
+ let prodFood: Product;
389
+
390
+ beforeEach(async () => {
391
+ catFood = await categoryRepo.create({ name: 'Food' });
392
+ catToys = await categoryRepo.create({ name: 'Toys' });
393
+ [prodFood] = await seedProducts(
394
+ { name: 'Kibble', price: 5, category: catFood },
395
+ { name: 'Ball', price: 3, category: catToys }
396
+ );
397
+ });
398
+
399
+ it('filter by relation property (where on nested object)', async () => {
400
+ const res: Product[] = await productRepo.findAll({ where: { category: { where: { name: 'Food' } } } });
401
+ expect(res.map(p => p.id)).toEqual([prodFood.id]);
402
+ });
403
+
404
+ it('filter by relation id (equals with id)', async () => {
405
+ // `equals` on a relation should filter by the primary key of the related entity
406
+ const res: Product[] = await productRepo.findAll({ where: { category: { is: catFood } } });
407
+ expect(res.map(p => p.id)).toEqual([prodFood.id]);
408
+ });
409
+
410
+ // TODO
411
+ // it('null (no category)', async () => {
412
+ // await productRepo.updateById(prodFood.id, { category: null });
413
+ // const res: Product[] = await productRepo.findAll({ where: { category: null } });
414
+ // expect(res.map(p => p.id)).toEqual([prodFood.id]);
415
+ // });
416
+ });
417
+
418
+ // =================== ARRAY OF OBJECTS (Review[]) ===================
419
+ describe('array of objects', () => {
420
+ let prodA: Product;
421
+ let prodB: Product;
422
+
423
+ beforeEach(async () => {
424
+ [prodA, prodB] = await seedProducts(
425
+ { name: 'a', price: 1, reviews: [{ rating: 5, comment: 'Great' }, { rating: 4, comment: 'Good' }] },
426
+ { name: 'b', price: 2, reviews: [{ rating: 2, comment: 'Bad' }] }
427
+ );
428
+ });
429
+
430
+ it('includes (contains all specified objects)', async () => {
431
+ const res: Product[] = await productRepo.findAll({ where: { reviews: { where: [{ rating: 5, comment: 'Great' }] } } });
432
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
433
+ });
434
+
435
+ it('isIncludedIn (all items of the array are subset of given list)', async () => {
436
+ const res: Product[] = await productRepo.findAll({ where: { reviews: { where: [{ rating: 5, comment: 'Great' }, { rating: 4, comment: 'Good' }, { rating: 2, comment: 'Bad' }] } } });
437
+ expect(res.map(p => p.id).sort()).toEqual([prodA.id, prodB.id].sort());
438
+ });
439
+
440
+ it('null', async () => {
441
+ await productRepo.updateById(prodA.id, { reviews: null });
442
+ const res: Product[] = await productRepo.findAll({ where: { reviews: null } });
443
+ expect(res.map(p => p.id)).toEqual([prodA.id]);
444
+ });
445
+ });
446
+
447
+ // =================== OR (array of filters) ===================
448
+ describe('OR combination', () => {
449
+ let prodA: Product;
450
+ let prodB: Product;
451
+ let prodC: Product;
452
+
453
+ beforeEach(async () => {
454
+ [prodA, prodB, prodC] = await seedProducts(
455
+ { name: 'A', price: 1 },
456
+ { name: 'B', price: 2 },
457
+ { name: 'C', price: 3 }
458
+ );
459
+ });
460
+
461
+ it('returns entities matching any of the filters', async () => {
462
+ const filters: WhereFilter<Product>[] = [
463
+ { name: 'A' },
464
+ { price: 3 }
465
+ ];
466
+ const res: Product[] = await productRepo.findAll({ where: filters });
467
+ expect(res.map(p => p.id).sort()).toEqual([prodA.id, prodC.id].sort());
468
+ });
469
+
470
+ it('multiple complex filters', async () => {
471
+ const filters: WhereFilter<Product>[] = [
472
+ { name: { like: 'A' }, price: 1 },
473
+ { name: { like: 'B' }, price: { greaterThan: 1 } }
474
+ ];
475
+ const res: Product[] = await productRepo.findAll({ where: filters });
476
+ expect(res.map(p => p.id).sort()).toEqual([prodA.id, prodB.id].sort());
477
+ });
478
+ });
479
+ });
@@ -1,3 +1,4 @@
1
+ import { RepositoryTypeForEntity } from '../../data-source/data-sources/data-source.interface';
1
2
  import { Repository } from '../../data-source/repository';
2
3
  import { BaseEntity } from '../../entity/base-entity.model';
3
4
  import { Newable } from '../../types/newable.type';
@@ -12,10 +13,10 @@ const allRepositoryTokens: Record<string, DiToken<Repository<BaseEntity>>> = {};
12
13
  * @param entity - The entity class to resolve the repository token for.
13
14
  * @returns The DI token.
14
15
  */
15
- export function repositoryTokenFor<T extends Newable<BaseEntity>>(entity: T): DiToken<Repository<InstanceType<T>>> {
16
+ export function repositoryTokenFor<T extends Newable<BaseEntity>>(entity: T): DiToken<RepositoryTypeForEntity<InstanceType<T>>> {
16
17
  const key: string = `Repository<${entity.name}>`;
17
18
  allRepositoryTokens[key] ??= new InjectionToken(key);
18
- return allRepositoryTokens[key] as unknown as DiToken<Repository<InstanceType<T>>>;
19
+ return allRepositoryTokens[key] as DiToken<RepositoryTypeForEntity<InstanceType<T>>>;
19
20
  }
20
21
 
21
22
  /**
@@ -11,6 +11,7 @@ import { PasswordResetEmailTemplate } from '../../auth/strategies/jwt/jwt-auth.c
11
11
  import { UserServiceInterface } from '../../auth/user/user-service.interface';
12
12
  import { BackupServiceInterface } from '../../backup/backup-service.interface';
13
13
  import { CacheServiceInterface } from '../../caching/cache-service.interface';
14
+ import { CacheContext } from '../../context/cache/cache.context';
14
15
  import { HttpRequestContext } from '../../context/request/http-request.context';
15
16
  import { WebsocketRequestContext } from '../../context/request/websocket-request.context';
16
17
  import { CronServiceInterface } from '../../cron/cron-service.interface';
@@ -24,7 +25,6 @@ import { FormatDateFn } from '../../localization/formatting/format-date-fn.model
24
25
  import { FormatPercentFn } from '../../localization/formatting/format-percent-fn.model';
25
26
  import { FormatPriceFn } from '../../localization/formatting/format-price-fn.model';
26
27
  import { LocalizeOptionsInput, LocalizeOptions } from '../../localization/models/localize-options.model';
27
- import { LogCacheContext } from '../../logging/log-context.model';
28
28
  import { LogLevel } from '../../logging/log-level.enum';
29
29
  import { LoggerInterface } from '../../logging/logger.interface';
30
30
  import { LoggerTransport, BaseLoggerTransportConfig } from '../../logging/transport/logger-transport.model';
@@ -118,5 +118,5 @@ export const ZIBRI_DI_TOKENS = {
118
118
  // dynamic/context based tokens
119
119
  CURRENT_REQUEST_CONTEXT: ziToken<HttpRequestContext | WebsocketRequestContext | undefined>('zi.current_request_context'),
120
120
  DEFAULT_CSP_OPTIONS: ziToken<CspOptions>('zi.default_csp_options'),
121
- CURRENT_CACHE_CONTEXT: ziToken<LogCacheContext[] | undefined>('zi.current_cache_context')
121
+ CURRENT_CACHE_CONTEXT: ziToken<CacheContext[] | undefined>('zi.current_cache_context')
122
122
  } as const satisfies TokenRecord;