@powerhousedao/reactor 6.0.0-dev.9 → 6.0.0-dev.91

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 (383) hide show
  1. package/dist/src/admin/document-integrity-service.d.ts +17 -0
  2. package/dist/src/admin/document-integrity-service.d.ts.map +1 -0
  3. package/dist/src/admin/types.d.ts +30 -0
  4. package/dist/src/admin/types.d.ts.map +1 -0
  5. package/dist/src/cache/collection-membership-cache.d.ts +14 -0
  6. package/dist/src/cache/collection-membership-cache.d.ts.map +1 -0
  7. package/dist/src/cache/document-meta-cache.d.ts +1 -0
  8. package/dist/src/cache/document-meta-cache.d.ts.map +1 -1
  9. package/dist/src/cache/kysely-operation-index.d.ts +11 -2
  10. package/dist/src/cache/kysely-operation-index.d.ts.map +1 -1
  11. package/dist/src/cache/kysely-write-cache.d.ts +10 -2
  12. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
  13. package/dist/src/cache/operation-index-types.d.ts +16 -2
  14. package/dist/src/cache/operation-index-types.d.ts.map +1 -1
  15. package/dist/src/cache/write/interfaces.d.ts +7 -2
  16. package/dist/src/cache/write/interfaces.d.ts.map +1 -1
  17. package/dist/src/client/reactor-client.d.ts +13 -10
  18. package/dist/src/client/reactor-client.d.ts.map +1 -1
  19. package/dist/src/client/types.d.ts +25 -6
  20. package/dist/src/client/types.d.ts.map +1 -1
  21. package/dist/src/core/reactor-builder.d.ts +23 -10
  22. package/dist/src/core/reactor-builder.d.ts.map +1 -1
  23. package/dist/src/core/reactor-client-builder.d.ts +8 -4
  24. package/dist/src/core/reactor-client-builder.d.ts.map +1 -1
  25. package/dist/src/core/reactor.d.ts +20 -80
  26. package/dist/src/core/reactor.d.ts.map +1 -1
  27. package/dist/src/core/types.d.ts +64 -28
  28. package/dist/src/core/types.d.ts.map +1 -1
  29. package/dist/src/core/utils.d.ts +39 -3
  30. package/dist/src/core/utils.d.ts.map +1 -1
  31. package/dist/src/events/types.d.ts +35 -10
  32. package/dist/src/events/types.d.ts.map +1 -1
  33. package/dist/src/executor/document-action-handler.d.ts +30 -0
  34. package/dist/src/executor/document-action-handler.d.ts.map +1 -0
  35. package/dist/src/executor/execution-scope.d.ts +44 -0
  36. package/dist/src/executor/execution-scope.d.ts.map +1 -0
  37. package/dist/src/executor/signature-verifier.d.ts +9 -0
  38. package/dist/src/executor/signature-verifier.d.ts.map +1 -0
  39. package/dist/src/executor/simple-job-executor-manager.d.ts +6 -1
  40. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
  41. package/dist/src/executor/simple-job-executor.d.ts +8 -46
  42. package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
  43. package/dist/src/executor/types.d.ts +1 -3
  44. package/dist/src/executor/types.d.ts.map +1 -1
  45. package/dist/src/executor/util.d.ts +12 -2
  46. package/dist/src/executor/util.d.ts.map +1 -1
  47. package/dist/src/index.d.ts +13 -9
  48. package/dist/src/index.d.ts.map +1 -1
  49. package/dist/src/index.js +20575 -61
  50. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +4 -3
  51. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -1
  52. package/dist/src/job-tracker/interfaces.d.ts +3 -1
  53. package/dist/src/job-tracker/interfaces.d.ts.map +1 -1
  54. package/dist/src/logging/console.d.ts +1 -22
  55. package/dist/src/logging/console.d.ts.map +1 -1
  56. package/dist/src/logging/types.d.ts +1 -11
  57. package/dist/src/logging/types.d.ts.map +1 -1
  58. package/dist/src/processors/index.d.ts +0 -1
  59. package/dist/src/processors/index.d.ts.map +1 -1
  60. package/dist/src/processors/processor-manager.d.ts +19 -6
  61. package/dist/src/processors/processor-manager.d.ts.map +1 -1
  62. package/dist/src/processors/utils.d.ts +3 -2
  63. package/dist/src/processors/utils.d.ts.map +1 -1
  64. package/dist/src/queue/job-execution-handle.d.ts +3 -0
  65. package/dist/src/queue/job-execution-handle.d.ts.map +1 -1
  66. package/dist/src/queue/queue.d.ts +30 -1
  67. package/dist/src/queue/queue.d.ts.map +1 -1
  68. package/dist/src/queue/types.d.ts +4 -3
  69. package/dist/src/queue/types.d.ts.map +1 -1
  70. package/dist/src/read-models/base-read-model.d.ts +11 -9
  71. package/dist/src/read-models/base-read-model.d.ts.map +1 -1
  72. package/dist/src/read-models/coordinator.d.ts +2 -2
  73. package/dist/src/read-models/coordinator.d.ts.map +1 -1
  74. package/dist/src/read-models/document-view.d.ts +7 -4
  75. package/dist/src/read-models/document-view.d.ts.map +1 -1
  76. package/dist/src/read-models/interfaces.d.ts +1 -1
  77. package/dist/src/read-models/interfaces.d.ts.map +1 -1
  78. package/dist/src/read-models/types.d.ts +16 -0
  79. package/dist/src/read-models/types.d.ts.map +1 -1
  80. package/dist/src/registry/document-model-resolver.d.ts +29 -0
  81. package/dist/src/registry/document-model-resolver.d.ts.map +1 -0
  82. package/dist/src/registry/implementation.d.ts +4 -0
  83. package/dist/src/registry/implementation.d.ts.map +1 -1
  84. package/dist/src/registry/index.d.ts +3 -1
  85. package/dist/src/registry/index.d.ts.map +1 -1
  86. package/dist/src/registry/interfaces.d.ts +8 -0
  87. package/dist/src/registry/interfaces.d.ts.map +1 -1
  88. package/dist/src/shared/awaiter.d.ts +2 -2
  89. package/dist/src/shared/awaiter.d.ts.map +1 -1
  90. package/dist/src/shared/collect-all-pages.d.ts +7 -0
  91. package/dist/src/shared/collect-all-pages.d.ts.map +1 -0
  92. package/dist/src/shared/drive-url.d.ts +15 -0
  93. package/dist/src/shared/drive-url.d.ts.map +1 -0
  94. package/dist/src/shared/errors.d.ts +9 -0
  95. package/dist/src/shared/errors.d.ts.map +1 -1
  96. package/dist/src/shared/factories.d.ts +6 -2
  97. package/dist/src/shared/factories.d.ts.map +1 -1
  98. package/dist/src/shared/types.d.ts +32 -6
  99. package/dist/src/shared/types.d.ts.map +1 -1
  100. package/dist/src/signer/passthrough-signer.d.ts +1 -1
  101. package/dist/src/signer/passthrough-signer.d.ts.map +1 -1
  102. package/dist/src/storage/interfaces.d.ts +252 -124
  103. package/dist/src/storage/interfaces.d.ts.map +1 -1
  104. package/dist/src/storage/kysely/document-indexer.d.ts +17 -18
  105. package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -1
  106. package/dist/src/storage/kysely/keyframe-store.d.ts +10 -1
  107. package/dist/src/storage/kysely/keyframe-store.d.ts.map +1 -1
  108. package/dist/src/storage/kysely/store.d.ts +9 -4
  109. package/dist/src/storage/kysely/store.d.ts.map +1 -1
  110. package/dist/src/storage/kysely/sync-cursor-storage.d.ts +1 -1
  111. package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -1
  112. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts +17 -0
  113. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts.map +1 -0
  114. package/dist/src/storage/kysely/types.d.ts +22 -0
  115. package/dist/src/storage/kysely/types.d.ts.map +1 -1
  116. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts +3 -0
  117. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts.map +1 -0
  118. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts +3 -0
  119. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts.map +1 -0
  120. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts +3 -0
  121. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts.map +1 -0
  122. package/dist/src/storage/migrations/014_create_processor_cursor_table.d.ts +3 -0
  123. package/dist/src/storage/migrations/014_create_processor_cursor_table.d.ts.map +1 -0
  124. package/dist/src/storage/migrations/migrator.d.ts.map +1 -1
  125. package/dist/src/subs/default-error-handler.d.ts.map +1 -1
  126. package/dist/src/subs/subscription-notification-read-model.d.ts +3 -2
  127. package/dist/src/subs/subscription-notification-read-model.d.ts.map +1 -1
  128. package/dist/src/sync/batch-aggregator.d.ts +25 -0
  129. package/dist/src/sync/batch-aggregator.d.ts.map +1 -0
  130. package/dist/src/sync/buffered-mailbox.d.ts +36 -0
  131. package/dist/src/sync/buffered-mailbox.d.ts.map +1 -0
  132. package/dist/src/sync/channels/gql-req-channel.d.ts +126 -0
  133. package/dist/src/sync/channels/gql-req-channel.d.ts.map +1 -0
  134. package/dist/src/sync/channels/gql-request-channel-factory.d.ts +32 -0
  135. package/dist/src/sync/channels/gql-request-channel-factory.d.ts.map +1 -0
  136. package/dist/src/sync/channels/gql-res-channel.d.ts +31 -0
  137. package/dist/src/sync/channels/gql-res-channel.d.ts.map +1 -0
  138. package/dist/src/sync/channels/gql-response-channel-factory.d.ts +13 -0
  139. package/dist/src/sync/channels/gql-response-channel-factory.d.ts.map +1 -0
  140. package/dist/src/sync/channels/index.d.ts +6 -4
  141. package/dist/src/sync/channels/index.d.ts.map +1 -1
  142. package/dist/src/sync/channels/interval-poll-timer.d.ts +40 -0
  143. package/dist/src/sync/channels/interval-poll-timer.d.ts.map +1 -0
  144. package/dist/src/sync/channels/poll-timer.d.ts +14 -0
  145. package/dist/src/sync/channels/poll-timer.d.ts.map +1 -0
  146. package/dist/src/sync/channels/utils.d.ts +15 -1
  147. package/dist/src/sync/channels/utils.d.ts.map +1 -1
  148. package/dist/src/sync/errors.d.ts +6 -0
  149. package/dist/src/sync/errors.d.ts.map +1 -1
  150. package/dist/src/sync/index.d.ts +11 -7
  151. package/dist/src/sync/index.d.ts.map +1 -1
  152. package/dist/src/sync/interfaces.d.ts +42 -19
  153. package/dist/src/sync/interfaces.d.ts.map +1 -1
  154. package/dist/src/sync/mailbox.d.ts +51 -12
  155. package/dist/src/sync/mailbox.d.ts.map +1 -1
  156. package/dist/src/sync/sync-awaiter.d.ts +34 -0
  157. package/dist/src/sync/sync-awaiter.d.ts.map +1 -0
  158. package/dist/src/sync/sync-builder.d.ts +5 -1
  159. package/dist/src/sync/sync-builder.d.ts.map +1 -1
  160. package/dist/src/sync/sync-manager.d.ts +23 -8
  161. package/dist/src/sync/sync-manager.d.ts.map +1 -1
  162. package/dist/src/sync/sync-operation.d.ts +4 -2
  163. package/dist/src/sync/sync-operation.d.ts.map +1 -1
  164. package/dist/src/sync/sync-status-tracker.d.ts +31 -0
  165. package/dist/src/sync/sync-status-tracker.d.ts.map +1 -0
  166. package/dist/src/sync/types.d.ts +107 -2
  167. package/dist/src/sync/types.d.ts.map +1 -1
  168. package/dist/src/sync/utils.d.ts +37 -2
  169. package/dist/src/sync/utils.d.ts.map +1 -1
  170. package/dist/src/utils/reshuffle.d.ts +22 -5
  171. package/dist/src/utils/reshuffle.d.ts.map +1 -1
  172. package/package.json +24 -20
  173. package/dist/src/actions/index.js +0 -76
  174. package/dist/src/actions/index.js.map +0 -1
  175. package/dist/src/cache/buffer/ring-buffer.js +0 -69
  176. package/dist/src/cache/buffer/ring-buffer.js.map +0 -1
  177. package/dist/src/cache/document-meta-cache-types.js +0 -2
  178. package/dist/src/cache/document-meta-cache-types.js.map +0 -1
  179. package/dist/src/cache/document-meta-cache.js +0 -128
  180. package/dist/src/cache/document-meta-cache.js.map +0 -1
  181. package/dist/src/cache/index.js +0 -2
  182. package/dist/src/cache/index.js.map +0 -1
  183. package/dist/src/cache/kysely-operation-index.js +0 -250
  184. package/dist/src/cache/kysely-operation-index.js.map +0 -1
  185. package/dist/src/cache/kysely-write-cache.js +0 -388
  186. package/dist/src/cache/kysely-write-cache.js.map +0 -1
  187. package/dist/src/cache/lru/lru-tracker.js +0 -96
  188. package/dist/src/cache/lru/lru-tracker.js.map +0 -1
  189. package/dist/src/cache/operation-index-types.js +0 -4
  190. package/dist/src/cache/operation-index-types.js.map +0 -1
  191. package/dist/src/cache/write/interfaces.js +0 -2
  192. package/dist/src/cache/write/interfaces.js.map +0 -1
  193. package/dist/src/cache/write-cache-types.js +0 -2
  194. package/dist/src/cache/write-cache-types.js.map +0 -1
  195. package/dist/src/client/reactor-client.js +0 -406
  196. package/dist/src/client/reactor-client.js.map +0 -1
  197. package/dist/src/client/types.js +0 -14
  198. package/dist/src/client/types.js.map +0 -1
  199. package/dist/src/core/reactor-builder.js +0 -231
  200. package/dist/src/core/reactor-builder.js.map +0 -1
  201. package/dist/src/core/reactor-client-builder.js +0 -123
  202. package/dist/src/core/reactor-client-builder.js.map +0 -1
  203. package/dist/src/core/reactor.js +0 -981
  204. package/dist/src/core/reactor.js.map +0 -1
  205. package/dist/src/core/types.js +0 -2
  206. package/dist/src/core/types.js.map +0 -1
  207. package/dist/src/core/utils.js +0 -171
  208. package/dist/src/core/utils.js.map +0 -1
  209. package/dist/src/events/event-bus.js +0 -53
  210. package/dist/src/events/event-bus.js.map +0 -1
  211. package/dist/src/events/interfaces.js +0 -2
  212. package/dist/src/events/interfaces.js.map +0 -1
  213. package/dist/src/events/types.js +0 -28
  214. package/dist/src/events/types.js.map +0 -1
  215. package/dist/src/executor/interfaces.js +0 -2
  216. package/dist/src/executor/interfaces.js.map +0 -1
  217. package/dist/src/executor/simple-job-executor-manager.js +0 -233
  218. package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
  219. package/dist/src/executor/simple-job-executor.js +0 -898
  220. package/dist/src/executor/simple-job-executor.js.map +0 -1
  221. package/dist/src/executor/types.js +0 -11
  222. package/dist/src/executor/types.js.map +0 -1
  223. package/dist/src/executor/util.js +0 -184
  224. package/dist/src/executor/util.js.map +0 -1
  225. package/dist/src/index.js.map +0 -1
  226. package/dist/src/job-tracker/in-memory-job-tracker.js +0 -112
  227. package/dist/src/job-tracker/in-memory-job-tracker.js.map +0 -1
  228. package/dist/src/job-tracker/index.js +0 -2
  229. package/dist/src/job-tracker/index.js.map +0 -1
  230. package/dist/src/job-tracker/interfaces.js +0 -2
  231. package/dist/src/job-tracker/interfaces.js.map +0 -1
  232. package/dist/src/logging/console.js +0 -108
  233. package/dist/src/logging/console.js.map +0 -1
  234. package/dist/src/logging/types.js +0 -2
  235. package/dist/src/logging/types.js.map +0 -1
  236. package/dist/src/processors/index.js +0 -2
  237. package/dist/src/processors/index.js.map +0 -1
  238. package/dist/src/processors/processor-manager.js +0 -165
  239. package/dist/src/processors/processor-manager.js.map +0 -1
  240. package/dist/src/processors/types.d.ts +0 -63
  241. package/dist/src/processors/types.d.ts.map +0 -1
  242. package/dist/src/processors/types.js +0 -2
  243. package/dist/src/processors/types.js.map +0 -1
  244. package/dist/src/processors/utils.js +0 -58
  245. package/dist/src/processors/utils.js.map +0 -1
  246. package/dist/src/queue/interfaces.js +0 -2
  247. package/dist/src/queue/interfaces.js.map +0 -1
  248. package/dist/src/queue/job-execution-handle.js +0 -62
  249. package/dist/src/queue/job-execution-handle.js.map +0 -1
  250. package/dist/src/queue/queue.js +0 -384
  251. package/dist/src/queue/queue.js.map +0 -1
  252. package/dist/src/queue/types.js +0 -19
  253. package/dist/src/queue/types.js.map +0 -1
  254. package/dist/src/read-models/base-read-model.js +0 -143
  255. package/dist/src/read-models/base-read-model.js.map +0 -1
  256. package/dist/src/read-models/coordinator.js +0 -72
  257. package/dist/src/read-models/coordinator.js.map +0 -1
  258. package/dist/src/read-models/document-view.js +0 -375
  259. package/dist/src/read-models/document-view.js.map +0 -1
  260. package/dist/src/read-models/interfaces.js +0 -2
  261. package/dist/src/read-models/interfaces.js.map +0 -1
  262. package/dist/src/read-models/types.js +0 -2
  263. package/dist/src/read-models/types.js.map +0 -1
  264. package/dist/src/registry/implementation.js +0 -216
  265. package/dist/src/registry/implementation.js.map +0 -1
  266. package/dist/src/registry/index.js +0 -2
  267. package/dist/src/registry/index.js.map +0 -1
  268. package/dist/src/registry/interfaces.js +0 -2
  269. package/dist/src/registry/interfaces.js.map +0 -1
  270. package/dist/src/shared/awaiter.js +0 -123
  271. package/dist/src/shared/awaiter.js.map +0 -1
  272. package/dist/src/shared/consistency-tracker.js +0 -123
  273. package/dist/src/shared/consistency-tracker.js.map +0 -1
  274. package/dist/src/shared/errors.js +0 -75
  275. package/dist/src/shared/errors.js.map +0 -1
  276. package/dist/src/shared/factories.js +0 -33
  277. package/dist/src/shared/factories.js.map +0 -1
  278. package/dist/src/shared/types.js +0 -38
  279. package/dist/src/shared/types.js.map +0 -1
  280. package/dist/src/shared/utils.js +0 -8
  281. package/dist/src/shared/utils.js.map +0 -1
  282. package/dist/src/signer/passthrough-signer.js +0 -19
  283. package/dist/src/signer/passthrough-signer.js.map +0 -1
  284. package/dist/src/signer/types.js +0 -2
  285. package/dist/src/signer/types.js.map +0 -1
  286. package/dist/src/storage/consistency-aware-legacy-storage.d.ts +0 -33
  287. package/dist/src/storage/consistency-aware-legacy-storage.d.ts.map +0 -1
  288. package/dist/src/storage/consistency-aware-legacy-storage.js +0 -65
  289. package/dist/src/storage/consistency-aware-legacy-storage.js.map +0 -1
  290. package/dist/src/storage/index.js +0 -3
  291. package/dist/src/storage/index.js.map +0 -1
  292. package/dist/src/storage/interfaces.js +0 -19
  293. package/dist/src/storage/interfaces.js.map +0 -1
  294. package/dist/src/storage/kysely/document-indexer.js +0 -350
  295. package/dist/src/storage/kysely/document-indexer.js.map +0 -1
  296. package/dist/src/storage/kysely/keyframe-store.js +0 -64
  297. package/dist/src/storage/kysely/keyframe-store.js.map +0 -1
  298. package/dist/src/storage/kysely/store.js +0 -233
  299. package/dist/src/storage/kysely/store.js.map +0 -1
  300. package/dist/src/storage/kysely/sync-cursor-storage.js +0 -93
  301. package/dist/src/storage/kysely/sync-cursor-storage.js.map +0 -1
  302. package/dist/src/storage/kysely/sync-remote-storage.js +0 -133
  303. package/dist/src/storage/kysely/sync-remote-storage.js.map +0 -1
  304. package/dist/src/storage/kysely/types.js +0 -2
  305. package/dist/src/storage/kysely/types.js.map +0 -1
  306. package/dist/src/storage/migrations/001_create_operation_table.js +0 -41
  307. package/dist/src/storage/migrations/001_create_operation_table.js.map +0 -1
  308. package/dist/src/storage/migrations/002_create_keyframe_table.js +0 -27
  309. package/dist/src/storage/migrations/002_create_keyframe_table.js.map +0 -1
  310. package/dist/src/storage/migrations/003_create_document_table.js +0 -10
  311. package/dist/src/storage/migrations/003_create_document_table.js.map +0 -1
  312. package/dist/src/storage/migrations/004_create_document_relationship_table.js +0 -35
  313. package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +0 -1
  314. package/dist/src/storage/migrations/005_create_indexer_state_table.js +0 -10
  315. package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +0 -1
  316. package/dist/src/storage/migrations/006_create_document_snapshot_table.js +0 -49
  317. package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +0 -1
  318. package/dist/src/storage/migrations/007_create_slug_mapping_table.js +0 -24
  319. package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +0 -1
  320. package/dist/src/storage/migrations/008_create_view_state_table.js +0 -10
  321. package/dist/src/storage/migrations/008_create_view_state_table.js.map +0 -1
  322. package/dist/src/storage/migrations/009_create_operation_index_tables.js +0 -50
  323. package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +0 -1
  324. package/dist/src/storage/migrations/010_create_sync_tables.js +0 -43
  325. package/dist/src/storage/migrations/010_create_sync_tables.js.map +0 -1
  326. package/dist/src/storage/migrations/index.js +0 -3
  327. package/dist/src/storage/migrations/index.js.map +0 -1
  328. package/dist/src/storage/migrations/migrator.js +0 -78
  329. package/dist/src/storage/migrations/migrator.js.map +0 -1
  330. package/dist/src/storage/migrations/run-migrations.js +0 -58
  331. package/dist/src/storage/migrations/run-migrations.js.map +0 -1
  332. package/dist/src/storage/migrations/types.js +0 -2
  333. package/dist/src/storage/migrations/types.js.map +0 -1
  334. package/dist/src/storage/txn.js +0 -42
  335. package/dist/src/storage/txn.js.map +0 -1
  336. package/dist/src/subs/default-error-handler.js +0 -27
  337. package/dist/src/subs/default-error-handler.js.map +0 -1
  338. package/dist/src/subs/react-subscription-manager.js +0 -185
  339. package/dist/src/subs/react-subscription-manager.js.map +0 -1
  340. package/dist/src/subs/subscription-notification-read-model.js +0 -62
  341. package/dist/src/subs/subscription-notification-read-model.js.map +0 -1
  342. package/dist/src/subs/types.js +0 -2
  343. package/dist/src/subs/types.js.map +0 -1
  344. package/dist/src/sync/channels/composite-channel-factory.d.ts +0 -30
  345. package/dist/src/sync/channels/composite-channel-factory.d.ts.map +0 -1
  346. package/dist/src/sync/channels/composite-channel-factory.js +0 -87
  347. package/dist/src/sync/channels/composite-channel-factory.js.map +0 -1
  348. package/dist/src/sync/channels/gql-channel-factory.d.ts +0 -25
  349. package/dist/src/sync/channels/gql-channel-factory.d.ts.map +0 -1
  350. package/dist/src/sync/channels/gql-channel-factory.js +0 -76
  351. package/dist/src/sync/channels/gql-channel-factory.js.map +0 -1
  352. package/dist/src/sync/channels/gql-channel.d.ts +0 -118
  353. package/dist/src/sync/channels/gql-channel.d.ts.map +0 -1
  354. package/dist/src/sync/channels/gql-channel.js +0 -423
  355. package/dist/src/sync/channels/gql-channel.js.map +0 -1
  356. package/dist/src/sync/channels/index.js +0 -6
  357. package/dist/src/sync/channels/index.js.map +0 -1
  358. package/dist/src/sync/channels/polling-channel.d.ts +0 -39
  359. package/dist/src/sync/channels/polling-channel.d.ts.map +0 -1
  360. package/dist/src/sync/channels/polling-channel.js +0 -72
  361. package/dist/src/sync/channels/polling-channel.js.map +0 -1
  362. package/dist/src/sync/channels/utils.js +0 -96
  363. package/dist/src/sync/channels/utils.js.map +0 -1
  364. package/dist/src/sync/errors.js +0 -17
  365. package/dist/src/sync/errors.js.map +0 -1
  366. package/dist/src/sync/index.js +0 -9
  367. package/dist/src/sync/index.js.map +0 -1
  368. package/dist/src/sync/interfaces.js +0 -2
  369. package/dist/src/sync/interfaces.js.map +0 -1
  370. package/dist/src/sync/mailbox.js +0 -59
  371. package/dist/src/sync/mailbox.js.map +0 -1
  372. package/dist/src/sync/sync-builder.js +0 -39
  373. package/dist/src/sync/sync-builder.js.map +0 -1
  374. package/dist/src/sync/sync-manager.js +0 -266
  375. package/dist/src/sync/sync-manager.js.map +0 -1
  376. package/dist/src/sync/sync-operation.js +0 -63
  377. package/dist/src/sync/sync-operation.js.map +0 -1
  378. package/dist/src/sync/types.js +0 -16
  379. package/dist/src/sync/types.js.map +0 -1
  380. package/dist/src/sync/utils.js +0 -78
  381. package/dist/src/sync/utils.js.map +0 -1
  382. package/dist/src/utils/reshuffle.js +0 -47
  383. package/dist/src/utils/reshuffle.js.map +0 -1
@@ -1,350 +0,0 @@
1
- import { v4 as uuidv4 } from "uuid";
2
- export class KyselyDocumentIndexer {
3
- db;
4
- operationStore;
5
- consistencyTracker;
6
- lastOperationId = 0;
7
- constructor(db, operationStore, consistencyTracker) {
8
- this.db = db;
9
- this.operationStore = operationStore;
10
- this.consistencyTracker = consistencyTracker;
11
- }
12
- async init() {
13
- const indexerState = await this.db
14
- .selectFrom("IndexerState")
15
- .selectAll()
16
- .executeTakeFirst();
17
- if (indexerState) {
18
- this.lastOperationId = indexerState.lastOperationId;
19
- const missedOperations = await this.operationStore.getSinceId(this.lastOperationId);
20
- if (missedOperations.items.length > 0) {
21
- await this.indexOperations(missedOperations.items);
22
- }
23
- }
24
- else {
25
- await this.db
26
- .insertInto("IndexerState")
27
- .values({
28
- lastOperationId: 0,
29
- })
30
- .execute();
31
- const allOperations = await this.operationStore.getSinceId(0);
32
- if (allOperations.items.length > 0) {
33
- await this.indexOperations(allOperations.items);
34
- }
35
- }
36
- }
37
- async indexOperations(items) {
38
- if (items.length === 0)
39
- return;
40
- await this.db.transaction().execute(async (trx) => {
41
- for (const item of items) {
42
- const { operation } = item;
43
- const actionType = operation.action.type;
44
- if (actionType === "ADD_RELATIONSHIP") {
45
- await this.handleAddRelationship(trx, operation);
46
- }
47
- else if (actionType === "REMOVE_RELATIONSHIP") {
48
- await this.handleRemoveRelationship(trx, operation);
49
- }
50
- }
51
- const lastOpId = items[items.length - 1].operation.id;
52
- if (lastOpId && typeof lastOpId === "number") {
53
- this.lastOperationId = lastOpId;
54
- await trx
55
- .updateTable("IndexerState")
56
- .set({
57
- lastOperationId: lastOpId,
58
- lastOperationTimestamp: new Date(),
59
- })
60
- .execute();
61
- }
62
- });
63
- const coordinates = [];
64
- for (let i = 0; i < items.length; i++) {
65
- const item = items[i];
66
- coordinates.push({
67
- documentId: item.context.documentId,
68
- scope: item.context.scope,
69
- branch: item.context.branch,
70
- operationIndex: item.operation.index,
71
- });
72
- }
73
- this.consistencyTracker.update(coordinates);
74
- }
75
- async waitForConsistency(token, timeoutMs, signal) {
76
- if (token.coordinates.length === 0) {
77
- return;
78
- }
79
- await this.consistencyTracker.waitFor(token.coordinates, timeoutMs, signal);
80
- }
81
- async getOutgoing(documentId, types, consistencyToken, signal) {
82
- if (consistencyToken) {
83
- await this.waitForConsistency(consistencyToken, undefined, signal);
84
- }
85
- if (signal?.aborted) {
86
- throw new Error("Operation aborted");
87
- }
88
- let query = this.db
89
- .selectFrom("DocumentRelationship")
90
- .selectAll()
91
- .where("sourceId", "=", documentId);
92
- if (types && types.length > 0) {
93
- query = query.where("relationshipType", "in", types);
94
- }
95
- const rows = await query.execute();
96
- return rows.map((row) => ({
97
- sourceId: row.sourceId,
98
- targetId: row.targetId,
99
- relationshipType: row.relationshipType,
100
- metadata: row.metadata
101
- ? row.metadata
102
- : undefined,
103
- createdAt: row.createdAt,
104
- updatedAt: row.updatedAt,
105
- }));
106
- }
107
- async getIncoming(documentId, types, consistencyToken, signal) {
108
- if (consistencyToken) {
109
- await this.waitForConsistency(consistencyToken, undefined, signal);
110
- }
111
- if (signal?.aborted) {
112
- throw new Error("Operation aborted");
113
- }
114
- let query = this.db
115
- .selectFrom("DocumentRelationship")
116
- .selectAll()
117
- .where("targetId", "=", documentId);
118
- if (types && types.length > 0) {
119
- query = query.where("relationshipType", "in", types);
120
- }
121
- const rows = await query.execute();
122
- return rows.map((row) => ({
123
- sourceId: row.sourceId,
124
- targetId: row.targetId,
125
- relationshipType: row.relationshipType,
126
- metadata: row.metadata
127
- ? row.metadata
128
- : undefined,
129
- createdAt: row.createdAt,
130
- updatedAt: row.updatedAt,
131
- }));
132
- }
133
- async hasRelationship(sourceId, targetId, types, consistencyToken, signal) {
134
- if (consistencyToken) {
135
- await this.waitForConsistency(consistencyToken, undefined, signal);
136
- }
137
- if (signal?.aborted) {
138
- throw new Error("Operation aborted");
139
- }
140
- let query = this.db
141
- .selectFrom("DocumentRelationship")
142
- .select("id")
143
- .where("sourceId", "=", sourceId)
144
- .where("targetId", "=", targetId);
145
- if (types && types.length > 0) {
146
- query = query.where("relationshipType", "in", types);
147
- }
148
- const result = await query.executeTakeFirst();
149
- return result !== undefined;
150
- }
151
- async getUndirectedRelationships(a, b, types, consistencyToken, signal) {
152
- if (consistencyToken) {
153
- await this.waitForConsistency(consistencyToken, undefined, signal);
154
- }
155
- if (signal?.aborted) {
156
- throw new Error("Operation aborted");
157
- }
158
- let query = this.db
159
- .selectFrom("DocumentRelationship")
160
- .selectAll()
161
- .where((eb) => eb.or([
162
- eb.and([eb("sourceId", "=", a), eb("targetId", "=", b)]),
163
- eb.and([eb("sourceId", "=", b), eb("targetId", "=", a)]),
164
- ]));
165
- if (types && types.length > 0) {
166
- query = query.where("relationshipType", "in", types);
167
- }
168
- const rows = await query.execute();
169
- return rows.map((row) => ({
170
- sourceId: row.sourceId,
171
- targetId: row.targetId,
172
- relationshipType: row.relationshipType,
173
- metadata: row.metadata
174
- ? row.metadata
175
- : undefined,
176
- createdAt: row.createdAt,
177
- updatedAt: row.updatedAt,
178
- }));
179
- }
180
- async getDirectedRelationships(sourceId, targetId, types, consistencyToken, signal) {
181
- if (consistencyToken) {
182
- await this.waitForConsistency(consistencyToken, undefined, signal);
183
- }
184
- if (signal?.aborted) {
185
- throw new Error("Operation aborted");
186
- }
187
- let query = this.db
188
- .selectFrom("DocumentRelationship")
189
- .selectAll()
190
- .where("sourceId", "=", sourceId)
191
- .where("targetId", "=", targetId);
192
- if (types && types.length > 0) {
193
- query = query.where("relationshipType", "in", types);
194
- }
195
- const rows = await query.execute();
196
- return rows.map((row) => ({
197
- sourceId: row.sourceId,
198
- targetId: row.targetId,
199
- relationshipType: row.relationshipType,
200
- metadata: row.metadata
201
- ? row.metadata
202
- : undefined,
203
- createdAt: row.createdAt,
204
- updatedAt: row.updatedAt,
205
- }));
206
- }
207
- async findPath(sourceId, targetId, types, consistencyToken, signal) {
208
- if (consistencyToken) {
209
- await this.waitForConsistency(consistencyToken, undefined, signal);
210
- }
211
- if (signal?.aborted) {
212
- throw new Error("Operation aborted");
213
- }
214
- if (sourceId === targetId) {
215
- return [sourceId];
216
- }
217
- const visited = new Set();
218
- const queue = [
219
- { id: sourceId, path: [sourceId] },
220
- ];
221
- while (queue.length > 0) {
222
- const current = queue.shift();
223
- if (current.id === targetId) {
224
- return current.path;
225
- }
226
- if (visited.has(current.id)) {
227
- continue;
228
- }
229
- visited.add(current.id);
230
- const outgoing = await this.getOutgoing(current.id, types, undefined, signal);
231
- for (const rel of outgoing) {
232
- if (!visited.has(rel.targetId)) {
233
- queue.push({
234
- id: rel.targetId,
235
- path: [...current.path, rel.targetId],
236
- });
237
- }
238
- }
239
- }
240
- return null;
241
- }
242
- async findAncestors(documentId, types, consistencyToken, signal) {
243
- if (consistencyToken) {
244
- await this.waitForConsistency(consistencyToken, undefined, signal);
245
- }
246
- if (signal?.aborted) {
247
- throw new Error("Operation aborted");
248
- }
249
- const nodes = new Set([documentId]);
250
- const edges = [];
251
- const queue = [documentId];
252
- const visited = new Set();
253
- while (queue.length > 0) {
254
- const currentId = queue.shift();
255
- if (visited.has(currentId)) {
256
- continue;
257
- }
258
- visited.add(currentId);
259
- const incoming = await this.getIncoming(currentId, types, undefined, signal);
260
- for (const rel of incoming) {
261
- nodes.add(rel.sourceId);
262
- edges.push({
263
- from: rel.sourceId,
264
- to: rel.targetId,
265
- type: rel.relationshipType,
266
- });
267
- if (!visited.has(rel.sourceId)) {
268
- queue.push(rel.sourceId);
269
- }
270
- }
271
- }
272
- return {
273
- nodes: Array.from(nodes),
274
- edges,
275
- };
276
- }
277
- async getRelationshipTypes(consistencyToken, signal) {
278
- if (consistencyToken) {
279
- await this.waitForConsistency(consistencyToken, undefined, signal);
280
- }
281
- if (signal?.aborted) {
282
- throw new Error("Operation aborted");
283
- }
284
- const rows = await this.db
285
- .selectFrom("DocumentRelationship")
286
- .select("relationshipType")
287
- .distinct()
288
- .execute();
289
- return rows.map((row) => row.relationshipType);
290
- }
291
- async handleAddRelationship(trx, operation) {
292
- const input = operation.action.input;
293
- const existingDoc = await trx
294
- .selectFrom("Document")
295
- .select("id")
296
- .where("id", "=", input.sourceId)
297
- .executeTakeFirst();
298
- if (!existingDoc) {
299
- await trx
300
- .insertInto("Document")
301
- .values({
302
- id: input.sourceId,
303
- })
304
- .execute();
305
- }
306
- const existingTargetDoc = await trx
307
- .selectFrom("Document")
308
- .select("id")
309
- .where("id", "=", input.targetId)
310
- .executeTakeFirst();
311
- if (!existingTargetDoc) {
312
- await trx
313
- .insertInto("Document")
314
- .values({
315
- id: input.targetId,
316
- })
317
- .execute();
318
- }
319
- const existingRel = await trx
320
- .selectFrom("DocumentRelationship")
321
- .select("id")
322
- .where("sourceId", "=", input.sourceId)
323
- .where("targetId", "=", input.targetId)
324
- .where("relationshipType", "=", input.relationshipType)
325
- .executeTakeFirst();
326
- if (!existingRel) {
327
- const relationship = {
328
- id: uuidv4(),
329
- sourceId: input.sourceId,
330
- targetId: input.targetId,
331
- relationshipType: input.relationshipType,
332
- metadata: input.metadata || null,
333
- };
334
- await trx
335
- .insertInto("DocumentRelationship")
336
- .values(relationship)
337
- .execute();
338
- }
339
- }
340
- async handleRemoveRelationship(trx, operation) {
341
- const input = operation.action.input;
342
- await trx
343
- .deleteFrom("DocumentRelationship")
344
- .where("sourceId", "=", input.sourceId)
345
- .where("targetId", "=", input.targetId)
346
- .where("relationshipType", "=", input.relationshipType)
347
- .execute();
348
- }
349
- }
350
- //# sourceMappingURL=document-indexer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"document-indexer.js","sourceRoot":"","sources":["../../../../src/storage/kysely/document-indexer.ts"],"names":[],"mappings":"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"}
@@ -1,64 +0,0 @@
1
- export class KyselyKeyframeStore {
2
- db;
3
- constructor(db) {
4
- this.db = db;
5
- }
6
- async putKeyframe(documentId, scope, branch, revision, document, signal) {
7
- if (signal?.aborted) {
8
- throw new Error("Operation aborted");
9
- }
10
- await this.db
11
- .insertInto("Keyframe")
12
- .values({
13
- documentId,
14
- documentType: document.header.documentType,
15
- scope,
16
- branch,
17
- revision,
18
- document,
19
- })
20
- .onConflict((oc) => oc
21
- .columns(["documentId", "scope", "branch", "revision"])
22
- .doUpdateSet({ document }))
23
- .execute();
24
- }
25
- async findNearestKeyframe(documentId, scope, branch, targetRevision, signal) {
26
- if (signal?.aborted) {
27
- throw new Error("Operation aborted");
28
- }
29
- const row = await this.db
30
- .selectFrom("Keyframe")
31
- .selectAll()
32
- .where("documentId", "=", documentId)
33
- .where("scope", "=", scope)
34
- .where("branch", "=", branch)
35
- .where("revision", "<=", targetRevision)
36
- .orderBy("revision", "desc")
37
- .limit(1)
38
- .executeTakeFirst();
39
- if (!row) {
40
- return undefined;
41
- }
42
- return {
43
- revision: row.revision,
44
- document: row.document,
45
- };
46
- }
47
- async deleteKeyframes(documentId, scope, branch, signal) {
48
- if (signal?.aborted) {
49
- throw new Error("Operation aborted");
50
- }
51
- let query = this.db
52
- .deleteFrom("Keyframe")
53
- .where("documentId", "=", documentId);
54
- if (scope !== undefined && branch !== undefined) {
55
- query = query.where("scope", "=", scope).where("branch", "=", branch);
56
- }
57
- else if (scope !== undefined) {
58
- query = query.where("scope", "=", scope);
59
- }
60
- const result = await query.executeTakeFirst();
61
- return Number(result.numDeletedRows || 0n);
62
- }
63
- }
64
- //# sourceMappingURL=keyframe-store.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"keyframe-store.js","sourceRoot":"","sources":["../../../../src/storage/kysely/keyframe-store.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,mBAAmB;IACV;IAApB,YAAoB,EAAoB;QAApB,OAAE,GAAF,EAAE,CAAkB;IAAG,CAAC;IAE5C,KAAK,CAAC,WAAW,CACf,UAAkB,EAClB,KAAa,EACb,MAAc,EACd,QAAgB,EAChB,QAAoB,EACpB,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,IAAI,CAAC,EAAE;aACV,UAAU,CAAC,UAAU,CAAC;aACtB,MAAM,CAAC;YACN,UAAU;YACV,YAAY,EAAE,QAAQ,CAAC,MAAM,CAAC,YAAY;YAC1C,KAAK;YACL,MAAM;YACN,QAAQ;YACR,QAAQ;SACT,CAAC;aACD,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,CACjB,EAAE;aACC,OAAO,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;aACtD,WAAW,CAAC,EAAE,QAAQ,EAAE,CAAC,CAC7B;aACA,OAAO,EAAE,CAAC;IACf,CAAC;IAED,KAAK,CAAC,mBAAmB,CACvB,UAAkB,EAClB,KAAa,EACb,MAAc,EACd,cAAsB,EACtB,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,EAAE;aACtB,UAAU,CAAC,UAAU,CAAC;aACtB,SAAS,EAAE;aACX,KAAK,CAAC,YAAY,EAAE,GAAG,EAAE,UAAU,CAAC;aACpC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC;aAC1B,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC;aAC5B,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,CAAC;aACvC,OAAO,CAAC,UAAU,EAAE,MAAM,CAAC;aAC3B,KAAK,CAAC,CAAC,CAAC;aACR,gBAAgB,EAAE,CAAC;QAEtB,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,OAAO;YACL,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAsB;SACrC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,KAAc,EACd,MAAe,EACf,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,UAAU,CAAC;aACtB,KAAK,CAAC,YAAY,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;QAExC,IAAI,KAAK,KAAK,SAAS,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;YAChD,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;QACxE,CAAC;aAAM,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAE9C,OAAO,MAAM,CAAC,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF"}
@@ -1,233 +0,0 @@
1
- import {} from "document-model";
2
- import { DuplicateOperationError, RevisionMismatchError, } from "../interfaces.js";
3
- import { AtomicTransaction } from "../txn.js";
4
- export class KyselyOperationStore {
5
- db;
6
- constructor(db) {
7
- this.db = db;
8
- }
9
- async apply(documentId, documentType, scope, branch, revision, fn, signal) {
10
- await this.db.transaction().execute(async (trx) => {
11
- // Check for abort signal
12
- if (signal?.aborted) {
13
- throw new Error("Operation aborted");
14
- }
15
- // Get the latest operation for this stream to verify revision
16
- const latestOp = await trx
17
- .selectFrom("Operation")
18
- .selectAll()
19
- .where("documentId", "=", documentId)
20
- .where("scope", "=", scope)
21
- .where("branch", "=", branch)
22
- .orderBy("index", "desc")
23
- .limit(1)
24
- .executeTakeFirst();
25
- // Check revision matches
26
- const currentRevision = latestOp ? latestOp.index : -1;
27
- if (currentRevision !== revision - 1) {
28
- throw new RevisionMismatchError(currentRevision + 1, revision);
29
- }
30
- // Create atomic transaction
31
- const atomicTxn = new AtomicTransaction(documentId, documentType, scope, branch, revision);
32
- await fn(atomicTxn);
33
- // Get operations and header updates
34
- const operations = atomicTxn.getOperations();
35
- // Insert operations
36
- if (operations.length > 0) {
37
- // Set prevOpId for each operation
38
- let prevOpId = latestOp?.opId || "";
39
- for (const op of operations) {
40
- op.prevOpId = prevOpId;
41
- prevOpId = op.opId;
42
- }
43
- try {
44
- await trx.insertInto("Operation").values(operations).execute();
45
- }
46
- catch (error) {
47
- if (error instanceof Error) {
48
- if (error.message.includes("unique constraint")) {
49
- const op = operations[0];
50
- throw new DuplicateOperationError(`${op.opId} at index ${op.index} with skip ${op.skip}`);
51
- }
52
- throw error;
53
- }
54
- throw error;
55
- }
56
- }
57
- });
58
- }
59
- async getSince(documentId, scope, branch, revision, paging, signal) {
60
- if (signal?.aborted) {
61
- throw new Error("Operation aborted");
62
- }
63
- let query = this.db
64
- .selectFrom("Operation")
65
- .selectAll()
66
- .where("documentId", "=", documentId)
67
- .where("scope", "=", scope)
68
- .where("branch", "=", branch)
69
- .where("index", ">", revision)
70
- .orderBy("index", "asc");
71
- // Handle cursor-based pagination
72
- if (paging) {
73
- // Cursor encodes the last seen index
74
- if (paging.cursor) {
75
- const lastIndex = Number.parseInt(paging.cursor, 10);
76
- query = query.where("index", ">", lastIndex);
77
- }
78
- // Apply limit if specified (fetch one extra to determine hasMore)
79
- if (paging.limit) {
80
- query = query.limit(paging.limit + 1);
81
- }
82
- }
83
- const rows = await query.execute();
84
- // Determine if there are more results
85
- let hasMore = false;
86
- let items = rows;
87
- if (paging?.limit && rows.length > paging.limit) {
88
- hasMore = true;
89
- items = rows.slice(0, paging.limit);
90
- }
91
- // Generate next cursor from last item's index
92
- const nextCursor = hasMore && items.length > 0
93
- ? items[items.length - 1].index.toString()
94
- : undefined;
95
- return {
96
- items: items.map((row) => this.rowToOperation(row)),
97
- nextCursor,
98
- hasMore,
99
- };
100
- }
101
- async getSinceId(id, paging, signal) {
102
- if (signal?.aborted) {
103
- throw new Error("Operation aborted");
104
- }
105
- let query = this.db
106
- .selectFrom("Operation")
107
- .selectAll()
108
- .where("id", ">", id)
109
- .orderBy("id", "asc");
110
- // Handle cursor-based pagination
111
- if (paging) {
112
- // Cursor encodes the last seen id
113
- if (paging.cursor) {
114
- const lastId = Number.parseInt(paging.cursor, 10);
115
- query = query.where("id", ">", lastId);
116
- }
117
- // Apply limit if specified (fetch one extra to determine hasMore)
118
- if (paging.limit) {
119
- query = query.limit(paging.limit + 1);
120
- }
121
- }
122
- const rows = await query.execute();
123
- // Determine if there are more results
124
- let hasMore = false;
125
- let items = rows;
126
- if (paging?.limit && rows.length > paging.limit) {
127
- hasMore = true;
128
- items = rows.slice(0, paging.limit);
129
- }
130
- // Generate next cursor from last item's id
131
- const nextCursor = hasMore && items.length > 0
132
- ? items[items.length - 1].id.toString()
133
- : undefined;
134
- return {
135
- items: items.map((row) => this.rowToOperationWithContext(row)),
136
- nextCursor,
137
- hasMore,
138
- };
139
- }
140
- async getConflicting(documentId, scope, branch, minTimestamp, paging, signal) {
141
- if (signal?.aborted) {
142
- throw new Error("Operation aborted");
143
- }
144
- let query = this.db
145
- .selectFrom("Operation")
146
- .selectAll()
147
- .where("documentId", "=", documentId)
148
- .where("scope", "=", scope)
149
- .where("branch", "=", branch)
150
- .where("timestampUtcMs", ">=", new Date(minTimestamp))
151
- .orderBy("index", "asc");
152
- if (paging) {
153
- if (paging.cursor) {
154
- const lastIndex = Number.parseInt(paging.cursor, 10);
155
- query = query.where("index", ">", lastIndex);
156
- }
157
- if (paging.limit) {
158
- query = query.limit(paging.limit + 1);
159
- }
160
- }
161
- const rows = await query.execute();
162
- let hasMore = false;
163
- let items = rows;
164
- if (paging?.limit && rows.length > paging.limit) {
165
- hasMore = true;
166
- items = rows.slice(0, paging.limit);
167
- }
168
- const nextCursor = hasMore && items.length > 0
169
- ? items[items.length - 1].index.toString()
170
- : undefined;
171
- return {
172
- items: items.map((row) => this.rowToOperation(row)),
173
- nextCursor,
174
- hasMore,
175
- };
176
- }
177
- async getRevisions(documentId, branch, signal) {
178
- if (signal?.aborted) {
179
- throw new Error("Operation aborted");
180
- }
181
- // Get the latest operation for each scope in a single query
182
- // Uses a subquery to find operations where the index equals the max index for that scope
183
- const scopeRevisions = await this.db
184
- .selectFrom("Operation as o1")
185
- .select(["o1.scope", "o1.index", "o1.timestampUtcMs"])
186
- .where("o1.documentId", "=", documentId)
187
- .where("o1.branch", "=", branch)
188
- .where((eb) => eb("o1.index", "=", eb
189
- .selectFrom("Operation as o2")
190
- .select((eb2) => eb2.fn.max("o2.index").as("maxIndex"))
191
- .where("o2.documentId", "=", eb.ref("o1.documentId"))
192
- .where("o2.branch", "=", eb.ref("o1.branch"))
193
- .where("o2.scope", "=", eb.ref("o1.scope"))))
194
- .execute();
195
- const revision = {};
196
- let latestTimestamp = new Date(0).toISOString();
197
- for (const row of scopeRevisions) {
198
- revision[row.scope] = row.index + 1;
199
- const timestamp = row.timestampUtcMs.toISOString();
200
- if (timestamp > latestTimestamp) {
201
- latestTimestamp = timestamp;
202
- }
203
- }
204
- return {
205
- revision,
206
- latestTimestamp,
207
- };
208
- }
209
- rowToOperation(row) {
210
- return {
211
- index: row.index,
212
- timestampUtcMs: row.timestampUtcMs.toISOString(),
213
- hash: row.hash,
214
- skip: row.skip,
215
- error: row.error || undefined,
216
- id: row.opId,
217
- action: row.action,
218
- };
219
- }
220
- rowToOperationWithContext(row) {
221
- return {
222
- operation: this.rowToOperation(row),
223
- context: {
224
- documentId: row.documentId,
225
- documentType: row.documentType,
226
- scope: row.scope,
227
- branch: row.branch,
228
- ordinal: row.id,
229
- },
230
- };
231
- }
232
- }
233
- //# sourceMappingURL=store.js.map