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,451 @@
1
+ import { Raw, FindOperator, DataSource as ToDataSource } from 'typeorm';
2
+ import { RelationMetadata as ToRelationMetadata } from 'typeorm/metadata/RelationMetadata.js';
3
+
4
+ import { TypeOrmWhereFilterConverter } from './typeorm-where-filter.converter';
5
+ import { BaseEntity } from '../../../entity/base-entity.model';
6
+ import { EntityMetadata } from '../../../entity/decorators/entity.decorator';
7
+ import { PropertyMetadata, RelationMetadata } from '../../../entity/decorators/property.decorator';
8
+ import { EntityMetadataMissingError } from '../../../entity/entity-metadata-missing.error';
9
+ import { Relation } from '../../../entity/models/relation.enum';
10
+ import { Newable } from '../../../types/newable.type';
11
+ import { MetadataUtilities } from '../../../utilities/metadata.utilities';
12
+ import { WhereFilterKeys } from '../../models/where/where-filter-keys.model';
13
+ import { Where } from '../../models/where/where-filter.model';
14
+
15
+ const ALIAS: string = '$$COL$$';
16
+ const elemAlias: string = 'elem';
17
+
18
+ /**
19
+ * Handler function for a single where-filter key inside of jsonb.
20
+ */
21
+ type JsonbOperatorHandler = (
22
+ jsonPath: string,
23
+ textPath: string,
24
+ castPath: string,
25
+ value: unknown,
26
+ fieldKey: string,
27
+ propMeta: PropertyMetadata | undefined
28
+ ) => string;
29
+
30
+ /**
31
+ * Converter that transforms a Zibri WhereFilter into a TypeORM FindOptionsWhere for postgres.
32
+ */
33
+ export class PostgresTypeOrmWhereFilterConverter extends TypeOrmWhereFilterConverter {
34
+
35
+ private readonly jsonbOperatorHandlers: Record<string, JsonbOperatorHandler> = {
36
+ is: (jp, _tp, _cp, val) => val === null
37
+ ? `${jp} = 'null'::jsonb`
38
+ : `${jp} @> ${this.toJsonbLiteral(val as object)}`,
39
+ not: (jp, _tp, cp, val) => {
40
+ if (val === null) {
41
+ return `${jp} IS NOT NULL`;
42
+ }
43
+ if (typeof val === 'object' && !Array.isArray(val)) {
44
+ return `NOT (${jp} @> ${this.toJsonbLiteral(val)})`;
45
+ }
46
+ return `${cp} != ${this.toSqlLiteral(val)}`;
47
+ },
48
+ oneOf: (_jp, _tp, cp, val, fieldKey) => {
49
+ if (!Array.isArray(val)) {
50
+ throw new Error(`"oneOf" must be an array for JSONB field "${fieldKey}"`);
51
+ }
52
+ return `${cp} IN (${(val as unknown[]).map(v => this.toSqlLiteral(v)).join(', ')})`;
53
+ },
54
+ notOneOf: (_jp, _tp, cp, val, fieldKey) => {
55
+ if (!Array.isArray(val)) {
56
+ throw new Error(`"notOneOf" must be an array for JSONB field "${fieldKey}"`);
57
+ }
58
+ return `${cp} NOT IN (${(val as unknown[]).map(v => this.toSqlLiteral(v)).join(', ')})`;
59
+ },
60
+ like: (_jp, tp, _cp, val) => `${tp} LIKE ${this.toSqlLiteral(val)}`,
61
+ iLike: (_jp, tp, _cp, val) => `${tp} ILIKE ${this.toSqlLiteral(val)}`,
62
+ greaterThan: (_jp, _tp, cp, val) => `${cp} > ${this.toSqlLiteral(val)}`,
63
+ after: (_jp, _tp, cp, val) => `${cp} > ${this.toSqlLiteral(val)}`,
64
+ greaterThanEquals: (_jp, _tp, cp, val) => `${cp} >= ${this.toSqlLiteral(val)}`,
65
+ lesserThan: (_jp, _tp, cp, val) => `${cp} < ${this.toSqlLiteral(val)}`,
66
+ before: (_jp, _tp, cp, val) => `${cp} < ${this.toSqlLiteral(val)}`,
67
+ lesserThanEquals: (_jp, _tp, cp, val) => `${cp} <= ${this.toSqlLiteral(val)}`,
68
+ length: (jp, _tp, _cp, val) => `jsonb_array_length(${jp}) = ${this.toSqlLiteral(val)}`,
69
+ lengthGreaterThan: (jp, _tp, _cp, val) => `jsonb_array_length(${jp}) > ${this.toSqlLiteral(val)}`,
70
+ lengthGreaterThanEquals: (jp, _tp, _cp, val) => `jsonb_array_length(${jp}) >= ${this.toSqlLiteral(val)}`,
71
+ lengthLesserThan: (jp, _tp, _cp, val) => `jsonb_array_length(${jp}) < ${this.toSqlLiteral(val)}`,
72
+ lengthLesserThanEquals: (jp, _tp, _cp, val) => `jsonb_array_length(${jp}) <= ${this.toSqlLiteral(val)}`,
73
+ includes: (jp, _tp, _cp, val, fieldKey) => {
74
+ if (!Array.isArray(val)) {
75
+ throw new Error(`"includes" must be an array for JSONB field "${fieldKey}"`);
76
+ }
77
+ return `${jp} @> ${this.toJsonbLiteral(val)}`;
78
+ },
79
+ isIncludedIn: (jp, _tp, _cp, val, fieldKey) => {
80
+ if (!Array.isArray(val)) {
81
+ throw new Error(`"isIncludedIn" must be an array for JSONB field "${fieldKey}"`);
82
+ }
83
+ return `${jp} <@ ${this.toJsonbLiteral(val)}`;
84
+ },
85
+ where: (jp, _tp, _cp, val, fieldKey, propMeta) => this.buildJsonbWhereCondition(jp, val, propMeta, fieldKey)
86
+ };
87
+
88
+ constructor(dataSource: ToDataSource) {
89
+ super(dataSource);
90
+ }
91
+
92
+ // ── JSONB-aware "where" handler ─────────────────────────────
93
+
94
+ // eslint-disable-next-line jsdoc/require-jsdoc
95
+ protected whereHandler(
96
+ value: unknown,
97
+ metadata: PropertyMetadata,
98
+ nestedProperties: Record<string, PropertyMetadata> | undefined,
99
+ entityClass: Newable<unknown>
100
+ ): FindOperator<unknown> {
101
+ if (metadata.type !== 'object' && metadata.type !== 'array') {
102
+ return super.whereHandler(value, metadata, nestedProperties, entityClass);
103
+ }
104
+
105
+ if (metadata.type === 'array') {
106
+ if (metadata.items.type !== 'object') {
107
+ throw new Error('The "where" operator on an array field requires an array of objects.');
108
+ }
109
+ const itemMeta: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(metadata.items.cls());
110
+ const innerSql: string = this.buildJsonbCondition(elemAlias, value as Where<Record<string, unknown>>, itemMeta);
111
+ const sql: string = `EXISTS (SELECT 1 FROM jsonb_array_elements(${ALIAS}) AS ${elemAlias} WHERE ${innerSql})`;
112
+ return Raw(alias => {
113
+ const quotedAlias: string = alias.split('.').map(part => `"${part.replaceAll('"', '')}"`)
114
+ .join('.');
115
+ return sql.replaceAll(ALIAS, quotedAlias);
116
+ }) as FindOperator<unknown>;
117
+ }
118
+
119
+ // object property
120
+ const nestedMeta: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(metadata.cls());
121
+ const sql: string = this.buildJsonbCondition(ALIAS, value as Where<Record<string, unknown>>, nestedMeta);
122
+ return Raw(alias => {
123
+ const quotedAlias: string = alias.split('.').map(part => `"${part.replaceAll('"', '')}"`)
124
+ .join('.');
125
+ return sql.replaceAll(ALIAS, quotedAlias);
126
+ }) as FindOperator<unknown>;
127
+ }
128
+
129
+ // eslint-disable-next-line jsdoc/require-jsdoc
130
+ protected buildRelationLengthRawOperator<T>(
131
+ entityClass: Newable<T>,
132
+ propertyName: string,
133
+ metadata: RelationMetadata<BaseEntity>,
134
+ lengthKey: string,
135
+ value: number
136
+ ): FindOperator<unknown> {
137
+ const operator: string = this.lengthKeyToSqlOperator(lengthKey);
138
+
139
+ if (metadata.type === Relation.ONE_TO_MANY) {
140
+ const targetEntity: Newable<BaseEntity> = metadata.target();
141
+ const targetMeta: EntityMetadata | undefined = MetadataUtilities.getEntityMetadata(targetEntity);
142
+ if (!targetMeta) {
143
+ throw new EntityMetadataMissingError(targetEntity, `used in ${entityClass.name}.${propertyName}`);
144
+ }
145
+ const targetProps: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(targetEntity);
146
+ const inverseProp: PropertyMetadata | undefined = targetProps[metadata.inverseSide];
147
+ if (inverseProp?.type !== Relation.MANY_TO_ONE) {
148
+ throw new Error(`Could not find inverse many-to-one relation "${metadata.inverseSide}" on ${targetEntity.name}`);
149
+ }
150
+ const fkColumn: string | undefined = inverseProp.joinColumn;
151
+ const rawSql: string = `(SELECT COUNT(*) FROM "${targetMeta.tableName}" `
152
+ + `WHERE "${targetMeta.tableName}"."${fkColumn}" = $alias$) ${operator} ${value}`;
153
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
154
+ }
155
+
156
+ // MANY_TO_MANY
157
+ const ormRelation: ToRelationMetadata | undefined = this.typeOrmDataSource
158
+ .getMetadata(entityClass)
159
+ .findRelationWithPropertyPath(propertyName);
160
+ if (ormRelation?.isManyToMany !== true || !ormRelation.junctionEntityMetadata) {
161
+ throw new Error(`Could not resolve many-to-many relation metadata for ${entityClass.name}.${propertyName}`);
162
+ }
163
+ const junctionTable: string = ormRelation.junctionEntityMetadata.tableName;
164
+ const ownFkColumn: string = ormRelation.junctionEntityMetadata.columns[0].databaseName;
165
+ const rawSql: string = `(SELECT COUNT(*) FROM "${junctionTable}" `
166
+ + `WHERE "${junctionTable}"."${ownFkColumn}" = $alias$) ${operator} ${value}`;
167
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
168
+ }
169
+
170
+ // eslint-disable-next-line jsdoc/require-jsdoc
171
+ protected buildRelationIncludesOperator<T>(
172
+ entityClass: Newable<T>,
173
+ propertyName: string,
174
+ metadata: RelationMetadata<BaseEntity>,
175
+ entities: BaseEntity[]
176
+ ): FindOperator<unknown> {
177
+ if (entities.length === 0) {
178
+ return Raw(() => 'TRUE');
179
+ }
180
+
181
+ if (metadata.type === Relation.ONE_TO_MANY) {
182
+ const targetEntity: Newable<BaseEntity> = metadata.target();
183
+ const targetMeta: EntityMetadata | undefined = MetadataUtilities.getEntityMetadata(targetEntity);
184
+ if (!targetMeta) {
185
+ throw new EntityMetadataMissingError(targetEntity, `used in ${entityClass.name}.${propertyName}`);
186
+ }
187
+ const targetProps: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(targetEntity);
188
+ const inverseProp: PropertyMetadata | undefined = targetProps[metadata.inverseSide];
189
+ if (inverseProp?.type !== Relation.MANY_TO_ONE) {
190
+ throw new Error(`Could not find inverse many-to-one relation "${metadata.inverseSide}" on ${targetEntity.name}`);
191
+ }
192
+ const fkColumn: string | undefined = inverseProp.joinColumn;
193
+ const ids: string = entities.map(e => `'${e.id}'`).join(', ');
194
+ const rawSql: string = `(SELECT COUNT(*) FROM "${targetMeta.tableName}" `
195
+ + `WHERE "${targetMeta.tableName}"."${fkColumn}" = $alias$ `
196
+ + `AND "${targetMeta.tableName}"."id" IN (${ids})) = ${entities.length}`;
197
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
198
+ }
199
+
200
+ // MANY_TO_MANY
201
+ const ormRelation: ToRelationMetadata | undefined = this.typeOrmDataSource
202
+ .getMetadata(entityClass)
203
+ .findRelationWithPropertyPath(propertyName);
204
+ if (ormRelation?.isManyToMany !== true || !ormRelation.junctionEntityMetadata) {
205
+ throw new Error(`Could not resolve many-to-many relation metadata for ${entityClass.name}.${propertyName}`);
206
+ }
207
+ const junctionTable: string = ormRelation.junctionEntityMetadata.tableName;
208
+ const ownFkColumn: string = ormRelation.junctionEntityMetadata.columns[0].databaseName;
209
+ const targetFkColumn: string = ormRelation.junctionEntityMetadata.columns[1].databaseName;
210
+ const ids: string = entities.map(e => `'${e.id}'`).join(', ');
211
+ const rawSql: string = `(SELECT COUNT(*) FROM "${junctionTable}" `
212
+ + `WHERE "${junctionTable}"."${ownFkColumn}" = $alias$ `
213
+ + `AND "${junctionTable}"."${targetFkColumn}" IN (${ids})) = ${entities.length}`;
214
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
215
+ }
216
+
217
+ // eslint-disable-next-line jsdoc/require-jsdoc
218
+ protected buildRelationIsIncludedInOperator<T>(
219
+ entityClass: Newable<T>,
220
+ propertyName: string,
221
+ metadata: RelationMetadata<BaseEntity>,
222
+ entities: BaseEntity[]
223
+ ): FindOperator<unknown> {
224
+ if (entities.length === 0) {
225
+ return Raw(() => 'FALSE');
226
+ }
227
+
228
+ if (metadata.type === Relation.ONE_TO_MANY) {
229
+ const targetEntity: Newable<BaseEntity> = metadata.target();
230
+ const targetMeta: EntityMetadata | undefined = MetadataUtilities.getEntityMetadata(targetEntity);
231
+ if (!targetMeta) {
232
+ throw new EntityMetadataMissingError(targetEntity, `used in ${entityClass.name}.${propertyName}`);
233
+ }
234
+ const targetProps: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(targetEntity);
235
+ const inverseProp: PropertyMetadata | undefined = targetProps[metadata.inverseSide];
236
+ if (inverseProp?.type !== Relation.MANY_TO_ONE || !inverseProp.joinColumn) {
237
+ throw new Error(`Could not find inverse many-to-one relation "${metadata.inverseSide}" on ${targetEntity.name}`);
238
+ }
239
+ const fkColumn: string = inverseProp.joinColumn;
240
+ const ids: string = entities.map(e => `'${e.id}'`).join(', ');
241
+ const rawSql: string = `NOT EXISTS (SELECT 1 FROM "${targetMeta.tableName}" `
242
+ + `WHERE "${targetMeta.tableName}"."${fkColumn}" = $alias$ `
243
+ + `AND "${targetMeta.tableName}"."id" NOT IN (${ids}))`;
244
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
245
+ }
246
+
247
+ // MANY_TO_MANY
248
+ const ormRelation: ToRelationMetadata | undefined = this.typeOrmDataSource
249
+ .getMetadata(entityClass)
250
+ .findRelationWithPropertyPath(propertyName);
251
+ if (ormRelation?.isManyToMany !== true || !ormRelation.junctionEntityMetadata) {
252
+ throw new Error(`Could not resolve many-to-many relation metadata for ${entityClass.name}.${propertyName}`);
253
+ }
254
+ const junctionTable: string = ormRelation.junctionEntityMetadata.tableName;
255
+ const ownFkColumn: string = ormRelation.junctionEntityMetadata.columns[0].databaseName;
256
+ const targetFkColumn: string = ormRelation.junctionEntityMetadata.columns[1].databaseName;
257
+ const ids: string = entities.map(e => `'${e.id}'`).join(', ');
258
+ const rawSql: string = `NOT EXISTS (SELECT 1 FROM "${junctionTable}" `
259
+ + `WHERE "${junctionTable}"."${ownFkColumn}" = $alias$ `
260
+ + `AND "${junctionTable}"."${targetFkColumn}" NOT IN (${ids}))`;
261
+ return Raw(alias => rawSql.replaceAll('$alias$', alias));
262
+ }
263
+
264
+ // ── JSONB SQL generation (moved from PostgresDataSource) ────
265
+
266
+ private buildJsonbCondition(
267
+ jsonbAlias: string,
268
+ whereFilter: Where<Record<string, unknown>>,
269
+ propertyMetadataMap: Record<string, PropertyMetadata>
270
+ ): string {
271
+ if (Array.isArray(whereFilter)) {
272
+ return '(' + whereFilter
273
+ .map(f => `(${this.buildJsonbCondition(jsonbAlias, f, propertyMetadataMap)})`)
274
+ .join(' OR ') + ')';
275
+ }
276
+
277
+ const andParts: string[] = [];
278
+ for (const [key, filterValue] of Object.entries(whereFilter as Record<string, unknown>)) {
279
+ const propMeta: PropertyMetadata = propertyMetadataMap[key];
280
+ andParts.push(this.buildJsonbFieldCondition(jsonbAlias, key, filterValue, propMeta));
281
+ }
282
+ return andParts.length > 0 ? andParts.join(' AND ') : 'TRUE';
283
+ }
284
+
285
+ private buildJsonbWhereCondition(
286
+ jsonPath: string,
287
+ val: unknown,
288
+ propMeta: PropertyMetadata | undefined,
289
+ fieldKey: string
290
+ ): string {
291
+ if (propMeta?.type === 'object') {
292
+ return this.buildJsonbCondition(
293
+ jsonPath,
294
+ val as Where<Record<string, unknown>>,
295
+ MetadataUtilities.getModelProperties(propMeta.cls())
296
+ );
297
+ }
298
+ if (propMeta?.type === 'array') {
299
+ if (propMeta.items.type !== 'object') {
300
+ throw new Error(`"where" on array field "${fieldKey}" requires object items`);
301
+ }
302
+ const itemMeta: Record<string, PropertyMetadata> = MetadataUtilities.getModelProperties(propMeta.items.cls());
303
+ const elemAlias: string = `elem_${fieldKey}`;
304
+ return `EXISTS (SELECT 1 FROM jsonb_array_elements(${jsonPath}) AS ${elemAlias} WHERE `
305
+ + this.buildJsonbCondition(elemAlias, val as Where<Record<string, unknown>>, itemMeta) + ')';
306
+ }
307
+ throw new Error(`"where" operator used on a non-object, non-array JSONB field "${fieldKey}"`);
308
+ }
309
+
310
+ private buildJsonbFieldCondition(
311
+ jsonbAlias: string,
312
+ fieldKey: string,
313
+ filterValue: unknown,
314
+ propMeta: PropertyMetadata | undefined
315
+ ): string {
316
+ // Guard against relations inside JSONB
317
+ if (propMeta && (
318
+ propMeta.type === Relation.HAS_ONE
319
+ || propMeta.type === Relation.BELONGS_TO_ONE
320
+ || propMeta.type === Relation.MANY_TO_ONE
321
+ || propMeta.type === Relation.ONE_TO_MANY
322
+ || propMeta.type === Relation.MANY_TO_MANY
323
+ )) {
324
+ throw new Error(`Cannot filter on relation "${fieldKey}" inside a JSONB column. `
325
+ + 'Relations are not supported as part of embedded JSON objects/arrays.');
326
+ }
327
+
328
+ const jsonPath: string = `${jsonbAlias}->'${fieldKey}'`;
329
+ const textPath: string = `${jsonbAlias}->>'${fieldKey}'`;
330
+ const cast: string = this.getJsonbCast(propMeta);
331
+ const castPath: string = `(${textPath})${cast}`;
332
+
333
+ if (filterValue === null) {
334
+ return `${jsonPath} = 'null'::jsonb`;
335
+ }
336
+
337
+ if (typeof filterValue === 'string' || typeof filterValue === 'number'
338
+ || typeof filterValue === 'boolean' || filterValue instanceof Date) {
339
+ return `${castPath} = ${this.toSqlLiteral(filterValue)}`;
340
+ }
341
+
342
+ if (Array.isArray(filterValue)) {
343
+ // exact array match
344
+ const literal: string = this.toJsonbLiteral(filterValue);
345
+ return `(${jsonPath} @> ${literal} AND ${jsonPath} <@ ${literal})`;
346
+ }
347
+
348
+ if (typeof filterValue !== 'object') {
349
+ throw new Error(`Unexpected JSONB filter value for field "${fieldKey}": ${JSON.stringify(filterValue)}`);
350
+ }
351
+
352
+ return this.buildJsonbOperatorCondition(filterValue, jsonPath, castPath, fieldKey, textPath, propMeta);
353
+ }
354
+
355
+ private buildJsonbOperatorCondition(
356
+ filterValue: object,
357
+ jsonPath: string,
358
+ castPath: string,
359
+ fieldKey: string,
360
+ textPath: string,
361
+ propMeta: PropertyMetadata | undefined
362
+ ): string {
363
+ const filterObj: Record<string, unknown> = filterValue as Record<string, unknown>;
364
+ const conditions: string[] = [];
365
+
366
+ for (const [op, val] of Object.entries(filterObj)) {
367
+ const handler: JsonbOperatorHandler | undefined = this.jsonbOperatorHandlers[op as WhereFilterKeys];
368
+ if (handler == undefined) {
369
+ throw new Error(`Unknown JSONB filter operator "${op}" on field "${fieldKey}"`);
370
+ }
371
+ conditions.push(handler(jsonPath, textPath, castPath, val, fieldKey, propMeta));
372
+ }
373
+
374
+ return conditions.length > 0 ? conditions.join(' AND ') : 'TRUE';
375
+ }
376
+
377
+ private toSqlLiteral(val: unknown): string {
378
+ if (val === null) {
379
+ return 'NULL';
380
+ }
381
+ if (typeof val === 'boolean') {
382
+ return val ? 'TRUE' : 'FALSE';
383
+ }
384
+ if (typeof val === 'number') {
385
+ return String(val);
386
+ }
387
+ if (val instanceof Date) {
388
+ return `'${val.toISOString()}'`;
389
+ }
390
+ if (typeof val === 'string') {
391
+ return `'${val.replaceAll('\'', '\'\'')}'`;
392
+ }
393
+ throw new Error(`Cannot convert value of type "${typeof val}" to a SQL literal`);
394
+ }
395
+
396
+ private toJsonbLiteral(val: object): string {
397
+ return `'${JSON.stringify(val).replaceAll('\'', '\'\'')}'::jsonb`;
398
+ }
399
+
400
+ private getJsonbCast(propMeta: PropertyMetadata | undefined): string {
401
+ if (!propMeta) {
402
+ return '';
403
+ }
404
+ switch (propMeta.type) {
405
+ case 'number': {
406
+ return '::numeric';
407
+ }
408
+ case 'date': {
409
+ return '::timestamptz';
410
+ }
411
+ case 'boolean': {
412
+ return '::boolean';
413
+ }
414
+ case 'string':
415
+ case 'object':
416
+ case Relation.HAS_ONE:
417
+ case Relation.BELONGS_TO_ONE:
418
+ case Relation.ONE_TO_MANY:
419
+ case Relation.MANY_TO_ONE:
420
+ case Relation.MANY_TO_MANY:
421
+ case 'array':
422
+ case 'file':
423
+ case 'unknown': {
424
+ return '';
425
+ }
426
+ }
427
+ }
428
+
429
+ private lengthKeyToSqlOperator(lengthKey: string): string {
430
+ switch (lengthKey) {
431
+ case 'length': {
432
+ return '=';
433
+ }
434
+ case 'lengthGreaterThan': {
435
+ return '>';
436
+ }
437
+ case 'lengthGreaterThanEquals': {
438
+ return '>=';
439
+ }
440
+ case 'lengthLesserThan': {
441
+ return '<';
442
+ }
443
+ case 'lengthLesserThanEquals': {
444
+ return '<=';
445
+ }
446
+ default: {
447
+ throw new Error(`Unknown length filter key: ${lengthKey}`);
448
+ }
449
+ }
450
+ }
451
+ }