@revisium/core 2.2.0 → 2.3.0-alpha.2

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 (285) hide show
  1. package/dist/package.json +16 -7
  2. package/dist/src/api/graphql-api/branch/model/branch.model.js +2 -1
  3. package/dist/src/api/graphql-api/branch/model/branch.model.js.map +1 -1
  4. package/dist/src/api/graphql-api/branch/parent-branch.resolver.d.ts +15 -2
  5. package/dist/src/api/graphql-api/branch/parent-branch.resolver.js +6 -4
  6. package/dist/src/api/graphql-api/branch/parent-branch.resolver.js.map +1 -1
  7. package/dist/src/api/graphql-api/draft/input/create-row.input.js +2 -2
  8. package/dist/src/api/graphql-api/draft/input/create-row.input.js.map +1 -1
  9. package/dist/src/api/graphql-api/draft/input/create-table.input.js +2 -2
  10. package/dist/src/api/graphql-api/draft/input/create-table.input.js.map +1 -1
  11. package/dist/src/api/graphql-api/draft/input/patch-row.input.js +2 -2
  12. package/dist/src/api/graphql-api/draft/input/patch-row.input.js.map +1 -1
  13. package/dist/src/api/graphql-api/draft/input/update-row.input.js +2 -2
  14. package/dist/src/api/graphql-api/draft/input/update-row.input.js.map +1 -1
  15. package/dist/src/api/graphql-api/draft/input/update-table.input.js +2 -2
  16. package/dist/src/api/graphql-api/draft/input/update-table.input.js.map +1 -1
  17. package/dist/src/api/graphql-api/endpoint/model/endpoint.model.js +2 -1
  18. package/dist/src/api/graphql-api/endpoint/model/endpoint.model.js.map +1 -1
  19. package/dist/src/api/graphql-api/graphql-api.module.js +2 -2
  20. package/dist/src/api/graphql-api/graphql-api.module.js.map +1 -1
  21. package/dist/src/api/graphql-api/project/model/project.model.js +2 -1
  22. package/dist/src/api/graphql-api/project/model/project.model.js.map +1 -1
  23. package/dist/src/api/graphql-api/revision/child-branch.resolver.d.ts +15 -2
  24. package/dist/src/api/graphql-api/revision/child-branch.resolver.js +6 -4
  25. package/dist/src/api/graphql-api/revision/child-branch.resolver.js.map +1 -1
  26. package/dist/src/api/graphql-api/revision/model/revision.model.js +2 -1
  27. package/dist/src/api/graphql-api/revision/model/revision.model.js.map +1 -1
  28. package/dist/src/api/graphql-api/revision/revision.resolver.d.ts +15 -2
  29. package/dist/src/api/graphql-api/revision/revision.resolver.js +6 -4
  30. package/dist/src/api/graphql-api/revision/revision.resolver.js.map +1 -1
  31. package/dist/src/api/graphql-api/row/inputs/get-rows.input.js +5 -5
  32. package/dist/src/api/graphql-api/row/inputs/get-rows.input.js.map +1 -1
  33. package/dist/src/api/graphql-api/row/model/row.model.js +5 -5
  34. package/dist/src/api/graphql-api/row/model/row.model.js.map +1 -1
  35. package/dist/src/api/graphql-api/row/row.resolver.js +7 -3
  36. package/dist/src/api/graphql-api/row/row.resolver.js.map +1 -1
  37. package/dist/src/api/graphql-api/table/model/table.model.js +4 -4
  38. package/dist/src/api/graphql-api/table/model/table.model.js.map +1 -1
  39. package/dist/src/api/rest-api/revision/revision-by-id.controller.js +1 -1
  40. package/dist/src/api/rest-api/revision/revision-by-id.controller.js.map +1 -1
  41. package/dist/src/api/rest-api/row/row-by-id.controller.d.ts +2 -3
  42. package/dist/src/api/rest-api/row/row-by-id.controller.js +2 -4
  43. package/dist/src/api/rest-api/row/row-by-id.controller.js.map +1 -1
  44. package/dist/src/core/core.module.js +2 -0
  45. package/dist/src/core/core.module.js.map +1 -1
  46. package/dist/src/features/auth/auth.module.js +3 -1
  47. package/dist/src/features/auth/auth.module.js.map +1 -1
  48. package/dist/src/features/auth/casl-ability.factory.d.ts +3 -1
  49. package/dist/src/features/auth/casl-ability.factory.js +6 -3
  50. package/dist/src/features/auth/casl-ability.factory.js.map +1 -1
  51. package/dist/src/features/auth/commands/auth-api.service.d.ts +11 -0
  52. package/dist/src/features/auth/commands/auth-api.service.js +44 -0
  53. package/dist/src/features/auth/commands/auth-api.service.js.map +1 -0
  54. package/dist/src/features/auth/commands/handlers/check-organization-permission.handler.d.ts +2 -2
  55. package/dist/src/features/auth/commands/handlers/check-organization-permission.handler.js.map +1 -1
  56. package/dist/src/features/auth/commands/handlers/check-project-permission.handler.d.ts +2 -2
  57. package/dist/src/features/auth/commands/handlers/check-project-permission.handler.js.map +1 -1
  58. package/dist/src/features/auth/commands/impl/check-organization-permission.command.d.ts +2 -0
  59. package/dist/src/features/auth/commands/impl/check-project-permission.command.d.ts +2 -0
  60. package/dist/src/features/auth/commands/impl/check-system-permission.command.d.ts +1 -0
  61. package/dist/src/features/auth/guards/base-persmission.guard.d.ts +4 -2
  62. package/dist/src/features/auth/guards/base-persmission.guard.js +6 -4
  63. package/dist/src/features/auth/guards/base-persmission.guard.js.map +1 -1
  64. package/dist/src/features/auth/guards/organization.guard.d.ts +2 -3
  65. package/dist/src/features/auth/guards/organization.guard.js +2 -3
  66. package/dist/src/features/auth/guards/organization.guard.js.map +1 -1
  67. package/dist/src/features/auth/guards/project.guard.d.ts +29 -3
  68. package/dist/src/features/auth/guards/project.guard.js +11 -8
  69. package/dist/src/features/auth/guards/project.guard.js.map +1 -1
  70. package/dist/src/features/auth/guards/system.guard.d.ts +1 -2
  71. package/dist/src/features/auth/guards/system.guard.js +2 -3
  72. package/dist/src/features/auth/guards/system.guard.js.map +1 -1
  73. package/dist/src/features/draft/commands/handlers/__tests__/utils.d.ts +2 -0
  74. package/dist/src/features/draft/commands/handlers/__tests__/utils.js +8 -0
  75. package/dist/src/features/draft/commands/handlers/__tests__/utils.js.map +1 -1
  76. package/dist/src/features/draft/commands/handlers/api-base-row.handler.d.ts +2 -1
  77. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js +2 -1
  78. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js.map +1 -1
  79. package/dist/src/features/draft/commands/handlers/api-create-revision.handler.d.ts +16 -4
  80. package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js +6 -6
  81. package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js.map +1 -1
  82. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js +1 -0
  83. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js.map +1 -1
  84. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js +1 -0
  85. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js.map +1 -1
  86. package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js +1 -0
  87. package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js.map +1 -1
  88. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js +1 -0
  89. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js.map +1 -1
  90. package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js +1 -0
  91. package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js.map +1 -1
  92. package/dist/src/features/draft/commands/handlers/create-revision.handler.d.ts +13 -6
  93. package/dist/src/features/draft/commands/handlers/create-revision.handler.js +17 -2
  94. package/dist/src/features/draft/commands/handlers/create-revision.handler.js.map +1 -1
  95. package/dist/src/features/draft/commands/handlers/create-row.handler.d.ts +4 -2
  96. package/dist/src/features/draft/commands/handlers/create-row.handler.js +9 -1
  97. package/dist/src/features/draft/commands/handlers/create-row.handler.js.map +1 -1
  98. package/dist/src/features/draft/commands/handlers/patch-row.handler.d.ts +4 -2
  99. package/dist/src/features/draft/commands/handlers/patch-row.handler.js +9 -1
  100. package/dist/src/features/draft/commands/handlers/patch-row.handler.js.map +1 -1
  101. package/dist/src/features/draft/commands/handlers/remove-row.handler.d.ts +4 -1
  102. package/dist/src/features/draft/commands/handlers/remove-row.handler.js +9 -1
  103. package/dist/src/features/draft/commands/handlers/remove-row.handler.js.map +1 -1
  104. package/dist/src/features/draft/commands/handlers/remove-table.handler.d.ts +4 -2
  105. package/dist/src/features/draft/commands/handlers/remove-table.handler.js +9 -1
  106. package/dist/src/features/draft/commands/handlers/remove-table.handler.js.map +1 -1
  107. package/dist/src/features/draft/commands/handlers/rename-table.handler.d.ts +4 -2
  108. package/dist/src/features/draft/commands/handlers/rename-table.handler.js +9 -1
  109. package/dist/src/features/draft/commands/handlers/rename-table.handler.js.map +1 -1
  110. package/dist/src/features/draft/commands/handlers/revert-changes.handler.d.ts +4 -1
  111. package/dist/src/features/draft/commands/handlers/revert-changes.handler.js +10 -2
  112. package/dist/src/features/draft/commands/handlers/revert-changes.handler.js.map +1 -1
  113. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.d.ts +4 -2
  114. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js +10 -2
  115. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js.map +1 -1
  116. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.d.ts +4 -1
  117. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js +10 -2
  118. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js.map +1 -1
  119. package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.d.ts +5 -1
  120. package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.js +32 -18
  121. package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.js.map +1 -1
  122. package/dist/src/features/draft/commands/handlers/update-table.handler.d.ts +4 -2
  123. package/dist/src/features/draft/commands/handlers/update-table.handler.js +9 -1
  124. package/dist/src/features/draft/commands/handlers/update-table.handler.js.map +1 -1
  125. package/dist/src/features/draft/commands/types/create-revision.handler.types.d.ts +2 -0
  126. package/dist/src/features/draft/draft.handler.d.ts +1 -1
  127. package/dist/src/features/draft/draft.module.js +2 -0
  128. package/dist/src/features/draft/draft.module.js.map +1 -1
  129. package/dist/src/features/revision/index.d.ts +2 -0
  130. package/dist/src/{utils/prisma-sql-generator → features/revision}/index.js +2 -5
  131. package/dist/src/features/revision/index.js.map +1 -0
  132. package/dist/src/features/revision/internal-revisions-api.service.d.ts +19 -0
  133. package/dist/src/features/revision/internal-revisions-api.service.js +32 -0
  134. package/dist/src/features/revision/internal-revisions-api.service.js.map +1 -0
  135. package/dist/src/features/revision/queries/impl/get-revision.query.d.ts +1 -0
  136. package/dist/src/features/revision/revision.module.js +6 -1
  137. package/dist/src/features/revision/revision.module.js.map +1 -1
  138. package/dist/src/features/revision/revisions-api.service.d.ts +19 -5
  139. package/dist/src/features/revision/revisions-api.service.js +11 -6
  140. package/dist/src/features/revision/revisions-api.service.js.map +1 -1
  141. package/dist/src/features/row/index.d.ts +2 -0
  142. package/dist/src/features/row/index.js +19 -0
  143. package/dist/src/features/row/index.js.map +1 -0
  144. package/dist/src/features/row/internal-row-api.service.d.ts +13 -0
  145. package/dist/src/features/row/internal-row-api.service.js +47 -0
  146. package/dist/src/features/row/internal-row-api.service.js.map +1 -0
  147. package/dist/src/features/row/queries/handlers/get-rows.handler.d.ts +2 -4
  148. package/dist/src/features/row/queries/handlers/get-rows.handler.js +9 -29
  149. package/dist/src/features/row/queries/handlers/get-rows.handler.js.map +1 -1
  150. package/dist/src/features/row/queries/impl/get-row-by-id.query.d.ts +2 -0
  151. package/dist/src/features/row/queries/impl/get-row-by-id.query.js.map +1 -1
  152. package/dist/src/features/row/queries/impl/get-rows.query.d.ts +3 -3
  153. package/dist/src/features/row/queries/impl/get-rows.query.js.map +1 -1
  154. package/dist/src/features/row/row-api.service.d.ts +13 -9
  155. package/dist/src/features/row/row-api.service.js +27 -14
  156. package/dist/src/features/row/row-api.service.js.map +1 -1
  157. package/dist/src/features/row/row.module.js +2 -1
  158. package/dist/src/features/row/row.module.js.map +1 -1
  159. package/dist/src/features/row/utils/get-rows-sql.d.ts +5 -0
  160. package/dist/src/features/row/utils/get-rows-sql.js +70 -0
  161. package/dist/src/features/row/utils/get-rows-sql.js.map +1 -0
  162. package/dist/src/infrastructure/cache/constants/auth-cache.constants.d.ts +18 -0
  163. package/dist/src/infrastructure/cache/constants/auth-cache.constants.js +22 -0
  164. package/dist/src/infrastructure/cache/constants/auth-cache.constants.js.map +1 -0
  165. package/dist/src/infrastructure/cache/constants/revision-cache.constants.d.ts +10 -0
  166. package/dist/src/infrastructure/cache/constants/revision-cache.constants.js +14 -0
  167. package/dist/src/infrastructure/cache/constants/revision-cache.constants.js.map +1 -0
  168. package/dist/src/infrastructure/cache/constants/row-cache.constants.d.ts +13 -0
  169. package/dist/src/infrastructure/cache/constants/row-cache.constants.js +17 -0
  170. package/dist/src/infrastructure/cache/constants/row-cache.constants.js.map +1 -0
  171. package/dist/src/infrastructure/cache/events/base.event.d.ts +4 -0
  172. package/dist/src/infrastructure/cache/events/base.event.js +10 -0
  173. package/dist/src/infrastructure/cache/events/base.event.js.map +1 -0
  174. package/dist/src/infrastructure/cache/events/index.d.ts +10 -0
  175. package/dist/src/infrastructure/cache/events/index.js +27 -0
  176. package/dist/src/infrastructure/cache/events/index.js.map +1 -0
  177. package/dist/src/infrastructure/cache/events/revision/revision-committed.event.d.ts +6 -0
  178. package/dist/src/infrastructure/cache/events/revision/revision-committed.event.js +13 -0
  179. package/dist/src/infrastructure/cache/events/revision/revision-committed.event.js.map +1 -0
  180. package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.d.ts +5 -0
  181. package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.js +12 -0
  182. package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.js.map +1 -0
  183. package/dist/src/infrastructure/cache/events/row/row-created.event.d.ts +7 -0
  184. package/dist/src/infrastructure/cache/events/row/row-created.event.js +14 -0
  185. package/dist/src/infrastructure/cache/events/row/row-created.event.js.map +1 -0
  186. package/dist/src/infrastructure/cache/events/row/row-deleted.event.d.ts +7 -0
  187. package/dist/src/infrastructure/cache/events/row/row-deleted.event.js +14 -0
  188. package/dist/src/infrastructure/cache/events/row/row-deleted.event.js.map +1 -0
  189. package/dist/src/infrastructure/cache/events/row/row-renamed.event.d.ts +8 -0
  190. package/dist/src/infrastructure/cache/events/row/row-renamed.event.js +15 -0
  191. package/dist/src/infrastructure/cache/events/row/row-renamed.event.js.map +1 -0
  192. package/dist/src/infrastructure/cache/events/row/row-updated.event.d.ts +7 -0
  193. package/dist/src/infrastructure/cache/events/row/row-updated.event.js +14 -0
  194. package/dist/src/infrastructure/cache/events/row/row-updated.event.js.map +1 -0
  195. package/dist/src/infrastructure/cache/events/table/table-deleted.event.d.ts +6 -0
  196. package/dist/src/infrastructure/cache/events/table/table-deleted.event.js +13 -0
  197. package/dist/src/infrastructure/cache/events/table/table-deleted.event.js.map +1 -0
  198. package/dist/src/infrastructure/cache/events/table/table-renamed.event.d.ts +7 -0
  199. package/dist/src/infrastructure/cache/events/table/table-renamed.event.js +14 -0
  200. package/dist/src/infrastructure/cache/events/table/table-renamed.event.js.map +1 -0
  201. package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.d.ts +6 -0
  202. package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.js +13 -0
  203. package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.js.map +1 -0
  204. package/dist/src/infrastructure/cache/handlers/index.d.ts +10 -0
  205. package/dist/src/infrastructure/cache/handlers/index.js +24 -0
  206. package/dist/src/infrastructure/cache/handlers/index.js.map +1 -0
  207. package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.d.ts +8 -0
  208. package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.js +32 -0
  209. package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.js.map +1 -0
  210. package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.d.ts +8 -0
  211. package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.js +29 -0
  212. package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.js.map +1 -0
  213. package/dist/src/infrastructure/cache/handlers/row/row-created.handler.d.ts +8 -0
  214. package/dist/src/infrastructure/cache/handlers/row/row-created.handler.js +29 -0
  215. package/dist/src/infrastructure/cache/handlers/row/row-created.handler.js.map +1 -0
  216. package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.d.ts +8 -0
  217. package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.js +30 -0
  218. package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.js.map +1 -0
  219. package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.d.ts +8 -0
  220. package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.js +34 -0
  221. package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.js.map +1 -0
  222. package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.d.ts +8 -0
  223. package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.js +30 -0
  224. package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.js.map +1 -0
  225. package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.d.ts +8 -0
  226. package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.js +29 -0
  227. package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.js.map +1 -0
  228. package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.d.ts +8 -0
  229. package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.js +32 -0
  230. package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.js.map +1 -0
  231. package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.d.ts +8 -0
  232. package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.js +29 -0
  233. package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.js.map +1 -0
  234. package/dist/src/infrastructure/cache/index.d.ts +7 -0
  235. package/dist/src/infrastructure/cache/index.js +24 -0
  236. package/dist/src/infrastructure/cache/index.js.map +1 -0
  237. package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.d.ts +37 -0
  238. package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.js +228 -0
  239. package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.js.map +1 -0
  240. package/dist/src/infrastructure/cache/revisium-cache.module.d.ts +4 -0
  241. package/dist/src/infrastructure/cache/revisium-cache.module.js +140 -0
  242. package/dist/src/infrastructure/cache/revisium-cache.module.js.map +1 -0
  243. package/dist/src/infrastructure/cache/services/auth-cache.service.d.ts +22 -0
  244. package/dist/src/infrastructure/cache/services/auth-cache.service.js +112 -0
  245. package/dist/src/infrastructure/cache/services/auth-cache.service.js.map +1 -0
  246. package/dist/src/infrastructure/cache/services/cache.service.d.ts +11 -0
  247. package/dist/src/infrastructure/cache/services/cache.service.js +38 -0
  248. package/dist/src/infrastructure/cache/services/cache.service.js.map +1 -0
  249. package/dist/src/infrastructure/cache/services/cache.tokens.d.ts +1 -0
  250. package/dist/src/infrastructure/cache/services/cache.tokens.js +5 -0
  251. package/dist/src/infrastructure/cache/services/cache.tokens.js.map +1 -0
  252. package/dist/src/infrastructure/cache/services/noop-cache.service.d.ts +6 -0
  253. package/dist/src/infrastructure/cache/services/noop-cache.service.js +24 -0
  254. package/dist/src/infrastructure/cache/services/noop-cache.service.js.map +1 -0
  255. package/dist/src/infrastructure/cache/services/revision-cache.service.d.ts +10 -0
  256. package/dist/src/infrastructure/cache/services/revision-cache.service.js +39 -0
  257. package/dist/src/infrastructure/cache/services/revision-cache.service.js.map +1 -0
  258. package/dist/src/infrastructure/cache/services/row-cache.service.d.ts +26 -0
  259. package/dist/src/infrastructure/cache/services/row-cache.service.js +68 -0
  260. package/dist/src/infrastructure/cache/services/row-cache.service.js.map +1 -0
  261. package/dist/src/utils/utils/parse-bool.d.ts +1 -0
  262. package/dist/src/utils/utils/parse-bool.js +10 -0
  263. package/dist/src/utils/utils/parse-bool.js.map +1 -0
  264. package/dist/src/utils/utils/stable-cache-key.d.ts +12 -0
  265. package/dist/src/utils/utils/stable-cache-key.js +46 -0
  266. package/dist/src/utils/utils/stable-cache-key.js.map +1 -0
  267. package/dist/tsconfig.build.tsbuildinfo +1 -1
  268. package/package.json +16 -7
  269. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.d.ts +0 -16
  270. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js +0 -70
  271. package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js.map +0 -1
  272. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.d.ts +0 -52
  273. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js +0 -531
  274. package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js.map +0 -1
  275. package/dist/src/utils/prisma-sql-generator/index.d.ts +0 -2
  276. package/dist/src/utils/prisma-sql-generator/index.js.map +0 -1
  277. package/dist/src/utils/prisma-sql-generator/json-path.d.ts +0 -14
  278. package/dist/src/utils/prisma-sql-generator/json-path.js +0 -121
  279. package/dist/src/utils/prisma-sql-generator/json-path.js.map +0 -1
  280. package/dist/src/utils/prisma-sql-generator/types.d.ts +0 -105
  281. package/dist/src/utils/prisma-sql-generator/types.js +0 -3
  282. package/dist/src/utils/prisma-sql-generator/types.js.map +0 -1
  283. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.d.ts +0 -21
  284. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js +0 -499
  285. package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"json-path.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/json-path.ts"],"names":[],"mappings":"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"}
@@ -1,105 +0,0 @@
1
- export interface WhereConditions {
2
- versionId?: string | StringFilter;
3
- createdId?: string | StringFilter;
4
- id?: string | StringFilter;
5
- hash?: string | StringFilter;
6
- schemaHash?: string | StringFilter;
7
- readonly?: boolean | BoolFilter;
8
- createdAt?: string | Date | DateFilter;
9
- updatedAt?: string | Date | DateFilter;
10
- publishedAt?: string | Date | DateFilter;
11
- data?: JsonFilter;
12
- meta?: JsonFilter;
13
- AND?: WhereConditions[];
14
- OR?: WhereConditions[];
15
- NOT?: WhereConditions;
16
- }
17
- export interface SqlResult {
18
- sql: string;
19
- params: any[];
20
- }
21
- export interface JsonFilter {
22
- path: string[];
23
- equals?: any;
24
- string_contains?: string;
25
- string_starts_with?: string;
26
- string_ends_with?: string;
27
- gt?: number;
28
- gte?: number;
29
- lt?: number;
30
- lte?: number;
31
- in?: any[];
32
- notIn?: any[];
33
- array_contains?: any;
34
- array_starts_with?: any;
35
- array_ends_with?: any;
36
- not?: any;
37
- mode?: 'default' | 'insensitive';
38
- }
39
- export interface DateFilter {
40
- equals?: string | Date;
41
- gt?: string | Date;
42
- gte?: string | Date;
43
- lt?: string | Date;
44
- lte?: string | Date;
45
- in?: (string | Date)[];
46
- notIn?: (string | Date)[];
47
- }
48
- export interface BoolFilter {
49
- equals?: boolean;
50
- not?: boolean;
51
- }
52
- export interface StringFilter {
53
- equals?: string;
54
- contains?: string;
55
- startsWith?: string;
56
- endsWith?: string;
57
- in?: string[];
58
- notIn?: string[];
59
- lt?: string;
60
- lte?: string;
61
- gt?: string;
62
- gte?: string;
63
- not?: string;
64
- search?: string;
65
- mode?: 'default' | 'insensitive';
66
- }
67
- export interface JsonOrderInput {
68
- path: string | string[];
69
- direction?: 'asc' | 'desc';
70
- type?: JsonValueType;
71
- aggregation?: JsonAggregation;
72
- subPath?: string;
73
- }
74
- export interface RowOrderInput {
75
- versionId?: 'asc' | 'desc';
76
- createdId?: 'asc' | 'desc';
77
- id?: 'asc' | 'desc';
78
- readonly?: 'asc' | 'desc';
79
- createdAt?: 'asc' | 'desc';
80
- updatedAt?: 'asc' | 'desc';
81
- publishedAt?: 'asc' | 'desc';
82
- data?: 'asc' | 'desc' | JsonOrderInput;
83
- meta?: 'asc' | 'desc' | JsonOrderInput;
84
- hash?: 'asc' | 'desc';
85
- schemaHash?: 'asc' | 'desc';
86
- }
87
- export type JsonValueType = 'text' | 'int' | 'float' | 'boolean' | 'timestamp';
88
- export type JsonAggregation = 'min' | 'max' | 'avg' | 'first' | 'last';
89
- export interface GetRowsQueryParams {
90
- tableId: string;
91
- take: number;
92
- skip: number;
93
- whereConditions?: WhereConditions;
94
- orderBy?: RowOrderInput[];
95
- }
96
- export interface RenderedQuery {
97
- sql: string;
98
- params: any[];
99
- }
100
- export interface GetRowsOptions {
101
- take?: number;
102
- skip?: number;
103
- orderBy?: RowOrderInput | RowOrderInput[];
104
- where?: WhereConditions;
105
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/types.ts"],"names":[],"mappings":""}
@@ -1,21 +0,0 @@
1
- import { Prisma } from '@prisma/client';
2
- import { WhereConditions, GetRowsOptions, RowOrderInput } from './types';
3
- export declare class WhereGeneratorPrisma {
4
- generateWhere(conditions?: WhereConditions): Prisma.Sql;
5
- private processConditions;
6
- private combineWithAnd;
7
- private combineWithOr;
8
- generateOrderBy(orderBy?: any[]): Prisma.Sql;
9
- private processStringField;
10
- private processBoolField;
11
- private processDateField;
12
- private processJsonField;
13
- private static readonly VALID_ORDER_FIELDS;
14
- private getFieldReference;
15
- private combineOrderBy;
16
- private generateJsonOrderBy;
17
- private generateArrayAggregationOrder;
18
- generateGetRowsQueryPrisma(tableId: string, options?: GetRowsOptions): Prisma.Sql;
19
- generateGetRowsQuery(tableId: string, take: number, skip: number, whereConditions?: WhereConditions, orderBy?: RowOrderInput[]): Prisma.Sql;
20
- }
21
- export declare function generateGetRowsQueryPrisma(tableId: string, take: number, skip: number, whereConditions?: WhereConditions, orderBy?: any[]): Prisma.Sql;
@@ -1,499 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.WhereGeneratorPrisma = void 0;
4
- exports.generateGetRowsQueryPrisma = generateGetRowsQueryPrisma;
5
- const client_1 = require("@prisma/client");
6
- const json_path_1 = require("./json-path");
7
- class WhereGeneratorPrisma {
8
- generateWhere(conditions) {
9
- if (!conditions || Object.keys(conditions).length === 0) {
10
- return client_1.Prisma.sql `TRUE`;
11
- }
12
- return this.processConditions(conditions);
13
- }
14
- processConditions(conditions) {
15
- const clauses = [];
16
- if (Array.isArray(conditions.AND) && conditions.AND.length > 0) {
17
- const andClauses = conditions.AND.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
18
- if (andClauses.length > 0) {
19
- clauses.push(client_1.Prisma.sql `(${this.combineWithAnd(andClauses)})`);
20
- }
21
- }
22
- if (Array.isArray(conditions.OR) && conditions.OR.length > 0) {
23
- const orClauses = conditions.OR.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
24
- if (orClauses.length > 0) {
25
- clauses.push(client_1.Prisma.sql `(${this.combineWithOr(orClauses)})`);
26
- }
27
- }
28
- if (conditions.NOT) {
29
- const notClause = this.processConditions(conditions.NOT);
30
- clauses.push(client_1.Prisma.sql `NOT (${notClause})`);
31
- }
32
- if (conditions.versionId !== undefined) {
33
- clauses.push(this.processStringField('versionId', conditions.versionId));
34
- }
35
- if (conditions.createdId !== undefined) {
36
- clauses.push(this.processStringField('createdId', conditions.createdId));
37
- }
38
- if (conditions.id !== undefined) {
39
- clauses.push(this.processStringField('id', conditions.id));
40
- }
41
- if (conditions.hash !== undefined) {
42
- clauses.push(this.processStringField('hash', conditions.hash));
43
- }
44
- if (conditions.schemaHash !== undefined) {
45
- clauses.push(this.processStringField('schemaHash', conditions.schemaHash));
46
- }
47
- if (conditions.readonly !== undefined) {
48
- clauses.push(this.processBoolField('readonly', conditions.readonly));
49
- }
50
- if (conditions.createdAt !== undefined) {
51
- clauses.push(this.processDateField('createdAt', conditions.createdAt));
52
- }
53
- if (conditions.updatedAt !== undefined) {
54
- clauses.push(this.processDateField('updatedAt', conditions.updatedAt));
55
- }
56
- if (conditions.publishedAt !== undefined) {
57
- clauses.push(this.processDateField('publishedAt', conditions.publishedAt));
58
- }
59
- if (conditions.data !== undefined) {
60
- clauses.push(this.processJsonField('data', conditions.data));
61
- }
62
- if (conditions.meta !== undefined) {
63
- clauses.push(this.processJsonField('meta', conditions.meta));
64
- }
65
- if (clauses.length === 0) {
66
- return client_1.Prisma.sql `TRUE`;
67
- }
68
- if (clauses.length === 1) {
69
- return clauses[0];
70
- }
71
- return this.combineWithAnd(clauses);
72
- }
73
- combineWithAnd(clauses) {
74
- if (clauses.length === 0) {
75
- return client_1.Prisma.sql `TRUE`;
76
- }
77
- if (clauses.length === 1) {
78
- return clauses[0];
79
- }
80
- let result = clauses[0];
81
- for (let i = 1; i < clauses.length; i++) {
82
- result = client_1.Prisma.sql `${result} AND ${clauses[i]}`;
83
- }
84
- return result;
85
- }
86
- combineWithOr(clauses) {
87
- if (clauses.length === 0) {
88
- return client_1.Prisma.sql `FALSE`;
89
- }
90
- if (clauses.length === 1) {
91
- return clauses[0];
92
- }
93
- let result = clauses[0];
94
- for (let i = 1; i < clauses.length; i++) {
95
- result = client_1.Prisma.sql `${result} OR ${clauses[i]}`;
96
- }
97
- return result;
98
- }
99
- generateOrderBy(orderBy) {
100
- if (!orderBy || orderBy.length === 0) {
101
- return client_1.Prisma.sql `r."createdAt" DESC`;
102
- }
103
- const orderClauses = [];
104
- for (const orderItem of orderBy) {
105
- for (const [field, direction] of Object.entries(orderItem)) {
106
- if (typeof direction === 'string') {
107
- const fieldRef = this.getFieldReference(field);
108
- const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
109
- orderClauses.push(client_1.Prisma.sql `${fieldRef} ${sortOrder}`);
110
- }
111
- else if (typeof direction === 'object' && direction !== null) {
112
- const jsonOrderClause = this.generateJsonOrderBy(field, direction);
113
- orderClauses.push(jsonOrderClause);
114
- }
115
- }
116
- }
117
- return orderClauses.length > 0
118
- ? this.combineOrderBy(orderClauses)
119
- : client_1.Prisma.sql `r."createdAt" DESC`;
120
- }
121
- processStringField(field, condition) {
122
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
123
- if (typeof condition === 'string') {
124
- return client_1.Prisma.sql `${fieldRef} = ${condition}`;
125
- }
126
- const filter = condition;
127
- const mode = filter.mode || 'default';
128
- const isInsensitive = mode === 'insensitive';
129
- if (filter.equals !== undefined) {
130
- if (isInsensitive) {
131
- return client_1.Prisma.sql `${fieldRef} ILIKE ${filter.equals}`;
132
- }
133
- return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
134
- }
135
- if (filter.contains !== undefined) {
136
- const pattern = `%${filter.contains}%`;
137
- if (isInsensitive) {
138
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
139
- }
140
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
141
- }
142
- if (filter.startsWith !== undefined) {
143
- const pattern = `${filter.startsWith}%`;
144
- if (isInsensitive) {
145
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
146
- }
147
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
148
- }
149
- if (filter.endsWith !== undefined) {
150
- const pattern = `%${filter.endsWith}`;
151
- if (isInsensitive) {
152
- return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
153
- }
154
- return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
155
- }
156
- if (filter.in !== undefined) {
157
- if (Array.isArray(filter.in) && filter.in.length === 0) {
158
- return client_1.Prisma.sql `FALSE`;
159
- }
160
- return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(filter.in)})`;
161
- }
162
- if (filter.notIn !== undefined) {
163
- if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
164
- return client_1.Prisma.sql `TRUE`;
165
- }
166
- return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(filter.notIn)})`;
167
- }
168
- if (filter.gt !== undefined) {
169
- return client_1.Prisma.sql `${fieldRef} > ${filter.gt}`;
170
- }
171
- if (filter.gte !== undefined) {
172
- return client_1.Prisma.sql `${fieldRef} >= ${filter.gte}`;
173
- }
174
- if (filter.lt !== undefined) {
175
- return client_1.Prisma.sql `${fieldRef} < ${filter.lt}`;
176
- }
177
- if (filter.lte !== undefined) {
178
- return client_1.Prisma.sql `${fieldRef} <= ${filter.lte}`;
179
- }
180
- if (filter.not !== undefined) {
181
- return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
182
- }
183
- if (filter.search !== undefined) {
184
- if (typeof filter.search !== 'string') {
185
- throw new Error('Full-text search term must be a string');
186
- }
187
- if (filter.search.length > 1000) {
188
- throw new Error('Full-text search term too long (max 1000 characters)');
189
- }
190
- return client_1.Prisma.sql `to_tsvector('simple', ${fieldRef}) @@ plainto_tsquery('simple', ${filter.search})`;
191
- }
192
- throw new Error(`Unsupported StringFilter: ${JSON.stringify(filter)}`);
193
- }
194
- processBoolField(field, condition) {
195
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
196
- if (typeof condition === 'boolean') {
197
- return client_1.Prisma.sql `${fieldRef} = ${condition}`;
198
- }
199
- const filter = condition;
200
- if (filter.equals !== undefined) {
201
- return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
202
- }
203
- if (filter.not !== undefined) {
204
- return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
205
- }
206
- throw new Error(`Unsupported BoolFilter: ${JSON.stringify(filter)}`);
207
- }
208
- processDateField(field, condition) {
209
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
210
- if (typeof condition === 'string' || condition instanceof Date) {
211
- const dateStr = condition instanceof Date ? condition.toISOString() : condition;
212
- return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
213
- }
214
- const filter = condition;
215
- const clauses = [];
216
- if (filter.equals !== undefined) {
217
- const dateStr = filter.equals instanceof Date
218
- ? filter.equals.toISOString()
219
- : filter.equals;
220
- return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
221
- }
222
- if (filter.gt !== undefined) {
223
- const dateStr = filter.gt instanceof Date ? filter.gt.toISOString() : filter.gt;
224
- clauses.push(client_1.Prisma.sql `${fieldRef} > ${dateStr}::timestamp`);
225
- }
226
- if (filter.gte !== undefined) {
227
- const dateStr = filter.gte instanceof Date ? filter.gte.toISOString() : filter.gte;
228
- clauses.push(client_1.Prisma.sql `${fieldRef} >= ${dateStr}::timestamp`);
229
- }
230
- if (filter.lt !== undefined) {
231
- const dateStr = filter.lt instanceof Date ? filter.lt.toISOString() : filter.lt;
232
- clauses.push(client_1.Prisma.sql `${fieldRef} < ${dateStr}::timestamp`);
233
- }
234
- if (filter.lte !== undefined) {
235
- const dateStr = filter.lte instanceof Date ? filter.lte.toISOString() : filter.lte;
236
- clauses.push(client_1.Prisma.sql `${fieldRef} <= ${dateStr}::timestamp`);
237
- }
238
- if (clauses.length > 0) {
239
- return this.combineWithAnd(clauses);
240
- }
241
- if (filter.in !== undefined) {
242
- if (Array.isArray(filter.in) && filter.in.length === 0) {
243
- return client_1.Prisma.sql `FALSE`;
244
- }
245
- const dateStrs = filter.in.map((d) => d instanceof Date ? d.toISOString() : d);
246
- const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
247
- return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(castDates)})`;
248
- }
249
- if (filter.notIn !== undefined) {
250
- if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
251
- return client_1.Prisma.sql `TRUE`;
252
- }
253
- const dateStrs = filter.notIn.map((d) => d instanceof Date ? d.toISOString() : d);
254
- const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
255
- return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(castDates)})`;
256
- }
257
- throw new Error(`Unsupported DateFilter: ${JSON.stringify(filter)}`);
258
- }
259
- processJsonField(field, condition) {
260
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
261
- const { path, mode = 'default' } = condition;
262
- const isInsensitive = mode === 'insensitive';
263
- const pathParam = path.length === 1 ? path[0] : `{${path.join(',')}}`;
264
- const jsonTextPath = path.length === 1
265
- ? client_1.Prisma.sql `${fieldRef}->>${pathParam}`
266
- : client_1.Prisma.sql `${fieldRef}#>>${pathParam}`;
267
- if (condition.equals !== undefined) {
268
- if (typeof condition.equals === 'string' && isInsensitive) {
269
- return client_1.Prisma.sql `LOWER(${jsonTextPath}) = LOWER(${condition.equals})`;
270
- }
271
- if (typeof condition.equals === 'string') {
272
- return client_1.Prisma.sql `${jsonTextPath} = ${condition.equals}`;
273
- }
274
- const jsonValue = JSON.stringify(condition.equals);
275
- return client_1.Prisma.sql `${jsonTextPath} = ${jsonValue}`;
276
- }
277
- if (condition.string_contains !== undefined) {
278
- const pattern = `%${condition.string_contains}%`;
279
- if (isInsensitive) {
280
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
281
- }
282
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
283
- }
284
- if (condition.string_starts_with !== undefined) {
285
- const pattern = `${condition.string_starts_with}%`;
286
- if (isInsensitive) {
287
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
288
- }
289
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
290
- }
291
- if (condition.string_ends_with !== undefined) {
292
- const pattern = `%${condition.string_ends_with}`;
293
- if (isInsensitive) {
294
- return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
295
- }
296
- return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
297
- }
298
- if (condition.gt !== undefined) {
299
- return client_1.Prisma.sql `(${jsonTextPath})::numeric > ${condition.gt}`;
300
- }
301
- if (condition.gte !== undefined) {
302
- return client_1.Prisma.sql `(${jsonTextPath})::numeric >= ${condition.gte}`;
303
- }
304
- if (condition.lt !== undefined) {
305
- return client_1.Prisma.sql `(${jsonTextPath})::numeric < ${condition.lt}`;
306
- }
307
- if (condition.lte !== undefined) {
308
- return client_1.Prisma.sql `(${jsonTextPath})::numeric <= ${condition.lte}`;
309
- }
310
- if (condition.array_contains !== undefined) {
311
- const jsonValue = JSON.stringify(condition.array_contains);
312
- return client_1.Prisma.sql `${fieldRef} @> ${jsonValue}::jsonb`;
313
- }
314
- if (condition.in !== undefined) {
315
- if (Array.isArray(condition.in) && condition.in.length === 0) {
316
- return client_1.Prisma.sql `FALSE`;
317
- }
318
- const values = condition.in.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
319
- return client_1.Prisma.sql `${jsonTextPath} IN (${client_1.Prisma.join(values)})`;
320
- }
321
- if (condition.notIn !== undefined) {
322
- if (Array.isArray(condition.notIn) && condition.notIn.length === 0) {
323
- return client_1.Prisma.sql `TRUE`;
324
- }
325
- const values = condition.notIn.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
326
- return client_1.Prisma.sql `${jsonTextPath} NOT IN (${client_1.Prisma.join(values)})`;
327
- }
328
- if (condition.not !== undefined) {
329
- if (typeof condition.not === 'string') {
330
- return client_1.Prisma.sql `${jsonTextPath} != ${condition.not}`;
331
- }
332
- const jsonValue = JSON.stringify(condition.not);
333
- return client_1.Prisma.sql `${jsonTextPath} != ${jsonValue}`;
334
- }
335
- throw new Error(`Unsupported JsonFilter: ${JSON.stringify(condition)}`);
336
- }
337
- getFieldReference(fieldName) {
338
- if (!WhereGeneratorPrisma.VALID_ORDER_FIELDS.has(fieldName)) {
339
- throw new Error(`Invalid ORDER BY field: ${fieldName}. Allowed fields: ${Array.from(WhereGeneratorPrisma.VALID_ORDER_FIELDS).join(', ')}`);
340
- }
341
- return client_1.Prisma.raw(`r."${fieldName}"`);
342
- }
343
- combineOrderBy(clauses) {
344
- if (clauses.length === 0) {
345
- return client_1.Prisma.sql `r."createdAt" DESC`;
346
- }
347
- if (clauses.length === 1) {
348
- return clauses[0];
349
- }
350
- let result = clauses[0];
351
- for (let i = 1; i < clauses.length; i++) {
352
- result = client_1.Prisma.sql `${result}, ${clauses[i]}`;
353
- }
354
- return result;
355
- }
356
- generateJsonOrderBy(field, jsonOrder) {
357
- const { path, direction = 'asc', type = 'text', aggregation = 'first', } = jsonOrder;
358
- const fieldRef = client_1.Prisma.raw(`r."${field}"`);
359
- const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
360
- const pgPath = typeof path === 'string' ? (0, json_path_1.parseJsonPath)(path) : path;
361
- (0, json_path_1.validateJsonPath)(pgPath);
362
- if ((0, json_path_1.hasArrayWildcard)(path) || aggregation !== 'first') {
363
- return this.generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder);
364
- }
365
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(pgPath)}'`);
366
- const sqlType = (0, json_path_1.getSqlType)(type);
367
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
368
- }
369
- generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder) {
370
- const sqlType = (0, json_path_1.getSqlType)(type);
371
- const { beforeStar, afterStar, starIndex } = (0, json_path_1.splitPathAtWildcard)(pgPath);
372
- if (starIndex === -1) {
373
- const modifiedPath = (0, json_path_1.handleArrayAggregation)(pgPath, aggregation);
374
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(modifiedPath)}'`);
375
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
376
- }
377
- const arrayPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(beforeStar)}'`);
378
- switch (aggregation) {
379
- case 'min':
380
- if (afterStar.length > 0) {
381
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
382
- return client_1.Prisma.sql `(SELECT MIN((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
383
- }
384
- else {
385
- return client_1.Prisma.sql `(SELECT MIN(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
386
- }
387
- case 'max':
388
- if (afterStar.length > 0) {
389
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
390
- return client_1.Prisma.sql `(SELECT MAX((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
391
- }
392
- else {
393
- return client_1.Prisma.sql `(SELECT MAX(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
394
- }
395
- case 'avg':
396
- if (afterStar.length > 0) {
397
- const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
398
- return client_1.Prisma.sql `(SELECT AVG((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
399
- }
400
- else {
401
- return client_1.Prisma.sql `(SELECT AVG(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
402
- }
403
- case 'last': {
404
- const lastPath = [...beforeStar, '-1', ...afterStar];
405
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(lastPath)}'`);
406
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
407
- }
408
- case 'first':
409
- default: {
410
- const firstPath = [...beforeStar, '0', ...afterStar];
411
- const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(firstPath)}'`);
412
- return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
413
- }
414
- }
415
- }
416
- generateGetRowsQueryPrisma(tableId, options = {}) {
417
- const takeNum = Number(options.take ?? 50);
418
- const take = Math.max(1, Math.min(500, isNaN(takeNum) ? 50 : takeNum));
419
- const skipNum = Number(options.skip ?? 0);
420
- const skip = Math.max(0, isNaN(skipNum) ? 0 : skipNum);
421
- const orderByArray = Array.isArray(options.orderBy)
422
- ? options.orderBy
423
- : options.orderBy
424
- ? [options.orderBy]
425
- : [];
426
- const whereSql = this.generateWhere(options.where || {});
427
- const orderSql = this.generateOrderBy(orderByArray);
428
- return client_1.Prisma.sql `
429
- SELECT
430
- r."versionId",
431
- r."createdId",
432
- r."id",
433
- r."readonly",
434
- r."createdAt",
435
- r."updatedAt",
436
- r."publishedAt",
437
- r."data",
438
- r."meta",
439
- r."hash",
440
- r."schemaHash"
441
- FROM "Row" r
442
- INNER JOIN "_RowToTable" rt ON rt."A" = r."versionId"
443
- WHERE rt."B" = ${tableId}
444
- AND ${whereSql}
445
- ORDER BY ${orderSql}
446
- LIMIT ${take}
447
- OFFSET ${skip}
448
- `;
449
- }
450
- generateGetRowsQuery(tableId, take, skip, whereConditions, orderBy) {
451
- return this.generateGetRowsQueryPrisma(tableId, {
452
- take,
453
- skip,
454
- where: whereConditions,
455
- orderBy,
456
- });
457
- }
458
- }
459
- exports.WhereGeneratorPrisma = WhereGeneratorPrisma;
460
- WhereGeneratorPrisma.VALID_ORDER_FIELDS = new Set([
461
- 'versionId',
462
- 'createdId',
463
- 'id',
464
- 'hash',
465
- 'schemaHash',
466
- 'readonly',
467
- 'createdAt',
468
- 'updatedAt',
469
- 'publishedAt',
470
- 'data',
471
- 'meta',
472
- ]);
473
- function generateGetRowsQueryPrisma(tableId, take, skip, whereConditions, orderBy) {
474
- const generator = new WhereGeneratorPrisma();
475
- const whereClause = generator.generateWhere(whereConditions || {});
476
- const orderByClause = generator.generateOrderBy(orderBy || []);
477
- return client_1.Prisma.sql `
478
- SELECT
479
- r."versionId",
480
- r."createdId",
481
- r."id",
482
- r."readonly",
483
- r."createdAt",
484
- r."updatedAt",
485
- r."publishedAt",
486
- r."data",
487
- r."meta",
488
- r."hash",
489
- r."schemaHash"
490
- FROM "Row" r
491
- INNER JOIN "_RowToTable" rt ON r."versionId" = rt."A"
492
- WHERE rt."B" = ${tableId}
493
- AND (${whereClause})
494
- ORDER BY ${orderByClause}
495
- LIMIT ${take}
496
- OFFSET ${skip}
497
- `;
498
- }
499
- //# sourceMappingURL=where-generator.prisma.js.map