@revisium/core 2.6.0-alpha.1 → 2.6.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 (367) hide show
  1. package/dist/package.json +1 -1
  2. package/dist/src/__tests__/utils/prepareProject.js +4 -3
  3. package/dist/src/__tests__/utils/prepareProject.js.map +1 -1
  4. package/dist/src/api/graphql-api/draft/draft.resolver.d.ts +5 -1
  5. package/dist/src/api/graphql-api/draft/draft.resolver.js +49 -0
  6. package/dist/src/api/graphql-api/draft/draft.resolver.js.map +1 -1
  7. package/dist/src/api/graphql-api/draft/input/create-rows.input.d.ts +11 -0
  8. package/dist/src/api/graphql-api/draft/input/create-rows.input.js +56 -0
  9. package/dist/src/api/graphql-api/draft/input/create-rows.input.js.map +1 -0
  10. package/dist/src/api/graphql-api/draft/input/index.d.ts +3 -0
  11. package/dist/src/api/graphql-api/draft/input/index.js +3 -0
  12. package/dist/src/api/graphql-api/draft/input/index.js.map +1 -1
  13. package/dist/src/api/graphql-api/draft/input/patch-rows.input.d.ts +10 -0
  14. package/dist/src/api/graphql-api/draft/input/patch-rows.input.js +52 -0
  15. package/dist/src/api/graphql-api/draft/input/patch-rows.input.js.map +1 -0
  16. package/dist/src/api/graphql-api/draft/input/update-rows.input.d.ts +10 -0
  17. package/dist/src/api/graphql-api/draft/input/update-rows.input.js +52 -0
  18. package/dist/src/api/graphql-api/draft/input/update-rows.input.js.map +1 -0
  19. package/dist/src/api/graphql-api/draft/model/create-rows-result.model.d.ts +7 -0
  20. package/dist/src/api/graphql-api/draft/model/create-rows-result.model.js +34 -0
  21. package/dist/src/api/graphql-api/draft/model/create-rows-result.model.js.map +1 -0
  22. package/dist/src/api/graphql-api/draft/model/patch-rows-result.model.d.ts +7 -0
  23. package/dist/src/api/graphql-api/draft/model/patch-rows-result.model.js +34 -0
  24. package/dist/src/api/graphql-api/draft/model/patch-rows-result.model.js.map +1 -0
  25. package/dist/src/api/graphql-api/draft/model/update-rows-result.model.d.ts +7 -0
  26. package/dist/src/api/graphql-api/draft/model/update-rows-result.model.js +34 -0
  27. package/dist/src/api/graphql-api/draft/model/update-rows-result.model.js.map +1 -0
  28. package/dist/src/api/mcp-api/tools/row.tools.js +122 -0
  29. package/dist/src/api/mcp-api/tools/row.tools.js.map +1 -1
  30. package/dist/src/api/rest-api/table/dto/create-rows.dto.d.ts +9 -0
  31. package/dist/src/api/rest-api/table/dto/create-rows.dto.js +44 -0
  32. package/dist/src/api/rest-api/table/dto/create-rows.dto.js.map +1 -0
  33. package/dist/src/api/rest-api/table/dto/index.d.ts +3 -0
  34. package/dist/src/api/rest-api/table/dto/index.js +3 -0
  35. package/dist/src/api/rest-api/table/dto/index.js.map +1 -1
  36. package/dist/src/api/rest-api/table/dto/patch-rows.dto.d.ts +8 -0
  37. package/dist/src/api/rest-api/table/dto/patch-rows.dto.js +44 -0
  38. package/dist/src/api/rest-api/table/dto/patch-rows.dto.js.map +1 -0
  39. package/dist/src/api/rest-api/table/dto/update-rows.dto.d.ts +8 -0
  40. package/dist/src/api/rest-api/table/dto/update-rows.dto.js +40 -0
  41. package/dist/src/api/rest-api/table/dto/update-rows.dto.js.map +1 -0
  42. package/dist/src/api/rest-api/table/model/create-rows.response.d.ts +7 -0
  43. package/dist/src/api/rest-api/table/model/create-rows.response.js +31 -0
  44. package/dist/src/api/rest-api/table/model/create-rows.response.js.map +1 -0
  45. package/dist/src/api/rest-api/table/model/index.d.ts +3 -0
  46. package/dist/src/api/rest-api/table/model/index.js +3 -0
  47. package/dist/src/api/rest-api/table/model/index.js.map +1 -1
  48. package/dist/src/api/rest-api/table/model/patch-rows.response.d.ts +7 -0
  49. package/dist/src/api/rest-api/table/model/patch-rows.response.js +31 -0
  50. package/dist/src/api/rest-api/table/model/patch-rows.response.js.map +1 -0
  51. package/dist/src/api/rest-api/table/model/update-rows.response.d.ts +7 -0
  52. package/dist/src/api/rest-api/table/model/update-rows.response.js +31 -0
  53. package/dist/src/api/rest-api/table/model/update-rows.response.js.map +1 -0
  54. package/dist/src/api/rest-api/table/table-by-id.controller.d.ts +5 -2
  55. package/dist/src/api/rest-api/table/table-by-id.controller.js +88 -0
  56. package/dist/src/api/rest-api/table/table-by-id.controller.js.map +1 -1
  57. package/dist/src/features/branch/quieries/handlers/get-branch-by-id.handler.d.ts +5 -4
  58. package/dist/src/features/branch/quieries/handlers/get-branch-by-id.handler.js +7 -4
  59. package/dist/src/features/branch/quieries/handlers/get-branch-by-id.handler.js.map +1 -1
  60. package/dist/src/features/branch/quieries/handlers/get-draft-revision.handler.d.ts +4 -3
  61. package/dist/src/features/branch/quieries/handlers/get-draft-revision.handler.js +7 -4
  62. package/dist/src/features/branch/quieries/handlers/get-draft-revision.handler.js.map +1 -1
  63. package/dist/src/features/branch/quieries/handlers/get-head-revision.handler.d.ts +4 -3
  64. package/dist/src/features/branch/quieries/handlers/get-head-revision.handler.js +7 -4
  65. package/dist/src/features/branch/quieries/handlers/get-head-revision.handler.js.map +1 -1
  66. package/dist/src/features/branch/quieries/handlers/get-project-by-branch.handler.d.ts +5 -4
  67. package/dist/src/features/branch/quieries/handlers/get-project-by-branch.handler.js +7 -4
  68. package/dist/src/features/branch/quieries/handlers/get-project-by-branch.handler.js.map +1 -1
  69. package/dist/src/features/branch/quieries/handlers/get-revisions-by-branch-id.handler.d.ts +4 -3
  70. package/dist/src/features/branch/quieries/handlers/get-revisions-by-branch-id.handler.js +7 -4
  71. package/dist/src/features/branch/quieries/handlers/get-revisions-by-branch-id.handler.js.map +1 -1
  72. package/dist/src/features/branch/quieries/handlers/get-start-revision.handler.d.ts +4 -3
  73. package/dist/src/features/branch/quieries/handlers/get-start-revision.handler.js +7 -4
  74. package/dist/src/features/branch/quieries/handlers/get-start-revision.handler.js.map +1 -1
  75. package/dist/src/features/branch/quieries/handlers/resolve-parent-branch-by-branch.handler.d.ts +4 -3
  76. package/dist/src/features/branch/quieries/handlers/resolve-parent-branch-by-branch.handler.js +7 -4
  77. package/dist/src/features/branch/quieries/handlers/resolve-parent-branch-by-branch.handler.js.map +1 -1
  78. package/dist/src/features/draft/commands/handlers/__tests__/utils.js +8 -0
  79. package/dist/src/features/draft/commands/handlers/__tests__/utils.js.map +1 -1
  80. package/dist/src/features/draft/commands/handlers/api-base-row.handler.d.ts +37 -0
  81. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js +32 -0
  82. package/dist/src/features/draft/commands/handlers/api-base-row.handler.js.map +1 -1
  83. package/dist/src/features/draft/commands/handlers/api-create-row.handler.d.ts +5 -1
  84. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js +13 -10
  85. package/dist/src/features/draft/commands/handlers/api-create-row.handler.js.map +1 -1
  86. package/dist/src/features/draft/commands/handlers/api-create-rows.handler.d.ts +37 -0
  87. package/dist/src/features/draft/commands/handlers/api-create-rows.handler.js +78 -0
  88. package/dist/src/features/draft/commands/handlers/api-create-rows.handler.js.map +1 -0
  89. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.d.ts +6 -1
  90. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js +18 -10
  91. package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js.map +1 -1
  92. package/dist/src/features/draft/commands/handlers/api-patch-rows.handler.d.ts +37 -0
  93. package/dist/src/features/draft/commands/handlers/api-patch-rows.handler.js +53 -0
  94. package/dist/src/features/draft/commands/handlers/api-patch-rows.handler.js.map +1 -0
  95. package/dist/src/features/draft/commands/handlers/api-update-row.handler.d.ts +6 -1
  96. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js +18 -10
  97. package/dist/src/features/draft/commands/handlers/api-update-row.handler.js.map +1 -1
  98. package/dist/src/features/draft/commands/handlers/api-update-rows.handler.d.ts +37 -0
  99. package/dist/src/features/draft/commands/handlers/api-update-rows.handler.js +53 -0
  100. package/dist/src/features/draft/commands/handlers/api-update-rows.handler.js.map +1 -0
  101. package/dist/src/features/draft/commands/handlers/create-revision.handler.d.ts +3 -14
  102. package/dist/src/features/draft/commands/handlers/create-revision.handler.js +16 -97
  103. package/dist/src/features/draft/commands/handlers/create-revision.handler.js.map +1 -1
  104. package/dist/src/features/draft/commands/handlers/create-rows.handler.d.ts +24 -0
  105. package/dist/src/features/draft/commands/handlers/{create-row.handler.js → create-rows.handler.js} +63 -44
  106. package/dist/src/features/draft/commands/handlers/create-rows.handler.js.map +1 -0
  107. package/dist/src/features/draft/commands/handlers/create-table.handler.d.ts +5 -10
  108. package/dist/src/features/draft/commands/handlers/create-table.handler.js +26 -63
  109. package/dist/src/features/draft/commands/handlers/create-table.handler.js.map +1 -1
  110. package/dist/src/features/draft/commands/handlers/index.d.ts +7 -7
  111. package/dist/src/features/draft/commands/handlers/index.js +12 -12
  112. package/dist/src/features/draft/commands/handlers/index.js.map +1 -1
  113. package/dist/src/features/draft/commands/handlers/{patch-row.handler.d.ts → patch-rows.handler.d.ts} +8 -7
  114. package/dist/src/features/draft/commands/handlers/{patch-row.handler.js → patch-rows.handler.js} +50 -32
  115. package/dist/src/features/draft/commands/handlers/patch-rows.handler.js.map +1 -0
  116. package/dist/src/features/draft/commands/handlers/remove-rows.handler.d.ts +3 -9
  117. package/dist/src/features/draft/commands/handlers/remove-rows.handler.js +12 -78
  118. package/dist/src/features/draft/commands/handlers/remove-rows.handler.js.map +1 -1
  119. package/dist/src/features/draft/commands/handlers/remove-table.handler.d.ts +3 -8
  120. package/dist/src/features/draft/commands/handlers/remove-table.handler.js +6 -39
  121. package/dist/src/features/draft/commands/handlers/remove-table.handler.js.map +1 -1
  122. package/dist/src/features/draft/commands/handlers/rename-row.handler.d.ts +1 -4
  123. package/dist/src/features/draft/commands/handlers/rename-row.handler.js +1 -13
  124. package/dist/src/features/draft/commands/handlers/rename-row.handler.js.map +1 -1
  125. package/dist/src/features/draft/commands/handlers/rename-table.handler.d.ts +3 -8
  126. package/dist/src/features/draft/commands/handlers/rename-table.handler.js +13 -48
  127. package/dist/src/features/draft/commands/handlers/rename-table.handler.js.map +1 -1
  128. package/dist/src/features/draft/commands/handlers/revert-changes.handler.d.ts +3 -4
  129. package/dist/src/features/draft/commands/handlers/revert-changes.handler.js +8 -36
  130. package/dist/src/features/draft/commands/handlers/revert-changes.handler.js.map +1 -1
  131. package/dist/src/features/draft/commands/handlers/transactional/internal-create-row.handler.d.ts +3 -16
  132. package/dist/src/features/draft/commands/handlers/transactional/internal-create-row.handler.js +21 -76
  133. package/dist/src/features/draft/commands/handlers/transactional/internal-create-row.handler.js.map +1 -1
  134. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.d.ts +3 -14
  135. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js +16 -69
  136. package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js.map +1 -1
  137. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.d.ts +3 -10
  138. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js +24 -41
  139. package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js.map +1 -1
  140. package/dist/src/features/draft/commands/handlers/transactional/internal-update-rows.handler.d.ts +6 -13
  141. package/dist/src/features/draft/commands/handlers/transactional/internal-update-rows.handler.js +14 -45
  142. package/dist/src/features/draft/commands/handlers/transactional/internal-update-rows.handler.js.map +1 -1
  143. package/dist/src/features/draft/commands/handlers/update-rows.handler.d.ts +26 -0
  144. package/dist/src/features/draft/commands/handlers/update-rows.handler.js +110 -0
  145. package/dist/src/features/draft/commands/handlers/update-rows.handler.js.map +1 -0
  146. package/dist/src/features/draft/commands/handlers/update-table.handler.d.ts +1 -4
  147. package/dist/src/features/draft/commands/handlers/update-table.handler.js +8 -21
  148. package/dist/src/features/draft/commands/handlers/update-table.handler.js.map +1 -1
  149. package/dist/src/features/draft/commands/handlers/upload-file.handler.d.ts +3 -7
  150. package/dist/src/features/draft/commands/handlers/upload-file.handler.js +14 -26
  151. package/dist/src/features/draft/commands/handlers/upload-file.handler.js.map +1 -1
  152. package/dist/src/features/draft/commands/impl/api-create-rows.command.d.ts +20 -0
  153. package/dist/src/features/draft/commands/impl/api-create-rows.command.js +10 -0
  154. package/dist/src/features/draft/commands/impl/api-create-rows.command.js.map +1 -0
  155. package/dist/src/features/draft/commands/impl/api-patch-rows.command.d.ts +18 -0
  156. package/dist/src/features/draft/commands/impl/api-patch-rows.command.js +10 -0
  157. package/dist/src/features/draft/commands/impl/api-patch-rows.command.js.map +1 -0
  158. package/dist/src/features/draft/commands/impl/api-update-rows.command.d.ts +18 -0
  159. package/dist/src/features/draft/commands/impl/api-update-rows.command.js +10 -0
  160. package/dist/src/features/draft/commands/impl/api-update-rows.command.js.map +1 -0
  161. package/dist/src/features/draft/commands/impl/{create-row.command.d.ts → create-rows.command.d.ts} +8 -5
  162. package/dist/src/features/draft/commands/impl/create-rows.command.js +10 -0
  163. package/dist/src/features/draft/commands/impl/create-rows.command.js.map +1 -0
  164. package/dist/src/features/draft/commands/impl/patch-rows.command.d.ts +18 -0
  165. package/dist/src/features/draft/commands/impl/patch-rows.command.js +10 -0
  166. package/dist/src/features/draft/commands/impl/patch-rows.command.js.map +1 -0
  167. package/dist/src/features/draft/commands/impl/transactional/internal-update-rows.command.d.ts +4 -0
  168. package/dist/src/features/draft/commands/impl/transactional/internal-update-rows.command.js.map +1 -1
  169. package/dist/src/features/draft/commands/impl/update-rows.command.d.ts +18 -0
  170. package/dist/src/features/draft/commands/impl/update-rows.command.js +10 -0
  171. package/dist/src/features/draft/commands/impl/update-rows.command.js.map +1 -0
  172. package/dist/src/features/draft/commands/types/api-create-rows.handler.types.d.ts +7 -0
  173. package/dist/src/features/draft/commands/types/api-create-rows.handler.types.js +3 -0
  174. package/dist/src/features/draft/commands/types/api-create-rows.handler.types.js.map +1 -0
  175. package/dist/src/features/draft/commands/types/api-patch-rows.handler.types.d.ts +7 -0
  176. package/dist/src/features/draft/commands/types/api-patch-rows.handler.types.js +3 -0
  177. package/dist/src/features/draft/commands/types/api-patch-rows.handler.types.js.map +1 -0
  178. package/dist/src/features/draft/commands/types/api-update-rows.handler.types.d.ts +7 -0
  179. package/dist/src/features/draft/commands/types/api-update-rows.handler.types.js +3 -0
  180. package/dist/src/features/draft/commands/types/api-update-rows.handler.types.js.map +1 -0
  181. package/dist/src/features/draft/commands/types/create-rows.handler.types.d.ts +9 -0
  182. package/dist/src/features/draft/commands/types/{update-row.handler.types.js → create-rows.handler.types.js} +1 -1
  183. package/dist/src/features/draft/commands/types/create-rows.handler.types.js.map +1 -0
  184. package/dist/src/features/draft/commands/types/patch-rows.handler.types.d.ts +10 -0
  185. package/dist/src/features/draft/commands/types/{create-row.handler.types.js → patch-rows.handler.types.js} +1 -1
  186. package/dist/src/features/draft/commands/types/patch-rows.handler.types.js.map +1 -0
  187. package/dist/src/features/draft/commands/types/update-rows.handler.types.d.ts +10 -0
  188. package/dist/src/features/draft/commands/types/update-rows.handler.types.js +3 -0
  189. package/dist/src/features/draft/commands/types/update-rows.handler.types.js.map +1 -0
  190. package/dist/src/features/draft/draft-api.service.d.ts +9 -0
  191. package/dist/src/features/draft/draft-api.service.js +12 -0
  192. package/dist/src/features/draft/draft-api.service.js.map +1 -1
  193. package/dist/src/features/draft/draft-request-dto/index.d.ts +1 -1
  194. package/dist/src/features/draft/draft.module.js +2 -0
  195. package/dist/src/features/draft/draft.module.js.map +1 -1
  196. package/dist/src/features/draft/draft.transactional.commands.d.ts +0 -3
  197. package/dist/src/features/draft/draft.transactional.commands.js +0 -12
  198. package/dist/src/features/draft/draft.transactional.commands.js.map +1 -1
  199. package/dist/src/features/draft-revision/commands/handlers/__tests__/utils.d.ts +20 -0
  200. package/dist/src/features/draft-revision/commands/handlers/__tests__/utils.js +98 -0
  201. package/dist/src/features/draft-revision/commands/handlers/__tests__/utils.js.map +1 -0
  202. package/dist/src/features/draft-revision/commands/handlers/draft-revision-commit.handler.d.ts +19 -0
  203. package/dist/src/features/draft-revision/commands/handlers/draft-revision-commit.handler.js +91 -0
  204. package/dist/src/features/draft-revision/commands/handlers/draft-revision-commit.handler.js.map +1 -0
  205. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-rows.handler.d.ts +19 -0
  206. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-rows.handler.js +109 -0
  207. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-rows.handler.js.map +1 -0
  208. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-table.handler.d.ts +16 -0
  209. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-table.handler.js +68 -0
  210. package/dist/src/features/draft-revision/commands/handlers/draft-revision-create-table.handler.js.map +1 -0
  211. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-row.handler.d.ts +19 -0
  212. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-row.handler.js +121 -0
  213. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-row.handler.js.map +1 -0
  214. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-table.handler.d.ts +20 -0
  215. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-table.handler.js +126 -0
  216. package/dist/src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-table.handler.js.map +1 -0
  217. package/dist/src/features/draft-revision/commands/handlers/draft-revision-recompute-has-changes.handler.d.ts +15 -0
  218. package/dist/src/features/draft-revision/commands/handlers/draft-revision-recompute-has-changes.handler.js +90 -0
  219. package/dist/src/features/draft-revision/commands/handlers/draft-revision-recompute-has-changes.handler.js.map +1 -0
  220. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-rows.handler.d.ts +17 -0
  221. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-rows.handler.js +104 -0
  222. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-rows.handler.js.map +1 -0
  223. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-table.handler.d.ts +21 -0
  224. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-table.handler.js +117 -0
  225. package/dist/src/features/draft-revision/commands/handlers/draft-revision-remove-table.handler.js.map +1 -0
  226. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-rows.handler.d.ts +17 -0
  227. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-rows.handler.js +108 -0
  228. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-rows.handler.js.map +1 -0
  229. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-table.handler.d.ts +14 -0
  230. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-table.handler.js +58 -0
  231. package/dist/src/features/draft-revision/commands/handlers/draft-revision-rename-table.handler.js.map +1 -0
  232. package/dist/src/features/draft-revision/commands/handlers/draft-revision-revert.handler.d.ts +14 -0
  233. package/dist/src/features/draft-revision/commands/handlers/draft-revision-revert.handler.js +52 -0
  234. package/dist/src/features/draft-revision/commands/handlers/draft-revision-revert.handler.js.map +1 -0
  235. package/dist/src/features/draft-revision/commands/handlers/draft-revision-update-rows.handler.d.ts +16 -0
  236. package/dist/src/features/draft-revision/commands/handlers/draft-revision-update-rows.handler.js +96 -0
  237. package/dist/src/features/draft-revision/commands/handlers/draft-revision-update-rows.handler.js.map +1 -0
  238. package/dist/src/features/draft-revision/commands/handlers/index.d.ts +25 -0
  239. package/dist/src/features/draft-revision/commands/handlers/index.js +54 -0
  240. package/dist/src/features/draft-revision/commands/handlers/index.js.map +1 -0
  241. package/dist/src/features/draft-revision/commands/impl/draft-revision-commit.command.d.ts +13 -0
  242. package/dist/src/features/draft-revision/commands/impl/draft-revision-commit.command.js +10 -0
  243. package/dist/src/features/draft-revision/commands/impl/draft-revision-commit.command.js.map +1 -0
  244. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-rows.command.d.ts +27 -0
  245. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-rows.command.js +10 -0
  246. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-rows.command.js.map +1 -0
  247. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-table.command.d.ts +13 -0
  248. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-table.command.js +10 -0
  249. package/dist/src/features/draft-revision/commands/impl/draft-revision-create-table.command.js.map +1 -0
  250. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-row.command.d.ts +14 -0
  251. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-row.command.js +10 -0
  252. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-row.command.js.map +1 -0
  253. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-table.command.d.ts +14 -0
  254. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-table.command.js +10 -0
  255. package/dist/src/features/draft-revision/commands/impl/draft-revision-get-or-create-draft-table.command.js.map +1 -0
  256. package/dist/src/features/draft-revision/commands/impl/draft-revision-recompute-has-changes.command.d.ts +8 -0
  257. package/dist/src/features/draft-revision/commands/impl/draft-revision-recompute-has-changes.command.js +10 -0
  258. package/dist/src/features/draft-revision/commands/impl/draft-revision-recompute-has-changes.command.js.map +1 -0
  259. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-rows.command.d.ts +18 -0
  260. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-rows.command.js +10 -0
  261. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-rows.command.js.map +1 -0
  262. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-table.command.d.ts +12 -0
  263. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-table.command.js +10 -0
  264. package/dist/src/features/draft-revision/commands/impl/draft-revision-remove-table.command.js.map +1 -0
  265. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-rows.command.d.ts +23 -0
  266. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-rows.command.js +10 -0
  267. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-rows.command.js.map +1 -0
  268. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-table.command.d.ts +13 -0
  269. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-table.command.js +10 -0
  270. package/dist/src/features/draft-revision/commands/impl/draft-revision-rename-table.command.js.map +1 -0
  271. package/dist/src/features/draft-revision/commands/impl/draft-revision-revert.command.d.ts +10 -0
  272. package/dist/src/features/draft-revision/commands/impl/draft-revision-revert.command.js +10 -0
  273. package/dist/src/features/draft-revision/commands/impl/draft-revision-revert.command.js.map +1 -0
  274. package/dist/src/features/draft-revision/commands/impl/draft-revision-update-rows.command.d.ts +26 -0
  275. package/dist/src/features/draft-revision/commands/impl/draft-revision-update-rows.command.js +10 -0
  276. package/dist/src/features/draft-revision/commands/impl/draft-revision-update-rows.command.js.map +1 -0
  277. package/dist/src/features/draft-revision/commands/impl/index.d.ts +12 -0
  278. package/dist/src/features/draft-revision/commands/impl/index.js +29 -0
  279. package/dist/src/features/draft-revision/commands/impl/index.js.map +1 -0
  280. package/dist/src/features/draft-revision/draft-revision-api.service.d.ts +15 -0
  281. package/dist/src/features/draft-revision/draft-revision-api.service.js +53 -0
  282. package/dist/src/features/draft-revision/draft-revision-api.service.js.map +1 -0
  283. package/dist/src/features/draft-revision/draft-revision.constants.d.ts +2 -0
  284. package/dist/src/features/draft-revision/draft-revision.constants.js +6 -0
  285. package/dist/src/features/draft-revision/draft-revision.constants.js.map +1 -0
  286. package/dist/src/features/draft-revision/draft-revision.module.d.ts +2 -0
  287. package/dist/src/features/draft-revision/draft-revision.module.js +40 -0
  288. package/dist/src/features/draft-revision/draft-revision.module.js.map +1 -0
  289. package/dist/src/features/draft-revision/services/draft-revision-internal.service.d.ts +59 -0
  290. package/dist/src/features/draft-revision/services/draft-revision-internal.service.js +110 -0
  291. package/dist/src/features/draft-revision/services/draft-revision-internal.service.js.map +1 -0
  292. package/dist/src/features/draft-revision/services/draft-revision-validation.service.d.ts +10 -0
  293. package/dist/src/features/draft-revision/services/draft-revision-validation.service.js +49 -0
  294. package/dist/src/features/draft-revision/services/draft-revision-validation.service.js.map +1 -0
  295. package/dist/src/features/draft-revision/services/index.d.ts +2 -0
  296. package/dist/src/features/draft-revision/services/index.js +19 -0
  297. package/dist/src/features/draft-revision/services/index.js.map +1 -0
  298. package/dist/src/features/revision/queries/commands/get-children-by-revision.handler.d.ts +4 -3
  299. package/dist/src/features/revision/queries/commands/get-children-by-revision.handler.js +7 -4
  300. package/dist/src/features/revision/queries/commands/get-children-by-revision.handler.js.map +1 -1
  301. package/dist/src/features/revision/queries/commands/get-endpoints-by-revision-id.handler.d.ts +4 -3
  302. package/dist/src/features/revision/queries/commands/get-endpoints-by-revision-id.handler.js +7 -4
  303. package/dist/src/features/revision/queries/commands/get-endpoints-by-revision-id.handler.js.map +1 -1
  304. package/dist/src/features/revision/queries/commands/get-migrations.handler.d.ts +4 -3
  305. package/dist/src/features/revision/queries/commands/get-migrations.handler.js +7 -4
  306. package/dist/src/features/revision/queries/commands/get-migrations.handler.js.map +1 -1
  307. package/dist/src/features/revision/queries/commands/get-revision.handler.d.ts +5 -4
  308. package/dist/src/features/revision/queries/commands/get-revision.handler.js +7 -4
  309. package/dist/src/features/revision/queries/commands/get-revision.handler.js.map +1 -1
  310. package/dist/src/features/revision/queries/commands/get-tables-by-revision-id.handler.d.ts +4 -3
  311. package/dist/src/features/revision/queries/commands/get-tables-by-revision-id.handler.js +7 -4
  312. package/dist/src/features/revision/queries/commands/get-tables-by-revision-id.handler.js.map +1 -1
  313. package/dist/src/features/revision/queries/commands/resolve-branch-by-revision.handler.d.ts +5 -4
  314. package/dist/src/features/revision/queries/commands/resolve-branch-by-revision.handler.js +7 -4
  315. package/dist/src/features/revision/queries/commands/resolve-branch-by-revision.handler.js.map +1 -1
  316. package/dist/src/features/revision/queries/commands/resolve-child-branches-by-revision.handler.d.ts +4 -3
  317. package/dist/src/features/revision/queries/commands/resolve-child-branches-by-revision.handler.js +7 -4
  318. package/dist/src/features/revision/queries/commands/resolve-child-branches-by-revision.handler.js.map +1 -1
  319. package/dist/src/features/revision/queries/commands/resolve-child-by-revision.handler.d.ts +4 -3
  320. package/dist/src/features/revision/queries/commands/resolve-child-by-revision.handler.js +7 -4
  321. package/dist/src/features/revision/queries/commands/resolve-child-by-revision.handler.js.map +1 -1
  322. package/dist/src/features/revision/queries/commands/resolve-parent-by-revision.handler.d.ts +5 -4
  323. package/dist/src/features/revision/queries/commands/resolve-parent-by-revision.handler.js +7 -4
  324. package/dist/src/features/revision/queries/commands/resolve-parent-by-revision.handler.js.map +1 -1
  325. package/dist/src/features/row/queries/handlers/get-row.handler.d.ts +3 -7
  326. package/dist/src/features/row/queries/handlers/get-row.handler.js +18 -21
  327. package/dist/src/features/row/queries/handlers/get-row.handler.js.map +1 -1
  328. package/dist/src/main.js +4 -1
  329. package/dist/src/main.js.map +1 -1
  330. package/dist/tsconfig.build.tsbuildinfo +1 -1
  331. package/package.json +1 -1
  332. package/dist/src/features/draft/commands/handlers/create-row.handler.d.ts +0 -24
  333. package/dist/src/features/draft/commands/handlers/create-row.handler.js.map +0 -1
  334. package/dist/src/features/draft/commands/handlers/patch-row.handler.js.map +0 -1
  335. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-row.handler.d.ts +0 -23
  336. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-row.handler.js +0 -102
  337. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-row.handler.js.map +0 -1
  338. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-rows.handler.d.ts +0 -21
  339. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-rows.handler.js +0 -144
  340. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-rows.handler.js.map +0 -1
  341. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-table.handler.d.ts +0 -21
  342. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-table.handler.js +0 -101
  343. package/dist/src/features/draft/commands/handlers/transactional/get-or-create-draft-table.handler.js.map +0 -1
  344. package/dist/src/features/draft/commands/handlers/update-row.handler.d.ts +0 -26
  345. package/dist/src/features/draft/commands/handlers/update-row.handler.js +0 -88
  346. package/dist/src/features/draft/commands/handlers/update-row.handler.js.map +0 -1
  347. package/dist/src/features/draft/commands/impl/create-row.command.js +0 -10
  348. package/dist/src/features/draft/commands/impl/create-row.command.js.map +0 -1
  349. package/dist/src/features/draft/commands/impl/patch-row.command.d.ts +0 -22
  350. package/dist/src/features/draft/commands/impl/patch-row.command.js +0 -10
  351. package/dist/src/features/draft/commands/impl/patch-row.command.js.map +0 -1
  352. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-row.command.d.ts +0 -4
  353. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-row.command.js +0 -10
  354. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-row.command.js.map +0 -1
  355. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-rows.command.d.ts +0 -4
  356. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-rows.command.js +0 -10
  357. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-rows.command.js.map +0 -1
  358. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-table.command.d.ts +0 -4
  359. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-table.command.js +0 -10
  360. package/dist/src/features/draft/commands/impl/transactional/get-or-create-draft-table.command.js.map +0 -1
  361. package/dist/src/features/draft/commands/impl/update-row.command.d.ts +0 -17
  362. package/dist/src/features/draft/commands/impl/update-row.command.js +0 -10
  363. package/dist/src/features/draft/commands/impl/update-row.command.js.map +0 -1
  364. package/dist/src/features/draft/commands/types/create-row.handler.types.d.ts +0 -5
  365. package/dist/src/features/draft/commands/types/create-row.handler.types.js.map +0 -1
  366. package/dist/src/features/draft/commands/types/update-row.handler.types.d.ts +0 -6
  367. package/dist/src/features/draft/commands/types/update-row.handler.types.js.map +0 -1
@@ -0,0 +1,16 @@
1
+ import { ICommandHandler } from '@nestjs/cqrs';
2
+ import { DraftRevisionCreateTableCommand } from '../../../../features/draft-revision/commands/impl/draft-revision-create-table.command';
3
+ import { DraftRevisionCreateTableCommandReturnType } from '../../../../features/draft-revision/commands/impl';
4
+ import { DraftRevisionInternalService, DraftRevisionValidationService } from '../../../../features/draft-revision/services';
5
+ import { IdService } from '../../../../infrastructure/database/id.service';
6
+ import { TransactionPrismaService } from '../../../../infrastructure/database/transaction-prisma.service';
7
+ export declare class DraftRevisionCreateTableHandler implements ICommandHandler<DraftRevisionCreateTableCommand> {
8
+ private readonly transactionService;
9
+ private readonly idService;
10
+ private readonly validationService;
11
+ private readonly internalService;
12
+ constructor(transactionService: TransactionPrismaService, idService: IdService, validationService: DraftRevisionValidationService, internalService: DraftRevisionInternalService);
13
+ private get transaction();
14
+ execute({ data, }: DraftRevisionCreateTableCommand): Promise<DraftRevisionCreateTableCommandReturnType>;
15
+ private createTableInRevision;
16
+ }
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.DraftRevisionCreateTableHandler = void 0;
13
+ const cqrs_1 = require("@nestjs/cqrs");
14
+ const draft_revision_create_table_command_1 = require("../impl/draft-revision-create-table.command");
15
+ const services_1 = require("../../services");
16
+ const id_service_1 = require("../../../../infrastructure/database/id.service");
17
+ const transaction_prisma_service_1 = require("../../../../infrastructure/database/transaction-prisma.service");
18
+ let DraftRevisionCreateTableHandler = class DraftRevisionCreateTableHandler {
19
+ constructor(transactionService, idService, validationService, internalService) {
20
+ this.transactionService = transactionService;
21
+ this.idService = idService;
22
+ this.validationService = validationService;
23
+ this.internalService = internalService;
24
+ }
25
+ get transaction() {
26
+ return this.transactionService.getTransaction();
27
+ }
28
+ async execute({ data, }) {
29
+ const { revisionId, tableId, system = false } = data;
30
+ const revision = await this.internalService.findRevisionOrThrow(revisionId);
31
+ this.validationService.ensureDraftRevision(revision);
32
+ this.validationService.ensureValidTableId(tableId);
33
+ await this.internalService.ensureTableNotExists(revisionId, tableId);
34
+ const result = await this.createTableInRevision({
35
+ revisionId,
36
+ tableId,
37
+ system,
38
+ });
39
+ await this.internalService.markRevisionAsChanged(revisionId);
40
+ return result;
41
+ }
42
+ async createTableInRevision(input) {
43
+ const tableVersionId = this.idService.generate();
44
+ const tableCreatedId = this.idService.generate();
45
+ await this.transaction.table.create({
46
+ data: {
47
+ versionId: tableVersionId,
48
+ createdId: tableCreatedId,
49
+ id: input.tableId,
50
+ system: input.system,
51
+ revisions: {
52
+ connect: { id: input.revisionId },
53
+ },
54
+ },
55
+ select: { versionId: true },
56
+ });
57
+ return { tableVersionId, tableCreatedId };
58
+ }
59
+ };
60
+ exports.DraftRevisionCreateTableHandler = DraftRevisionCreateTableHandler;
61
+ exports.DraftRevisionCreateTableHandler = DraftRevisionCreateTableHandler = __decorate([
62
+ (0, cqrs_1.CommandHandler)(draft_revision_create_table_command_1.DraftRevisionCreateTableCommand),
63
+ __metadata("design:paramtypes", [transaction_prisma_service_1.TransactionPrismaService,
64
+ id_service_1.IdService,
65
+ services_1.DraftRevisionValidationService,
66
+ services_1.DraftRevisionInternalService])
67
+ ], DraftRevisionCreateTableHandler);
68
+ //# sourceMappingURL=draft-revision-create-table.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"draft-revision-create-table.handler.js","sourceRoot":"","sources":["../../../../../../src/features/draft-revision/commands/handlers/draft-revision-create-table.handler.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,uCAA+D;AAC/D,qGAAgI;AAEhI,6CAG8C;AAC9C,+EAAmE;AACnE,+GAAkG;AAG3F,IAAM,+BAA+B,GAArC,MAAM,+BAA+B;IAG1C,YACmB,kBAA4C,EAC5C,SAAoB,EACpB,iBAAiD,EACjD,eAA6C;QAH7C,uBAAkB,GAAlB,kBAAkB,CAA0B;QAC5C,cAAS,GAAT,SAAS,CAAW;QACpB,sBAAiB,GAAjB,iBAAiB,CAAgC;QACjD,oBAAe,GAAf,eAAe,CAA8B;IAC7D,CAAC;IAEJ,IAAY,WAAW;QACrB,OAAO,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,EACZ,IAAI,GAC4B;QAChC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC;QAErD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAC5E,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACnD,MAAM,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAErE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC;YAC9C,UAAU;YACV,OAAO;YACP,MAAM;SACP,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,eAAe,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;QAE7D,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAAC,KAInC;QACC,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QACjD,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAEjD,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC;YAClC,IAAI,EAAE;gBACJ,SAAS,EAAE,cAAc;gBACzB,SAAS,EAAE,cAAc;gBACzB,EAAE,EAAE,KAAK,CAAC,OAAO;gBACjB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,SAAS,EAAE;oBACT,OAAO,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,UAAU,EAAE;iBAClC;aACF;YACD,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE;SAC5B,CAAC,CAAC;QAEH,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC;IAC5C,CAAC;CACF,CAAA;AA1DY,0EAA+B;0CAA/B,+BAA+B;IAD3C,IAAA,qBAAc,EAAC,qEAA+B,CAAC;qCAKP,qDAAwB;QACjC,sBAAS;QACD,yCAA8B;QAChC,uCAA4B;GAPrD,+BAA+B,CA0D3C"}
@@ -0,0 +1,19 @@
1
+ import { ICommandHandler } from '@nestjs/cqrs';
2
+ import { DraftRevisionGetOrCreateDraftRowCommand } from '../../../../features/draft-revision/commands/impl/draft-revision-get-or-create-draft-row.command';
3
+ import { DraftRevisionGetOrCreateDraftRowCommandReturnType } from '../../../../features/draft-revision/commands/impl';
4
+ import { IdService } from '../../../../infrastructure/database/id.service';
5
+ import { TransactionPrismaService } from '../../../../infrastructure/database/transaction-prisma.service';
6
+ export declare class DraftRevisionGetOrCreateDraftRowHandler implements ICommandHandler<DraftRevisionGetOrCreateDraftRowCommand> {
7
+ private readonly transactionService;
8
+ private readonly idService;
9
+ constructor(transactionService: TransactionPrismaService, idService: IdService);
10
+ private get transaction();
11
+ execute({ data, }: DraftRevisionGetOrCreateDraftRowCommand): Promise<DraftRevisionGetOrCreateDraftRowCommandReturnType>;
12
+ private findRowOrThrow;
13
+ private buildExistingResult;
14
+ private createNewRowVersion;
15
+ private replaceRowInTable;
16
+ private findRowInTable;
17
+ private cloneRow;
18
+ private disconnectRowFromTable;
19
+ }
@@ -0,0 +1,121 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.DraftRevisionGetOrCreateDraftRowHandler = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const cqrs_1 = require("@nestjs/cqrs");
15
+ const draft_revision_get_or_create_draft_row_command_1 = require("../impl/draft-revision-get-or-create-draft-row.command");
16
+ const id_service_1 = require("../../../../infrastructure/database/id.service");
17
+ const transaction_prisma_service_1 = require("../../../../infrastructure/database/transaction-prisma.service");
18
+ let DraftRevisionGetOrCreateDraftRowHandler = class DraftRevisionGetOrCreateDraftRowHandler {
19
+ constructor(transactionService, idService) {
20
+ this.transactionService = transactionService;
21
+ this.idService = idService;
22
+ }
23
+ get transaction() {
24
+ return this.transactionService.getTransaction();
25
+ }
26
+ async execute({ data, }) {
27
+ const { tableVersionId, rowId } = data;
28
+ const row = await this.findRowOrThrow(tableVersionId, rowId);
29
+ if (!row.readonly) {
30
+ return this.buildExistingResult(row);
31
+ }
32
+ return this.createNewRowVersion(tableVersionId, rowId, row);
33
+ }
34
+ async findRowOrThrow(tableVersionId, rowId) {
35
+ const row = await this.findRowInTable(tableVersionId, rowId);
36
+ if (!row) {
37
+ throw new common_1.BadRequestException(`Row "${rowId}" not found in table`);
38
+ }
39
+ return row;
40
+ }
41
+ buildExistingResult(row) {
42
+ return {
43
+ rowVersionId: row.versionId,
44
+ previousRowVersionId: row.versionId,
45
+ rowCreatedId: row.createdId,
46
+ wasCreated: false,
47
+ };
48
+ }
49
+ async createNewRowVersion(tableVersionId, rowId, previousRow) {
50
+ const newRowVersionId = await this.cloneRow(tableVersionId, rowId, previousRow);
51
+ await this.replaceRowInTable(tableVersionId, previousRow.versionId);
52
+ return {
53
+ rowVersionId: newRowVersionId,
54
+ previousRowVersionId: previousRow.versionId,
55
+ rowCreatedId: previousRow.createdId,
56
+ wasCreated: true,
57
+ };
58
+ }
59
+ async replaceRowInTable(tableVersionId, oldRowVersionId) {
60
+ await this.disconnectRowFromTable(tableVersionId, oldRowVersionId);
61
+ }
62
+ async findRowInTable(tableVersionId, rowId) {
63
+ return this.transaction.row.findFirst({
64
+ where: {
65
+ id: rowId,
66
+ tables: {
67
+ some: { versionId: tableVersionId },
68
+ },
69
+ },
70
+ select: {
71
+ versionId: true,
72
+ createdId: true,
73
+ readonly: true,
74
+ data: true,
75
+ meta: true,
76
+ hash: true,
77
+ schemaHash: true,
78
+ createdAt: true,
79
+ publishedAt: true,
80
+ },
81
+ });
82
+ }
83
+ async cloneRow(tableVersionId, rowId, previousRow) {
84
+ const newRowVersionId = this.idService.generate();
85
+ await this.transaction.row.create({
86
+ data: {
87
+ versionId: newRowVersionId,
88
+ createdId: previousRow.createdId,
89
+ id: rowId,
90
+ readonly: false,
91
+ tables: {
92
+ connect: { versionId: tableVersionId },
93
+ },
94
+ data: previousRow.data,
95
+ meta: previousRow.meta,
96
+ hash: previousRow.hash,
97
+ schemaHash: previousRow.schemaHash,
98
+ createdAt: previousRow.createdAt,
99
+ publishedAt: previousRow.publishedAt ?? undefined,
100
+ },
101
+ });
102
+ return newRowVersionId;
103
+ }
104
+ async disconnectRowFromTable(tableVersionId, rowVersionId) {
105
+ await this.transaction.table.update({
106
+ where: { versionId: tableVersionId },
107
+ data: {
108
+ rows: {
109
+ disconnect: { versionId: rowVersionId },
110
+ },
111
+ },
112
+ });
113
+ }
114
+ };
115
+ exports.DraftRevisionGetOrCreateDraftRowHandler = DraftRevisionGetOrCreateDraftRowHandler;
116
+ exports.DraftRevisionGetOrCreateDraftRowHandler = DraftRevisionGetOrCreateDraftRowHandler = __decorate([
117
+ (0, cqrs_1.CommandHandler)(draft_revision_get_or_create_draft_row_command_1.DraftRevisionGetOrCreateDraftRowCommand),
118
+ __metadata("design:paramtypes", [transaction_prisma_service_1.TransactionPrismaService,
119
+ id_service_1.IdService])
120
+ ], DraftRevisionGetOrCreateDraftRowHandler);
121
+ //# sourceMappingURL=draft-revision-get-or-create-draft-row.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"draft-revision-get-or-create-draft-row.handler.js","sourceRoot":"","sources":["../../../../../../src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-row.handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { ICommandHandler } from '@nestjs/cqrs';
2
+ import { DraftRevisionGetOrCreateDraftTableCommand } from '../../../../features/draft-revision/commands/impl/draft-revision-get-or-create-draft-table.command';
3
+ import { DraftRevisionGetOrCreateDraftTableCommandReturnType } from '../../../../features/draft-revision/commands/impl';
4
+ import { IdService } from '../../../../infrastructure/database/id.service';
5
+ import { TransactionPrismaService } from '../../../../infrastructure/database/transaction-prisma.service';
6
+ export declare class DraftRevisionGetOrCreateDraftTableHandler implements ICommandHandler<DraftRevisionGetOrCreateDraftTableCommand> {
7
+ private readonly transactionService;
8
+ private readonly idService;
9
+ constructor(transactionService: TransactionPrismaService, idService: IdService);
10
+ private get transaction();
11
+ execute({ data, }: DraftRevisionGetOrCreateDraftTableCommand): Promise<DraftRevisionGetOrCreateDraftTableCommandReturnType>;
12
+ private findTableOrThrow;
13
+ private buildExistingResult;
14
+ private createNewTableVersion;
15
+ private replaceTableInRevision;
16
+ private findTableInRevision;
17
+ private getTableRows;
18
+ private cloneTable;
19
+ private disconnectTableFromRevision;
20
+ }
@@ -0,0 +1,126 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.DraftRevisionGetOrCreateDraftTableHandler = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const cqrs_1 = require("@nestjs/cqrs");
15
+ const draft_revision_get_or_create_draft_table_command_1 = require("../impl/draft-revision-get-or-create-draft-table.command");
16
+ const id_service_1 = require("../../../../infrastructure/database/id.service");
17
+ const transaction_prisma_service_1 = require("../../../../infrastructure/database/transaction-prisma.service");
18
+ let DraftRevisionGetOrCreateDraftTableHandler = class DraftRevisionGetOrCreateDraftTableHandler {
19
+ constructor(transactionService, idService) {
20
+ this.transactionService = transactionService;
21
+ this.idService = idService;
22
+ }
23
+ get transaction() {
24
+ return this.transactionService.getTransaction();
25
+ }
26
+ async execute({ data, }) {
27
+ const { revisionId, tableId } = data;
28
+ const table = await this.findTableOrThrow(revisionId, tableId);
29
+ if (!table.readonly) {
30
+ return this.buildExistingResult(table);
31
+ }
32
+ return this.createNewTableVersion(revisionId, tableId, table);
33
+ }
34
+ async findTableOrThrow(revisionId, tableId) {
35
+ const table = await this.findTableInRevision(revisionId, tableId);
36
+ if (!table) {
37
+ throw new common_1.BadRequestException(`Table "${tableId}" not found in revision`);
38
+ }
39
+ return table;
40
+ }
41
+ buildExistingResult(table) {
42
+ return {
43
+ tableVersionId: table.versionId,
44
+ previousTableVersionId: table.versionId,
45
+ tableCreatedId: table.createdId,
46
+ wasCreated: false,
47
+ };
48
+ }
49
+ async createNewTableVersion(revisionId, tableId, previousTable) {
50
+ const newTableVersionId = await this.cloneTable(revisionId, tableId, previousTable);
51
+ await this.replaceTableInRevision(revisionId, previousTable.versionId);
52
+ return {
53
+ tableVersionId: newTableVersionId,
54
+ previousTableVersionId: previousTable.versionId,
55
+ tableCreatedId: previousTable.createdId,
56
+ wasCreated: true,
57
+ };
58
+ }
59
+ async replaceTableInRevision(revisionId, oldTableVersionId) {
60
+ await this.disconnectTableFromRevision(revisionId, oldTableVersionId);
61
+ }
62
+ async findTableInRevision(revisionId, tableId) {
63
+ return this.transaction.table.findFirst({
64
+ where: {
65
+ id: tableId,
66
+ revisions: {
67
+ some: { id: revisionId },
68
+ },
69
+ },
70
+ select: {
71
+ versionId: true,
72
+ createdId: true,
73
+ readonly: true,
74
+ system: true,
75
+ createdAt: true,
76
+ },
77
+ });
78
+ }
79
+ async getTableRows(revisionId, tableVersionId) {
80
+ return this.transaction.table
81
+ .findUniqueOrThrow({
82
+ where: {
83
+ versionId: tableVersionId,
84
+ revisions: { some: { id: revisionId } },
85
+ },
86
+ })
87
+ .rows({ select: { versionId: true } });
88
+ }
89
+ async cloneTable(revisionId, tableId, previousTable) {
90
+ const previousRows = await this.getTableRows(revisionId, previousTable.versionId);
91
+ const newTableVersionId = this.idService.generate();
92
+ await this.transaction.table.create({
93
+ data: {
94
+ versionId: newTableVersionId,
95
+ createdId: previousTable.createdId,
96
+ system: previousTable.system,
97
+ createdAt: previousTable.createdAt,
98
+ id: tableId,
99
+ revisions: {
100
+ connect: { id: revisionId },
101
+ },
102
+ rows: {
103
+ connect: previousRows,
104
+ },
105
+ },
106
+ });
107
+ return newTableVersionId;
108
+ }
109
+ async disconnectTableFromRevision(revisionId, tableVersionId) {
110
+ await this.transaction.revision.update({
111
+ where: { id: revisionId },
112
+ data: {
113
+ tables: {
114
+ disconnect: { versionId: tableVersionId },
115
+ },
116
+ },
117
+ });
118
+ }
119
+ };
120
+ exports.DraftRevisionGetOrCreateDraftTableHandler = DraftRevisionGetOrCreateDraftTableHandler;
121
+ exports.DraftRevisionGetOrCreateDraftTableHandler = DraftRevisionGetOrCreateDraftTableHandler = __decorate([
122
+ (0, cqrs_1.CommandHandler)(draft_revision_get_or_create_draft_table_command_1.DraftRevisionGetOrCreateDraftTableCommand),
123
+ __metadata("design:paramtypes", [transaction_prisma_service_1.TransactionPrismaService,
124
+ id_service_1.IdService])
125
+ ], DraftRevisionGetOrCreateDraftTableHandler);
126
+ //# sourceMappingURL=draft-revision-get-or-create-draft-table.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"draft-revision-get-or-create-draft-table.handler.js","sourceRoot":"","sources":["../../../../../../src/features/draft-revision/commands/handlers/draft-revision-get-or-create-draft-table.handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { ICommandHandler } from '@nestjs/cqrs';
2
+ import { DraftRevisionRecomputeHasChangesCommand } from '../../../../features/draft-revision/commands/impl';
3
+ import { DiffService } from '../../../../features/share/diff.service';
4
+ import { ShareTransactionalQueries } from '../../../../features/share/share.transactional.queries';
5
+ import { TransactionPrismaService } from '../../../../infrastructure/database/transaction-prisma.service';
6
+ export declare class DraftRevisionRecomputeHasChangesHandler implements ICommandHandler<DraftRevisionRecomputeHasChangesCommand> {
7
+ private readonly transactionService;
8
+ private readonly diffService;
9
+ private readonly shareTransactionalQueries;
10
+ constructor(transactionService: TransactionPrismaService, diffService: DiffService, shareTransactionalQueries: ShareTransactionalQueries);
11
+ private get transaction();
12
+ execute({ data, }: DraftRevisionRecomputeHasChangesCommand): Promise<void>;
13
+ private revertTable;
14
+ private updateRevisionHasChanges;
15
+ }
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.DraftRevisionRecomputeHasChangesHandler = void 0;
13
+ const cqrs_1 = require("@nestjs/cqrs");
14
+ const impl_1 = require("../impl");
15
+ const diff_service_1 = require("../../../share/diff.service");
16
+ const share_transactional_queries_1 = require("../../../share/share.transactional.queries");
17
+ const transaction_prisma_service_1 = require("../../../../infrastructure/database/transaction-prisma.service");
18
+ let DraftRevisionRecomputeHasChangesHandler = class DraftRevisionRecomputeHasChangesHandler {
19
+ constructor(transactionService, diffService, shareTransactionalQueries) {
20
+ this.transactionService = transactionService;
21
+ this.diffService = diffService;
22
+ this.shareTransactionalQueries = shareTransactionalQueries;
23
+ }
24
+ get transaction() {
25
+ return this.transactionService.getTransaction();
26
+ }
27
+ async execute({ data, }) {
28
+ const { revisionId, tableId } = data;
29
+ const revision = await this.transaction.revision.findUniqueOrThrow({
30
+ where: { id: revisionId },
31
+ select: { parentId: true, branchId: true },
32
+ });
33
+ if (!revision.parentId) {
34
+ return;
35
+ }
36
+ const table = await this.shareTransactionalQueries.findTableInRevision(revisionId, tableId);
37
+ if (!table) {
38
+ await this.updateRevisionHasChanges(revisionId, revision.parentId);
39
+ return;
40
+ }
41
+ const hasRowChanges = await this.diffService.hasRowDiffs({
42
+ tableCreatedId: table.createdId,
43
+ fromRevisionId: revision.parentId,
44
+ toRevisionId: revisionId,
45
+ });
46
+ if (!hasRowChanges) {
47
+ await this.revertTable(revision.branchId, tableId);
48
+ }
49
+ await this.updateRevisionHasChanges(revisionId, revision.parentId);
50
+ }
51
+ async revertTable(branchId, tableId) {
52
+ const headRevision = await this.shareTransactionalQueries.findHeadRevisionInBranchOrThrow(branchId);
53
+ const draftRevision = await this.shareTransactionalQueries.findDraftRevisionInBranchOrThrow(branchId);
54
+ const tableInHead = await this.shareTransactionalQueries.findTableInRevision(headRevision.id, tableId);
55
+ const tableInDraft = await this.shareTransactionalQueries.findTableInRevisionOrThrow(draftRevision.id, tableId);
56
+ await this.transaction.revision.update({
57
+ where: { id: draftRevision.id },
58
+ data: {
59
+ tables: {
60
+ disconnect: {
61
+ versionId: tableInDraft.versionId,
62
+ },
63
+ ...(tableInHead && {
64
+ connect: {
65
+ versionId: tableInHead.versionId,
66
+ },
67
+ }),
68
+ },
69
+ },
70
+ });
71
+ }
72
+ async updateRevisionHasChanges(revisionId, parentRevisionId) {
73
+ const hasChanges = await this.diffService.hasTableDiffs({
74
+ fromRevisionId: parentRevisionId,
75
+ toRevisionId: revisionId,
76
+ });
77
+ await this.transaction.revision.update({
78
+ where: { id: revisionId },
79
+ data: { hasChanges },
80
+ });
81
+ }
82
+ };
83
+ exports.DraftRevisionRecomputeHasChangesHandler = DraftRevisionRecomputeHasChangesHandler;
84
+ exports.DraftRevisionRecomputeHasChangesHandler = DraftRevisionRecomputeHasChangesHandler = __decorate([
85
+ (0, cqrs_1.CommandHandler)(impl_1.DraftRevisionRecomputeHasChangesCommand),
86
+ __metadata("design:paramtypes", [transaction_prisma_service_1.TransactionPrismaService,
87
+ diff_service_1.DiffService,
88
+ share_transactional_queries_1.ShareTransactionalQueries])
89
+ ], DraftRevisionRecomputeHasChangesHandler);
90
+ //# sourceMappingURL=draft-revision-recompute-has-changes.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"draft-revision-recompute-has-changes.handler.js","sourceRoot":"","sources":["../../../../../../src/features/draft-revision/commands/handlers/draft-revision-recompute-has-changes.handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { ICommandHandler } from '@nestjs/cqrs';
2
+ import { DraftRevisionRemoveRowsCommand } from '../../../../features/draft-revision/commands/impl/draft-revision-remove-rows.command';
3
+ import { DraftRevisionRemoveRowsCommandReturnType } from '../../../../features/draft-revision/commands/impl';
4
+ import { DraftRevisionInternalService, DraftRevisionValidationService } from '../../../../features/draft-revision/services';
5
+ import { TransactionPrismaService } from '../../../../infrastructure/database/transaction-prisma.service';
6
+ export declare class DraftRevisionRemoveRowsHandler implements ICommandHandler<DraftRevisionRemoveRowsCommand> {
7
+ private readonly transactionService;
8
+ private readonly internalService;
9
+ private readonly validationService;
10
+ constructor(transactionService: TransactionPrismaService, internalService: DraftRevisionInternalService, validationService: DraftRevisionValidationService);
11
+ private get transaction();
12
+ execute({ data, }: DraftRevisionRemoveRowsCommand): Promise<DraftRevisionRemoveRowsCommandReturnType>;
13
+ private findRowsWithReadonly;
14
+ private ensureAllRowsFound;
15
+ private removeRows;
16
+ private buildResult;
17
+ }
@@ -0,0 +1,104 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.DraftRevisionRemoveRowsHandler = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const cqrs_1 = require("@nestjs/cqrs");
15
+ const draft_revision_remove_rows_command_1 = require("../impl/draft-revision-remove-rows.command");
16
+ const services_1 = require("../../services");
17
+ const transaction_prisma_service_1 = require("../../../../infrastructure/database/transaction-prisma.service");
18
+ let DraftRevisionRemoveRowsHandler = class DraftRevisionRemoveRowsHandler {
19
+ constructor(transactionService, internalService, validationService) {
20
+ this.transactionService = transactionService;
21
+ this.internalService = internalService;
22
+ this.validationService = validationService;
23
+ }
24
+ get transaction() {
25
+ return this.transactionService.getTransaction();
26
+ }
27
+ async execute({ data, }) {
28
+ const { revisionId, tableId, rowIds } = data;
29
+ const revision = await this.internalService.findRevisionOrThrow(revisionId);
30
+ this.validationService.ensureDraftRevision(revision);
31
+ const uniqueRowIds = [...new Set(rowIds)];
32
+ const tableResult = await this.internalService.getOrCreateDraftTable({
33
+ revisionId,
34
+ tableId,
35
+ });
36
+ const rows = await this.findRowsWithReadonly(tableResult.tableVersionId, uniqueRowIds);
37
+ this.ensureAllRowsFound(uniqueRowIds, rows);
38
+ const removedRows = await this.removeRows(tableResult.tableVersionId, rows);
39
+ await this.internalService.recomputeHasChanges(revisionId, tableId);
40
+ return this.buildResult(tableResult, removedRows);
41
+ }
42
+ async findRowsWithReadonly(tableVersionId, rowIds) {
43
+ return this.transaction.row.findMany({
44
+ where: {
45
+ id: { in: rowIds },
46
+ tables: {
47
+ some: { versionId: tableVersionId },
48
+ },
49
+ },
50
+ select: {
51
+ id: true,
52
+ versionId: true,
53
+ readonly: true,
54
+ },
55
+ });
56
+ }
57
+ ensureAllRowsFound(requestedRowIds, foundRows) {
58
+ const foundIds = new Set(foundRows.map((r) => r.id));
59
+ const missing = requestedRowIds.filter((id) => !foundIds.has(id));
60
+ if (missing.length > 0) {
61
+ throw new common_1.BadRequestException(`Rows not found in table: ${missing.join(', ')}`);
62
+ }
63
+ }
64
+ async removeRows(tableVersionId, rows) {
65
+ const toDelete = rows.filter((r) => !r.readonly);
66
+ const toDisconnect = rows.filter((r) => r.readonly);
67
+ if (toDelete.length > 0) {
68
+ await this.transaction.row.deleteMany({
69
+ where: {
70
+ versionId: { in: toDelete.map((r) => r.versionId) },
71
+ },
72
+ });
73
+ }
74
+ if (toDisconnect.length > 0) {
75
+ await this.transaction.table.update({
76
+ where: { versionId: tableVersionId },
77
+ data: {
78
+ rows: {
79
+ disconnect: toDisconnect.map((r) => ({ versionId: r.versionId })),
80
+ },
81
+ },
82
+ });
83
+ }
84
+ return rows.map((r) => ({
85
+ rowVersionId: r.versionId,
86
+ deleted: !r.readonly,
87
+ }));
88
+ }
89
+ buildResult(tableResult, removedRows) {
90
+ return {
91
+ tableVersionId: tableResult.tableVersionId,
92
+ previousTableVersionId: tableResult.previousTableVersionId,
93
+ removedRows,
94
+ };
95
+ }
96
+ };
97
+ exports.DraftRevisionRemoveRowsHandler = DraftRevisionRemoveRowsHandler;
98
+ exports.DraftRevisionRemoveRowsHandler = DraftRevisionRemoveRowsHandler = __decorate([
99
+ (0, cqrs_1.CommandHandler)(draft_revision_remove_rows_command_1.DraftRevisionRemoveRowsCommand),
100
+ __metadata("design:paramtypes", [transaction_prisma_service_1.TransactionPrismaService,
101
+ services_1.DraftRevisionInternalService,
102
+ services_1.DraftRevisionValidationService])
103
+ ], DraftRevisionRemoveRowsHandler);
104
+ //# sourceMappingURL=draft-revision-remove-rows.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"draft-revision-remove-rows.handler.js","sourceRoot":"","sources":["../../../../../../src/features/draft-revision/commands/handlers/draft-revision-remove-rows.handler.ts"],"names":[],"mappings":"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"}