@powerhousedao/reactor 6.0.0-dev.6 → 6.0.0-dev.60

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 (324) hide show
  1. package/dist/src/cache/collection-membership-cache.d.ts +13 -0
  2. package/dist/src/cache/collection-membership-cache.d.ts.map +1 -0
  3. package/dist/src/cache/collection-membership-cache.js +33 -0
  4. package/dist/src/cache/collection-membership-cache.js.map +1 -0
  5. package/dist/src/cache/document-meta-cache.d.ts.map +1 -1
  6. package/dist/src/cache/document-meta-cache.js +6 -5
  7. package/dist/src/cache/document-meta-cache.js.map +1 -1
  8. package/dist/src/cache/kysely-operation-index.d.ts +6 -1
  9. package/dist/src/cache/kysely-operation-index.d.ts.map +1 -1
  10. package/dist/src/cache/kysely-operation-index.js +102 -7
  11. package/dist/src/cache/kysely-operation-index.js.map +1 -1
  12. package/dist/src/cache/kysely-write-cache.d.ts +9 -2
  13. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
  14. package/dist/src/cache/kysely-write-cache.js +38 -15
  15. package/dist/src/cache/kysely-write-cache.js.map +1 -1
  16. package/dist/src/cache/operation-index-types.d.ts +16 -2
  17. package/dist/src/cache/operation-index-types.d.ts.map +1 -1
  18. package/dist/src/cache/operation-index-types.js.map +1 -1
  19. package/dist/src/cache/write/interfaces.d.ts +7 -2
  20. package/dist/src/cache/write/interfaces.d.ts.map +1 -1
  21. package/dist/src/client/reactor-client.d.ts +13 -10
  22. package/dist/src/client/reactor-client.d.ts.map +1 -1
  23. package/dist/src/client/reactor-client.js +134 -43
  24. package/dist/src/client/reactor-client.js.map +1 -1
  25. package/dist/src/client/types.d.ts +25 -6
  26. package/dist/src/client/types.d.ts.map +1 -1
  27. package/dist/src/client/types.js.map +1 -1
  28. package/dist/src/core/reactor-builder.d.ts +23 -7
  29. package/dist/src/core/reactor-builder.d.ts.map +1 -1
  30. package/dist/src/core/reactor-builder.js +99 -24
  31. package/dist/src/core/reactor-builder.js.map +1 -1
  32. package/dist/src/core/reactor-client-builder.d.ts +5 -4
  33. package/dist/src/core/reactor-client-builder.d.ts.map +1 -1
  34. package/dist/src/core/reactor-client-builder.js +14 -5
  35. package/dist/src/core/reactor-client-builder.js.map +1 -1
  36. package/dist/src/core/reactor.d.ts +20 -80
  37. package/dist/src/core/reactor.d.ts.map +1 -1
  38. package/dist/src/core/reactor.js +235 -576
  39. package/dist/src/core/reactor.js.map +1 -1
  40. package/dist/src/core/types.d.ts +64 -28
  41. package/dist/src/core/types.d.ts.map +1 -1
  42. package/dist/src/core/utils.d.ts +39 -3
  43. package/dist/src/core/utils.d.ts.map +1 -1
  44. package/dist/src/core/utils.js +63 -9
  45. package/dist/src/core/utils.js.map +1 -1
  46. package/dist/src/events/types.d.ts +35 -10
  47. package/dist/src/events/types.d.ts.map +1 -1
  48. package/dist/src/events/types.js +7 -5
  49. package/dist/src/events/types.js.map +1 -1
  50. package/dist/src/executor/document-action-handler.d.ts +37 -0
  51. package/dist/src/executor/document-action-handler.d.ts.map +1 -0
  52. package/dist/src/executor/document-action-handler.js +356 -0
  53. package/dist/src/executor/document-action-handler.js.map +1 -0
  54. package/dist/src/executor/signature-verifier.d.ts +9 -0
  55. package/dist/src/executor/signature-verifier.d.ts.map +1 -0
  56. package/dist/src/executor/signature-verifier.js +70 -0
  57. package/dist/src/executor/signature-verifier.js.map +1 -0
  58. package/dist/src/executor/simple-job-executor-manager.d.ts +6 -1
  59. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
  60. package/dist/src/executor/simple-job-executor-manager.js +125 -13
  61. package/dist/src/executor/simple-job-executor-manager.js.map +1 -1
  62. package/dist/src/executor/simple-job-executor.d.ts +6 -46
  63. package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
  64. package/dist/src/executor/simple-job-executor.js +113 -588
  65. package/dist/src/executor/simple-job-executor.js.map +1 -1
  66. package/dist/src/executor/types.d.ts +1 -3
  67. package/dist/src/executor/types.d.ts.map +1 -1
  68. package/dist/src/executor/types.js.map +1 -1
  69. package/dist/src/executor/util.d.ts +12 -2
  70. package/dist/src/executor/util.d.ts.map +1 -1
  71. package/dist/src/executor/util.js +47 -1
  72. package/dist/src/executor/util.js.map +1 -1
  73. package/dist/src/index.d.ts +11 -9
  74. package/dist/src/index.d.ts.map +1 -1
  75. package/dist/src/index.js +7 -6
  76. package/dist/src/index.js.map +1 -1
  77. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +4 -3
  78. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -1
  79. package/dist/src/job-tracker/in-memory-job-tracker.js +20 -18
  80. package/dist/src/job-tracker/in-memory-job-tracker.js.map +1 -1
  81. package/dist/src/job-tracker/interfaces.d.ts +3 -1
  82. package/dist/src/job-tracker/interfaces.d.ts.map +1 -1
  83. package/dist/src/logging/console.d.ts +1 -22
  84. package/dist/src/logging/console.d.ts.map +1 -1
  85. package/dist/src/logging/console.js +1 -107
  86. package/dist/src/logging/console.js.map +1 -1
  87. package/dist/src/logging/types.d.ts +1 -11
  88. package/dist/src/logging/types.d.ts.map +1 -1
  89. package/dist/src/processors/index.d.ts +1 -1
  90. package/dist/src/processors/index.d.ts.map +1 -1
  91. package/dist/src/processors/index.js.map +1 -1
  92. package/dist/src/processors/processor-manager.d.ts +2 -2
  93. package/dist/src/processors/processor-manager.d.ts.map +1 -1
  94. package/dist/src/processors/processor-manager.js.map +1 -1
  95. package/dist/src/processors/relational/types.d.ts +2 -0
  96. package/dist/src/processors/relational/types.d.ts.map +1 -0
  97. package/dist/src/processors/relational/types.js +2 -0
  98. package/dist/src/processors/relational/types.js.map +1 -0
  99. package/dist/src/processors/relational/utils.d.ts +2 -0
  100. package/dist/src/processors/relational/utils.d.ts.map +1 -0
  101. package/dist/src/processors/relational/utils.js +2 -0
  102. package/dist/src/processors/relational/utils.js.map +1 -0
  103. package/dist/src/processors/utils.d.ts +2 -2
  104. package/dist/src/processors/utils.d.ts.map +1 -1
  105. package/dist/src/processors/utils.js +2 -1
  106. package/dist/src/processors/utils.js.map +1 -1
  107. package/dist/src/queue/job-execution-handle.d.ts +3 -0
  108. package/dist/src/queue/job-execution-handle.d.ts.map +1 -1
  109. package/dist/src/queue/job-execution-handle.js +9 -0
  110. package/dist/src/queue/job-execution-handle.js.map +1 -1
  111. package/dist/src/queue/queue.d.ts +30 -1
  112. package/dist/src/queue/queue.d.ts.map +1 -1
  113. package/dist/src/queue/queue.js +110 -1
  114. package/dist/src/queue/queue.js.map +1 -1
  115. package/dist/src/queue/types.d.ts +4 -3
  116. package/dist/src/queue/types.d.ts.map +1 -1
  117. package/dist/src/queue/types.js.map +1 -1
  118. package/dist/src/read-models/base-read-model.d.ts +1 -1
  119. package/dist/src/read-models/base-read-model.d.ts.map +1 -1
  120. package/dist/src/read-models/base-read-model.js +4 -4
  121. package/dist/src/read-models/base-read-model.js.map +1 -1
  122. package/dist/src/read-models/coordinator.d.ts +2 -2
  123. package/dist/src/read-models/coordinator.d.ts.map +1 -1
  124. package/dist/src/read-models/coordinator.js +8 -8
  125. package/dist/src/read-models/coordinator.js.map +1 -1
  126. package/dist/src/read-models/document-view.d.ts +6 -3
  127. package/dist/src/read-models/document-view.d.ts.map +1 -1
  128. package/dist/src/read-models/document-view.js +130 -48
  129. package/dist/src/read-models/document-view.js.map +1 -1
  130. package/dist/src/read-models/interfaces.d.ts +1 -1
  131. package/dist/src/read-models/interfaces.d.ts.map +1 -1
  132. package/dist/src/registry/document-model-resolver.d.ts +29 -0
  133. package/dist/src/registry/document-model-resolver.d.ts.map +1 -0
  134. package/dist/src/registry/document-model-resolver.js +81 -0
  135. package/dist/src/registry/document-model-resolver.js.map +1 -0
  136. package/dist/src/registry/implementation.d.ts +4 -0
  137. package/dist/src/registry/implementation.d.ts.map +1 -1
  138. package/dist/src/registry/implementation.js +10 -0
  139. package/dist/src/registry/implementation.js.map +1 -1
  140. package/dist/src/registry/index.d.ts +3 -1
  141. package/dist/src/registry/index.d.ts.map +1 -1
  142. package/dist/src/registry/index.js +1 -0
  143. package/dist/src/registry/index.js.map +1 -1
  144. package/dist/src/registry/interfaces.d.ts +8 -0
  145. package/dist/src/registry/interfaces.d.ts.map +1 -1
  146. package/dist/src/shared/awaiter.d.ts +2 -2
  147. package/dist/src/shared/awaiter.d.ts.map +1 -1
  148. package/dist/src/shared/awaiter.js +11 -11
  149. package/dist/src/shared/awaiter.js.map +1 -1
  150. package/dist/src/shared/collect-all-pages.d.ts +7 -0
  151. package/dist/src/shared/collect-all-pages.d.ts.map +1 -0
  152. package/dist/src/shared/collect-all-pages.js +17 -0
  153. package/dist/src/shared/collect-all-pages.js.map +1 -0
  154. package/dist/src/shared/drive-url.d.ts +15 -0
  155. package/dist/src/shared/drive-url.d.ts.map +1 -0
  156. package/dist/src/shared/drive-url.js +17 -0
  157. package/dist/src/shared/drive-url.js.map +1 -0
  158. package/dist/src/shared/errors.d.ts +9 -0
  159. package/dist/src/shared/errors.d.ts.map +1 -1
  160. package/dist/src/shared/errors.js +18 -0
  161. package/dist/src/shared/errors.js.map +1 -1
  162. package/dist/src/shared/factories.d.ts +6 -2
  163. package/dist/src/shared/factories.d.ts.map +1 -1
  164. package/dist/src/shared/factories.js +10 -2
  165. package/dist/src/shared/factories.js.map +1 -1
  166. package/dist/src/shared/types.d.ts +32 -6
  167. package/dist/src/shared/types.d.ts.map +1 -1
  168. package/dist/src/shared/types.js +4 -4
  169. package/dist/src/shared/types.js.map +1 -1
  170. package/dist/src/signer/passthrough-signer.d.ts +1 -1
  171. package/dist/src/signer/passthrough-signer.d.ts.map +1 -1
  172. package/dist/src/signer/passthrough-signer.js +1 -3
  173. package/dist/src/signer/passthrough-signer.js.map +1 -1
  174. package/dist/src/storage/interfaces.d.ts +238 -124
  175. package/dist/src/storage/interfaces.d.ts.map +1 -1
  176. package/dist/src/storage/interfaces.js +10 -0
  177. package/dist/src/storage/interfaces.js.map +1 -1
  178. package/dist/src/storage/kysely/document-indexer.d.ts +8 -7
  179. package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -1
  180. package/dist/src/storage/kysely/document-indexer.js +123 -52
  181. package/dist/src/storage/kysely/document-indexer.js.map +1 -1
  182. package/dist/src/storage/kysely/store.d.ts +5 -4
  183. package/dist/src/storage/kysely/store.d.ts.map +1 -1
  184. package/dist/src/storage/kysely/store.js +52 -21
  185. package/dist/src/storage/kysely/store.js.map +1 -1
  186. package/dist/src/storage/kysely/sync-cursor-storage.d.ts +1 -1
  187. package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -1
  188. package/dist/src/storage/kysely/sync-cursor-storage.js +6 -2
  189. package/dist/src/storage/kysely/sync-cursor-storage.js.map +1 -1
  190. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts +17 -0
  191. package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts.map +1 -0
  192. package/dist/src/storage/kysely/sync-dead-letter-storage.js +110 -0
  193. package/dist/src/storage/kysely/sync-dead-letter-storage.js.map +1 -0
  194. package/dist/src/storage/kysely/sync-remote-storage.js +1 -1
  195. package/dist/src/storage/kysely/sync-remote-storage.js.map +1 -1
  196. package/dist/src/storage/kysely/types.d.ts +22 -0
  197. package/dist/src/storage/kysely/types.d.ts.map +1 -1
  198. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts +3 -0
  199. package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts.map +1 -0
  200. package/dist/src/storage/migrations/011_add_cursor_type_column.js +29 -0
  201. package/dist/src/storage/migrations/011_add_cursor_type_column.js.map +1 -0
  202. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts +3 -0
  203. package/dist/src/storage/migrations/012_add_source_remote_column.d.ts.map +1 -0
  204. package/dist/src/storage/migrations/012_add_source_remote_column.js +7 -0
  205. package/dist/src/storage/migrations/012_add_source_remote_column.js.map +1 -0
  206. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts +3 -0
  207. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts.map +1 -0
  208. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js +24 -0
  209. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js.map +1 -0
  210. package/dist/src/storage/migrations/migrator.d.ts.map +1 -1
  211. package/dist/src/storage/migrations/migrator.js +6 -0
  212. package/dist/src/storage/migrations/migrator.js.map +1 -1
  213. package/dist/src/subs/default-error-handler.d.ts.map +1 -1
  214. package/dist/src/subs/default-error-handler.js.map +1 -1
  215. package/dist/src/subs/subscription-notification-read-model.d.ts +3 -2
  216. package/dist/src/subs/subscription-notification-read-model.d.ts.map +1 -1
  217. package/dist/src/subs/subscription-notification-read-model.js +1 -1
  218. package/dist/src/subs/subscription-notification-read-model.js.map +1 -1
  219. package/dist/src/sync/batch-aggregator.d.ts +25 -0
  220. package/dist/src/sync/batch-aggregator.d.ts.map +1 -0
  221. package/dist/src/sync/batch-aggregator.js +94 -0
  222. package/dist/src/sync/batch-aggregator.js.map +1 -0
  223. package/dist/src/sync/buffered-mailbox.d.ts +36 -0
  224. package/dist/src/sync/buffered-mailbox.d.ts.map +1 -0
  225. package/dist/src/sync/buffered-mailbox.js +164 -0
  226. package/dist/src/sync/buffered-mailbox.js.map +1 -0
  227. package/dist/src/sync/channels/{gql-channel.d.ts → gql-req-channel.d.ts} +49 -42
  228. package/dist/src/sync/channels/gql-req-channel.d.ts.map +1 -0
  229. package/dist/src/sync/channels/gql-req-channel.js +548 -0
  230. package/dist/src/sync/channels/gql-req-channel.js.map +1 -0
  231. package/dist/src/sync/channels/gql-request-channel-factory.d.ts +32 -0
  232. package/dist/src/sync/channels/gql-request-channel-factory.d.ts.map +1 -0
  233. package/dist/src/sync/channels/gql-request-channel-factory.js +105 -0
  234. package/dist/src/sync/channels/gql-request-channel-factory.js.map +1 -0
  235. package/dist/src/sync/channels/gql-res-channel.d.ts +25 -0
  236. package/dist/src/sync/channels/gql-res-channel.d.ts.map +1 -0
  237. package/dist/src/sync/channels/gql-res-channel.js +79 -0
  238. package/dist/src/sync/channels/gql-res-channel.js.map +1 -0
  239. package/dist/src/sync/channels/gql-response-channel-factory.d.ts +13 -0
  240. package/dist/src/sync/channels/gql-response-channel-factory.d.ts.map +1 -0
  241. package/dist/src/sync/channels/gql-response-channel-factory.js +14 -0
  242. package/dist/src/sync/channels/gql-response-channel-factory.js.map +1 -0
  243. package/dist/src/sync/channels/index.d.ts +6 -4
  244. package/dist/src/sync/channels/index.d.ts.map +1 -1
  245. package/dist/src/sync/channels/index.js +6 -4
  246. package/dist/src/sync/channels/index.js.map +1 -1
  247. package/dist/src/sync/channels/interval-poll-timer.d.ts +40 -0
  248. package/dist/src/sync/channels/interval-poll-timer.d.ts.map +1 -0
  249. package/dist/src/sync/channels/interval-poll-timer.js +123 -0
  250. package/dist/src/sync/channels/interval-poll-timer.js.map +1 -0
  251. package/dist/src/sync/channels/poll-timer.d.ts +14 -0
  252. package/dist/src/sync/channels/poll-timer.d.ts.map +1 -0
  253. package/dist/src/sync/channels/poll-timer.js +2 -0
  254. package/dist/src/sync/channels/poll-timer.js.map +1 -0
  255. package/dist/src/sync/channels/utils.d.ts +15 -1
  256. package/dist/src/sync/channels/utils.d.ts.map +1 -1
  257. package/dist/src/sync/channels/utils.js +67 -2
  258. package/dist/src/sync/channels/utils.js.map +1 -1
  259. package/dist/src/sync/index.d.ts +10 -6
  260. package/dist/src/sync/index.d.ts.map +1 -1
  261. package/dist/src/sync/index.js +7 -5
  262. package/dist/src/sync/index.js.map +1 -1
  263. package/dist/src/sync/interfaces.d.ts +34 -21
  264. package/dist/src/sync/interfaces.d.ts.map +1 -1
  265. package/dist/src/sync/mailbox.d.ts +51 -12
  266. package/dist/src/sync/mailbox.d.ts.map +1 -1
  267. package/dist/src/sync/mailbox.js +89 -6
  268. package/dist/src/sync/mailbox.js.map +1 -1
  269. package/dist/src/sync/sync-awaiter.d.ts +34 -0
  270. package/dist/src/sync/sync-awaiter.d.ts.map +1 -0
  271. package/dist/src/sync/sync-awaiter.js +124 -0
  272. package/dist/src/sync/sync-awaiter.js.map +1 -0
  273. package/dist/src/sync/sync-builder.d.ts +5 -1
  274. package/dist/src/sync/sync-builder.d.ts.map +1 -1
  275. package/dist/src/sync/sync-builder.js +14 -1
  276. package/dist/src/sync/sync-builder.js.map +1 -1
  277. package/dist/src/sync/sync-manager.d.ts +21 -8
  278. package/dist/src/sync/sync-manager.d.ts.map +1 -1
  279. package/dist/src/sync/sync-manager.js +274 -93
  280. package/dist/src/sync/sync-manager.js.map +1 -1
  281. package/dist/src/sync/sync-operation.d.ts +4 -2
  282. package/dist/src/sync/sync-operation.d.ts.map +1 -1
  283. package/dist/src/sync/sync-operation.js +8 -1
  284. package/dist/src/sync/sync-operation.js.map +1 -1
  285. package/dist/src/sync/sync-status-tracker.d.ts +31 -0
  286. package/dist/src/sync/sync-status-tracker.d.ts.map +1 -0
  287. package/dist/src/sync/sync-status-tracker.js +137 -0
  288. package/dist/src/sync/sync-status-tracker.js.map +1 -0
  289. package/dist/src/sync/types.d.ts +79 -2
  290. package/dist/src/sync/types.d.ts.map +1 -1
  291. package/dist/src/sync/types.js +15 -0
  292. package/dist/src/sync/types.js.map +1 -1
  293. package/dist/src/sync/utils.d.ts +37 -2
  294. package/dist/src/sync/utils.d.ts.map +1 -1
  295. package/dist/src/sync/utils.js +205 -0
  296. package/dist/src/sync/utils.js.map +1 -1
  297. package/dist/src/utils/reshuffle.d.ts +22 -5
  298. package/dist/src/utils/reshuffle.d.ts.map +1 -1
  299. package/dist/src/utils/reshuffle.js +50 -6
  300. package/dist/src/utils/reshuffle.js.map +1 -1
  301. package/package.json +12 -15
  302. package/dist/src/processors/types.d.ts +0 -63
  303. package/dist/src/processors/types.d.ts.map +0 -1
  304. package/dist/src/processors/types.js +0 -2
  305. package/dist/src/processors/types.js.map +0 -1
  306. package/dist/src/storage/consistency-aware-legacy-storage.d.ts +0 -33
  307. package/dist/src/storage/consistency-aware-legacy-storage.d.ts.map +0 -1
  308. package/dist/src/storage/consistency-aware-legacy-storage.js +0 -65
  309. package/dist/src/storage/consistency-aware-legacy-storage.js.map +0 -1
  310. package/dist/src/sync/channels/composite-channel-factory.d.ts +0 -30
  311. package/dist/src/sync/channels/composite-channel-factory.d.ts.map +0 -1
  312. package/dist/src/sync/channels/composite-channel-factory.js +0 -87
  313. package/dist/src/sync/channels/composite-channel-factory.js.map +0 -1
  314. package/dist/src/sync/channels/gql-channel-factory.d.ts +0 -25
  315. package/dist/src/sync/channels/gql-channel-factory.d.ts.map +0 -1
  316. package/dist/src/sync/channels/gql-channel-factory.js +0 -76
  317. package/dist/src/sync/channels/gql-channel-factory.js.map +0 -1
  318. package/dist/src/sync/channels/gql-channel.d.ts.map +0 -1
  319. package/dist/src/sync/channels/gql-channel.js +0 -423
  320. package/dist/src/sync/channels/gql-channel.js.map +0 -1
  321. package/dist/src/sync/channels/polling-channel.d.ts +0 -39
  322. package/dist/src/sync/channels/polling-channel.d.ts.map +0 -1
  323. package/dist/src/sync/channels/polling-channel.js +0 -72
  324. package/dist/src/sync/channels/polling-channel.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/sync/channels/utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/sync/channels/utils.ts"],"names":[],"mappings":"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"}
@@ -1,12 +1,16 @@
1
1
  export type { IChannel, IChannelFactory, ISyncManager, Remote, } from "./interfaces.js";
2
2
  export type { ShutdownStatus } from "../shared/types.js";
3
- export type { ChannelConfig, ChannelHealth, SyncOperationErrorType, RemoteFilter, RemoteOptions, RemoteRecord, RemoteCursor, RemoteStatus, SyncEnvelope, SyncEnvelopeType, ChannelMeta, } from "./types.js";
4
- export { ChannelErrorSource, SyncOperationStatus } from "./types.js";
3
+ export type { ChannelConfig, ChannelHealth, ChannelMeta, JwtHandler, RemoteCursor, RemoteFilter, RemoteOptions, RemoteRecord, RemoteStatus, SyncEnvelope, SyncEnvelopeType, SyncFailedEvent, SyncOperationErrorType, SyncPendingEvent, SyncResult, SyncResultError, SyncResultStatus, SyncSucceededEvent, } from "./types.js";
4
+ export { ChannelErrorSource, ChannelScheme, SyncEventTypes, SyncOperationStatus, } from "./types.js";
5
+ export { BufferedMailbox } from "./buffered-mailbox.js";
6
+ export { Mailbox, type IMailbox } from "./mailbox.js";
5
7
  export { SyncOperation, SyncOperationAggregateError, } from "./sync-operation.js";
6
- export { Mailbox, type MailboxItem } from "./mailbox.js";
7
8
  export { ChannelError, PollingChannelError } from "./errors.js";
8
- export { PollingChannel, GqlChannelFactory, CompositeChannelFactory, } from "./channels/index.js";
9
- export { SyncManager } from "./sync-manager.js";
9
+ export { GqlRequestChannel, GqlRequestChannelFactory, GqlResponseChannel, GqlResponseChannelFactory, IntervalPollTimer, type GqlChannelConfig, type IPollTimer, } from "./channels/index.js";
10
10
  export { SyncBuilder } from "./sync-builder.js";
11
- export { createIdleHealth, filterOperations } from "./utils.js";
11
+ export { SyncManager } from "./sync-manager.js";
12
+ export { SyncStatus, SyncStatusTracker } from "./sync-status-tracker.js";
13
+ export type { ISyncStatusTracker, SyncStatusChangeCallback, } from "./sync-status-tracker.js";
14
+ export { batchOperationsByDocument, consolidateSyncOperations, createIdleHealth, filterOperations, sortEnvelopesByFirstOperationTimestamp, trimMailboxFromAckOrdinal, } from "./utils.js";
15
+ export type { OperationBatch } from "./utils.js";
12
16
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,QAAQ,EACR,eAAe,EACf,YAAY,EACZ,MAAM,GACP,MAAM,iBAAiB,CAAC;AAEzB,YAAY,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEzD,YAAY,EACV,aAAa,EACb,aAAa,EACb,sBAAsB,EACtB,YAAY,EACZ,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAChB,WAAW,GACZ,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAErE,OAAO,EACL,aAAa,EACb,2BAA2B,GAC5B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,QAAQ,EACR,eAAe,EACf,YAAY,EACZ,MAAM,GACP,MAAM,iBAAiB,CAAC;AAEzB,YAAY,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEzD,YAAY,EACV,aAAa,EACb,aAAa,EACb,WAAW,EACX,UAAU,EACV,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAChB,eAAe,EACf,sBAAsB,EACtB,gBAAgB,EAChB,UAAU,EACV,eAAe,EACf,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,YAAY,CAAC;AAEpB,OAAO,EACL,kBAAkB,EAClB,aAAa,EACb,cAAc,EACd,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,EACL,aAAa,EACb,2BAA2B,GAC5B,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EACL,iBAAiB,EACjB,wBAAwB,EACxB,kBAAkB,EAClB,yBAAyB,EACzB,iBAAiB,EACjB,KAAK,gBAAgB,EACrB,KAAK,UAAU,GAChB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AACzE,YAAY,EACV,kBAAkB,EAClB,wBAAwB,GACzB,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,yBAAyB,EACzB,yBAAyB,EACzB,gBAAgB,EAChB,gBAAgB,EAChB,sCAAsC,EACtC,yBAAyB,GAC1B,MAAM,YAAY,CAAC;AAEpB,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC"}
@@ -1,9 +1,11 @@
1
- export { ChannelErrorSource, SyncOperationStatus } from "./types.js";
2
- export { SyncOperation, SyncOperationAggregateError, } from "./sync-operation.js";
1
+ export { ChannelErrorSource, ChannelScheme, SyncEventTypes, SyncOperationStatus, } from "./types.js";
2
+ export { BufferedMailbox } from "./buffered-mailbox.js";
3
3
  export { Mailbox } from "./mailbox.js";
4
+ export { SyncOperation, SyncOperationAggregateError, } from "./sync-operation.js";
4
5
  export { ChannelError, PollingChannelError } from "./errors.js";
5
- export { PollingChannel, GqlChannelFactory, CompositeChannelFactory, } from "./channels/index.js";
6
- export { SyncManager } from "./sync-manager.js";
6
+ export { GqlRequestChannel, GqlRequestChannelFactory, GqlResponseChannel, GqlResponseChannelFactory, IntervalPollTimer, } from "./channels/index.js";
7
7
  export { SyncBuilder } from "./sync-builder.js";
8
- export { createIdleHealth, filterOperations } from "./utils.js";
8
+ export { SyncManager } from "./sync-manager.js";
9
+ export { SyncStatus, SyncStatusTracker } from "./sync-status-tracker.js";
10
+ export { batchOperationsByDocument, consolidateSyncOperations, createIdleHealth, filterOperations, sortEnvelopesByFirstOperationTimestamp, trimMailboxFromAckOrdinal, } from "./utils.js";
9
11
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":"AAuBA,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAErE,OAAO,EACL,aAAa,EACb,2BAA2B,GAC5B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,OAAO,EAAoB,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EACL,cAAc,EACd,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":"AA8BA,OAAO,EACL,kBAAkB,EAClB,aAAa,EACb,cAAc,EACd,mBAAmB,GACpB,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,OAAO,EAAiB,MAAM,cAAc,CAAC;AACtD,OAAO,EACL,aAAa,EACb,2BAA2B,GAC5B,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAEhE,OAAO,EACL,iBAAiB,EACjB,wBAAwB,EACxB,kBAAkB,EAClB,yBAAyB,EACzB,iBAAiB,GAGlB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAMzE,OAAO,EACL,yBAAyB,EACzB,yBAAyB,EACzB,gBAAgB,EAChB,gBAAgB,EAChB,sCAAsC,EACtC,yBAAyB,GAC1B,MAAM,YAAY,CAAC"}
@@ -1,8 +1,9 @@
1
+ import type { IOperationIndex } from "../cache/operation-index-types.js";
1
2
  import type { ShutdownStatus } from "../shared/types.js";
2
3
  import type { ISyncCursorStorage } from "../storage/interfaces.js";
3
- import type { SyncOperation } from "./sync-operation.js";
4
- import type { Mailbox } from "./mailbox.js";
5
- import type { ChannelConfig, RemoteFilter, RemoteOptions } from "./types.js";
4
+ import type { IMailbox } from "./mailbox.js";
5
+ import type { SyncStatus, SyncStatusChangeCallback } from "./sync-status-tracker.js";
6
+ import type { ChannelConfig, RemoteFilter, RemoteOptions, SyncResult } from "./types.js";
6
7
  /**
7
8
  * Represents a bidirectional synchronization channel between two reactor instances.
8
9
  *
@@ -10,29 +11,23 @@ import type { ChannelConfig, RemoteFilter, RemoteOptions } from "./types.js";
10
11
  * - inbox: Sync operations received from the remote that need to be applied locally
11
12
  * - outbox: Sync operations to be sent to the remote
12
13
  * - deadLetter: Sync operations that failed and cannot be retried
13
- *
14
- * Channels are responsible for:
15
- * - Transporting sync envelopes between reactor instances
16
- * - Managing sync operation lifecycle through status transitions
17
- * - Handling errors and moving failed sync operations to dead letter queue
18
- * - Updating cursors as operations are applied
19
14
  */
20
15
  export interface IChannel {
21
16
  /**
22
17
  * Mailbox containing sync operations received from the remote that need to be applied locally.
23
18
  * Consumers should register callbacks via onAdded to process incoming sync operations.
24
19
  */
25
- inbox: Mailbox<SyncOperation>;
20
+ inbox: IMailbox;
26
21
  /**
27
22
  * Mailbox containing sync operations that need to be sent to the remote.
28
23
  * The channel is responsible for transporting these sync operations and handling ACKs.
29
24
  */
30
- outbox: Mailbox<SyncOperation>;
25
+ outbox: IMailbox;
31
26
  /**
32
27
  * Mailbox containing sync operations that failed and cannot be retried.
33
28
  * These sync operations require manual intervention or should be logged for debugging.
34
29
  */
35
- deadLetter: Mailbox<SyncOperation>;
30
+ deadLetter: IMailbox;
36
31
  /**
37
32
  * Initializes the channel asynchronously.
38
33
  * For remote channels, this typically involves registering the channel on the remote server.
@@ -42,14 +37,7 @@ export interface IChannel {
42
37
  /**
43
38
  * Shuts down the channel and prevents further operations.
44
39
  */
45
- shutdown(): void;
46
- /**
47
- * Updates the synchronization cursor for this channel.
48
- * For polling channels, this also removes acknowledged operations from the outbox.
49
- *
50
- * @param cursorOrdinal - The last processed ordinal
51
- */
52
- updateCursor(cursorOrdinal: number): Promise<void>;
40
+ shutdown(): Promise<void>;
53
41
  }
54
42
  /**
55
43
  * Factory for creating channel instances.
@@ -67,9 +55,10 @@ export interface IChannelFactory {
67
55
  * @param cursorStorage - Storage for persisting synchronization cursors
68
56
  * @param collectionId - Collection ID to synchronize
69
57
  * @param filter - Filter to apply to operations
58
+ * @param operationIndex - Operation index for querying timestamps
70
59
  * @returns A new channel instance
71
60
  */
72
- instance(remoteId: string, remoteName: string, config: ChannelConfig, cursorStorage: ISyncCursorStorage, collectionId: string, filter: RemoteFilter): IChannel;
61
+ instance(remoteId: string, remoteName: string, config: ChannelConfig, cursorStorage: ISyncCursorStorage, collectionId: string, filter: RemoteFilter, operationIndex: IOperationIndex): IChannel;
73
62
  }
74
63
  /**
75
64
  * Represents a configured remote with an active channel.
@@ -176,5 +165,29 @@ export interface ISyncManager {
176
165
  * @returns Array of all remotes
177
166
  */
178
167
  list(): Remote[];
168
+ /**
169
+ * Waits for sync operations for a job to complete.
170
+ * Resolves when SYNC_SUCCEEDED is emitted.
171
+ * Rejects when SYNC_FAILED is emitted.
172
+ *
173
+ * @param jobId - The job id to wait for
174
+ * @param signal - Optional abort signal
175
+ * @returns The sync result
176
+ */
177
+ waitForSync(jobId: string, signal?: AbortSignal): Promise<SyncResult>;
178
+ /**
179
+ * Gets the current sync status for a document.
180
+ *
181
+ * @param documentId - The document ID to check
182
+ * @returns The sync status, or undefined if the document has never been tracked
183
+ */
184
+ getSyncStatus(documentId: string): SyncStatus | undefined;
185
+ /**
186
+ * Registers a callback that fires when a document's sync status changes.
187
+ *
188
+ * @param callback - Called with (documentId, newStatus) on each transition
189
+ * @returns Unsubscribe function
190
+ */
191
+ onSyncStatusChange(callback: SyncStatusChangeCallback): () => void;
179
192
  }
180
193
  //# sourceMappingURL=interfaces.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/sync/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE7E;;;;;;;;;;;;;GAaG;AACH,MAAM,WAAW,QAAQ;IACvB;;;OAGG;IACH,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;IAE9B;;;OAGG;IACH,MAAM,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;IAE/B;;;OAGG;IACH,UAAU,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;IAEnC;;;;OAIG;IACH,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB;;OAEG;IACH,QAAQ,IAAI,IAAI,CAAC;IAEjB;;;;;OAKG;IACH,YAAY,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACpD;AAED;;;;;GAKG;AACH,MAAM,WAAW,eAAe;IAC9B;;;;;;;;;;OAUG;IACH,QAAQ,CACN,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,aAAa,EACrB,aAAa,EAAE,kBAAkB,EACjC,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,YAAY,GACnB,QAAQ,CAAC;CACb;AAED;;;;;GAKG;AACH,MAAM,MAAM,MAAM,GAAG;IACnB;;OAEG;IACH,EAAE,EAAE,MAAM,CAAC;IAEX;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IAEb;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAC;IAErB;;;OAGG;IACH,MAAM,EAAE,YAAY,CAAC;IAErB;;OAEG;IACH,OAAO,EAAE,aAAa,CAAC;IAEvB;;OAEG;IACH,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B;;;;;;;OAOG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzB;;;;;;;OAOG;IACH,QAAQ,IAAI,cAAc,CAAC;IAE3B;;;;;;OAMG;IACH,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;IAEhC;;;;;;OAMG;IACH,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IAE5B;;;;;;;;;;;;;;OAcG;IACH,GAAG,CACD,IAAI,EAAE,MAAM,EACZ,YAAY,EAAE,MAAM,EACpB,aAAa,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,YAAY,EACrB,OAAO,CAAC,EAAE,aAAa,EACvB,EAAE,CAAC,EAAE,MAAM,GACV,OAAO,CAAC,MAAM,CAAC,CAAC;IAEnB;;;;;;;;;OASG;IACH,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC;;;;OAIG;IACH,IAAI,IAAI,MAAM,EAAE,CAAC;CAClB"}
1
+ {"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/sync/interfaces.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,KAAK,EACV,UAAU,EACV,wBAAwB,EACzB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACZ,aAAa,EACb,UAAU,EACX,MAAM,YAAY,CAAC;AAEpB;;;;;;;GAOG;AACH,MAAM,WAAW,QAAQ;IACvB;;;OAGG;IACH,KAAK,EAAE,QAAQ,CAAC;IAEhB;;;OAGG;IACH,MAAM,EAAE,QAAQ,CAAC;IAEjB;;;OAGG;IACH,UAAU,EAAE,QAAQ,CAAC;IAErB;;;;OAIG;IACH,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtB;;OAEG;IACH,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3B;AAED;;;;;GAKG;AACH,MAAM,WAAW,eAAe;IAC9B;;;;;;;;;;;OAWG;IACH,QAAQ,CACN,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,aAAa,EAErB,aAAa,EAAE,kBAAkB,EACjC,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE,YAAY,EAEpB,cAAc,EAAE,eAAe,GAC9B,QAAQ,CAAC;CACb;AAED;;;;;GAKG;AACH,MAAM,MAAM,MAAM,GAAG;IACnB;;OAEG;IACH,EAAE,EAAE,MAAM,CAAC;IAEX;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IAEb;;;OAGG;IACH,YAAY,EAAE,MAAM,CAAC;IAErB;;;OAGG;IACH,MAAM,EAAE,YAAY,CAAC;IAErB;;OAEG;IACH,OAAO,EAAE,aAAa,CAAC;IAEvB;;OAEG;IACH,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B;;;;;;;OAOG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzB;;;;;;;OAOG;IACH,QAAQ,IAAI,cAAc,CAAC;IAE3B;;;;;;OAMG;IACH,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAC;IAEhC;;;;;;OAMG;IACH,OAAO,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAAC;IAE5B;;;;;;;;;;;;;;OAcG;IACH,GAAG,CACD,IAAI,EAAE,MAAM,EACZ,YAAY,EAAE,MAAM,EACpB,aAAa,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,YAAY,EACrB,OAAO,CAAC,EAAE,aAAa,EACvB,EAAE,CAAC,EAAE,MAAM,GACV,OAAO,CAAC,MAAM,CAAC,CAAC;IAEnB;;;;;;;;;OASG;IACH,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpC;;;;OAIG;IACH,IAAI,IAAI,MAAM,EAAE,CAAC;IAEjB;;;;;;;;OAQG;IACH,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAEtE;;;;;OAKG;IACH,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS,CAAC;IAE1D;;;;;OAKG;IACH,kBAAkB,CAAC,QAAQ,EAAE,wBAAwB,GAAG,MAAM,IAAI,CAAC;CACpE"}
@@ -1,21 +1,60 @@
1
- export type MailboxItem = {
2
- id: string;
3
- };
4
- type MailboxCallback<T extends MailboxItem> = (item: T) => void;
1
+ import type { SyncOperation } from "./sync-operation.js";
2
+ export type MailboxCallback = (items: SyncOperation[]) => void;
3
+ /**
4
+ * The Mailbox interface is not intended to use any persistence. Instead, the
5
+ * IChannel implementation is responsible for persisting cursors or other data.
6
+ *
7
+ * This means that ackOrdinal and latestOrdinal are in memory only.
8
+ */
9
+ export interface IMailbox {
10
+ get items(): ReadonlyArray<SyncOperation>;
11
+ /**
12
+ * The latest ordinal that has been acknowledged. Because acknowledged items
13
+ * are removed from the mailbox, this is the last ordinal that has been removed.
14
+ */
15
+ get ackOrdinal(): number;
16
+ /**
17
+ * The latest ordinal of the items that are or have been added to the mailbox.
18
+ * This may be greater than the ack ordinal if items have been added but not
19
+ * yet acknowledged.
20
+ */
21
+ get latestOrdinal(): number;
22
+ init(ackOrdinal: number): void;
23
+ get(id: string): SyncOperation | undefined;
24
+ add(...items: SyncOperation[]): void;
25
+ remove(...items: SyncOperation[]): void;
26
+ onAdded(callback: MailboxCallback): void;
27
+ onRemoved(callback: MailboxCallback): void;
28
+ pause(): void;
29
+ resume(): void;
30
+ flush(): void;
31
+ isPaused(): boolean;
32
+ }
5
33
  export declare class MailboxAggregateError extends Error {
6
34
  errors: Error[];
7
35
  constructor(errors: Error[]);
8
36
  }
9
- export declare class Mailbox<T extends MailboxItem> {
37
+ export declare class Mailbox implements IMailbox {
10
38
  private itemsMap;
11
39
  private addedCallbacks;
12
40
  private removedCallbacks;
13
- get items(): ReadonlyArray<T>;
14
- get(id: string): T | undefined;
15
- add(item: T): void;
16
- remove(item: T): void;
17
- onAdded(callback: MailboxCallback<T>): void;
18
- onRemoved(callback: MailboxCallback<T>): void;
41
+ private paused;
42
+ private addedBuffer;
43
+ private removedBuffer;
44
+ private _ack;
45
+ private _latestOrdinal;
46
+ init(ackOrdinal: number): void;
47
+ get items(): ReadonlyArray<SyncOperation>;
48
+ get ackOrdinal(): number;
49
+ get latestOrdinal(): number;
50
+ get(id: string): SyncOperation | undefined;
51
+ add(...items: SyncOperation[]): void;
52
+ remove(...items: SyncOperation[]): void;
53
+ onAdded(callback: MailboxCallback): void;
54
+ onRemoved(callback: MailboxCallback): void;
55
+ pause(): void;
56
+ resume(): void;
57
+ flush(): void;
58
+ isPaused(): boolean;
19
59
  }
20
- export {};
21
60
  //# sourceMappingURL=mailbox.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mailbox.d.ts","sourceRoot":"","sources":["../../../src/sync/mailbox.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,KAAK,eAAe,CAAC,CAAC,SAAS,WAAW,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC;AAEhE,qBAAa,qBAAsB,SAAQ,KAAK;IAC9C,MAAM,EAAE,KAAK,EAAE,CAAC;gBAEJ,MAAM,EAAE,KAAK,EAAE;CAQ5B;AAED,qBAAa,OAAO,CAAC,CAAC,SAAS,WAAW;IACxC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,cAAc,CAA4B;IAClD,OAAO,CAAC,gBAAgB,CAA4B;IAEpD,IAAI,KAAK,IAAI,aAAa,CAAC,CAAC,CAAC,CAE5B;IAED,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,CAAC,GAAG,SAAS;IAI9B,GAAG,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI;IAgBlB,MAAM,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI;IAgBrB,OAAO,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI;IAI3C,SAAS,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI;CAG9C"}
1
+ {"version":3,"file":"mailbox.d.ts","sourceRoot":"","sources":["../../../src/sync/mailbox.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGzD,MAAM,MAAM,eAAe,GAAG,CAAC,KAAK,EAAE,aAAa,EAAE,KAAK,IAAI,CAAC;AAE/D;;;;;GAKG;AACH,MAAM,WAAW,QAAQ;IACvB,IAAI,KAAK,IAAI,aAAa,CAAC,aAAa,CAAC,CAAC;IAE1C;;;OAGG;IACH,IAAI,UAAU,IAAI,MAAM,CAAC;IAEzB;;;;OAIG;IACH,IAAI,aAAa,IAAI,MAAM,CAAC;IAG5B,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS,CAAC;IAC3C,GAAG,CAAC,GAAG,KAAK,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;IACrC,MAAM,CAAC,GAAG,KAAK,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;IAGxC,OAAO,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI,CAAC;IACzC,SAAS,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI,CAAC;IAG3C,KAAK,IAAI,IAAI,CAAC;IACd,MAAM,IAAI,IAAI,CAAC;IACf,KAAK,IAAI,IAAI,CAAC;IACd,QAAQ,IAAI,OAAO,CAAC;CACrB;AAED,qBAAa,qBAAsB,SAAQ,KAAK;IAC9C,MAAM,EAAE,KAAK,EAAE,CAAC;gBAEJ,MAAM,EAAE,KAAK,EAAE;CAQ5B;AAED,qBAAa,OAAQ,YAAW,QAAQ;IACtC,OAAO,CAAC,QAAQ,CAAyC;IACzD,OAAO,CAAC,cAAc,CAAyB;IAC/C,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,MAAM,CAAkB;IAChC,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,aAAa,CAAuB;IAE5C,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,cAAc,CAAa;IAEnC,IAAI,CAAC,UAAU,EAAE,MAAM;IAIvB,IAAI,KAAK,IAAI,aAAa,CAAC,aAAa,CAAC,CAExC;IAED,IAAI,UAAU,IAAI,MAAM,CAEvB;IAED,IAAI,aAAa,IAAI,MAAM,CAE1B;IAED,GAAG,CAAC,EAAE,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAI1C,GAAG,CAAC,GAAG,KAAK,EAAE,aAAa,EAAE,GAAG,IAAI;IAsCpC,MAAM,CAAC,GAAG,KAAK,EAAE,aAAa,EAAE,GAAG,IAAI;IAwBvC,OAAO,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI;IAIxC,SAAS,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI;IAI1C,KAAK,IAAI,IAAI;IAIb,MAAM,IAAI,IAAI;IAKd,KAAK,IAAI,IAAI;IAsCb,QAAQ,IAAI,OAAO;CAGpB"}
@@ -1,3 +1,4 @@
1
+ import { SyncOperationStatus } from "./types.js";
1
2
  export class MailboxAggregateError extends Error {
2
3
  errors;
3
4
  constructor(errors) {
@@ -11,19 +12,51 @@ export class Mailbox {
11
12
  itemsMap = new Map();
12
13
  addedCallbacks = [];
13
14
  removedCallbacks = [];
15
+ paused = false;
16
+ addedBuffer = [];
17
+ removedBuffer = [];
18
+ _ack = 0;
19
+ _latestOrdinal = 0;
20
+ init(ackOrdinal) {
21
+ this._ack = this._latestOrdinal = ackOrdinal;
22
+ }
14
23
  get items() {
15
24
  return Array.from(this.itemsMap.values());
16
25
  }
26
+ get ackOrdinal() {
27
+ return this._ack;
28
+ }
29
+ get latestOrdinal() {
30
+ return this._latestOrdinal;
31
+ }
17
32
  get(id) {
18
33
  return this.itemsMap.get(id);
19
34
  }
20
- add(item) {
21
- this.itemsMap.set(item.id, item);
35
+ add(...items) {
36
+ for (const item of items) {
37
+ this.itemsMap.set(item.id, item);
38
+ // update latest ordinal
39
+ for (const op of item.operations) {
40
+ this._latestOrdinal = Math.max(this._latestOrdinal, op.context.ordinal);
41
+ }
42
+ // listen for updates to the syncop status
43
+ item.on((syncOp, _, next) => {
44
+ if (next === SyncOperationStatus.Applied) {
45
+ for (const op of syncOp.operations) {
46
+ this._ack = Math.max(this._ack, op.context.ordinal);
47
+ }
48
+ }
49
+ });
50
+ }
51
+ if (this.paused) {
52
+ this.addedBuffer.push(...items);
53
+ return;
54
+ }
22
55
  const callbacks = [...this.addedCallbacks];
23
56
  const errors = [];
24
57
  for (const callback of callbacks) {
25
58
  try {
26
- callback(item);
59
+ callback(items);
27
60
  }
28
61
  catch (error) {
29
62
  errors.push(error instanceof Error ? error : new Error(String(error)));
@@ -33,13 +66,19 @@ export class Mailbox {
33
66
  throw new MailboxAggregateError(errors);
34
67
  }
35
68
  }
36
- remove(item) {
37
- this.itemsMap.delete(item.id);
69
+ remove(...items) {
70
+ for (const item of items) {
71
+ this.itemsMap.delete(item.id);
72
+ }
73
+ if (this.paused) {
74
+ this.removedBuffer.push(...items);
75
+ return;
76
+ }
38
77
  const callbacks = [...this.removedCallbacks];
39
78
  const errors = [];
40
79
  for (const callback of callbacks) {
41
80
  try {
42
- callback(item);
81
+ callback(items);
43
82
  }
44
83
  catch (error) {
45
84
  errors.push(error instanceof Error ? error : new Error(String(error)));
@@ -55,5 +94,49 @@ export class Mailbox {
55
94
  onRemoved(callback) {
56
95
  this.removedCallbacks.push(callback);
57
96
  }
97
+ pause() {
98
+ this.paused = true;
99
+ }
100
+ resume() {
101
+ this.paused = false;
102
+ this.flush();
103
+ }
104
+ flush() {
105
+ if (this.addedBuffer.length > 0) {
106
+ const items = this.addedBuffer.splice(0);
107
+ const callbacks = [...this.addedCallbacks];
108
+ const errors = [];
109
+ for (const callback of callbacks) {
110
+ try {
111
+ callback(items);
112
+ }
113
+ catch (error) {
114
+ errors.push(error instanceof Error ? error : new Error(String(error)));
115
+ }
116
+ }
117
+ if (errors.length > 0) {
118
+ throw new MailboxAggregateError(errors);
119
+ }
120
+ }
121
+ if (this.removedBuffer.length > 0) {
122
+ const items = this.removedBuffer.splice(0);
123
+ const callbacks = [...this.removedCallbacks];
124
+ const errors = [];
125
+ for (const callback of callbacks) {
126
+ try {
127
+ callback(items);
128
+ }
129
+ catch (error) {
130
+ errors.push(error instanceof Error ? error : new Error(String(error)));
131
+ }
132
+ }
133
+ if (errors.length > 0) {
134
+ throw new MailboxAggregateError(errors);
135
+ }
136
+ }
137
+ }
138
+ isPaused() {
139
+ return this.paused;
140
+ }
58
141
  }
59
142
  //# sourceMappingURL=mailbox.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mailbox.js","sourceRoot":"","sources":["../../../src/sync/mailbox.ts"],"names":[],"mappings":"AAMA,MAAM,OAAO,qBAAsB,SAAQ,KAAK;IAC9C,MAAM,CAAU;IAEhB,YAAY,MAAe;QACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzD,KAAK,CACH,gCAAgC,MAAM,CAAC,MAAM,cAAc,QAAQ,EAAE,CACtE,CAAC;QACF,IAAI,CAAC,IAAI,GAAG,uBAAuB,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;CACF;AAED,MAAM,OAAO,OAAO;IACV,QAAQ,GAAmB,IAAI,GAAG,EAAE,CAAC;IACrC,cAAc,GAAyB,EAAE,CAAC;IAC1C,gBAAgB,GAAyB,EAAE,CAAC;IAEpD,IAAI,KAAK;QACP,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,GAAG,CAAC,EAAU;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED,GAAG,CAAC,IAAO;QACT,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QACjC,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAY,EAAE,CAAC;QAC3B,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC;gBACH,QAAQ,CAAC,IAAI,CAAC,CAAC;YACjB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,IAAI,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACzE,CAAC;QACH,CAAC;QACD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,MAAM,IAAI,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAO;QACZ,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC9B,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC7C,MAAM,MAAM,GAAY,EAAE,CAAC;QAC3B,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC;gBACH,QAAQ,CAAC,IAAI,CAAC,CAAC;YACjB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,IAAI,CAAC,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACzE,CAAC;QACH,CAAC;QACD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,MAAM,IAAI,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED,OAAO,CAAC,QAA4B;QAClC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC;IAED,SAAS,CAAC,QAA4B;QACpC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;CACF"}
1
+ {"version":3,"file":"mailbox.js","sourceRoot":"","sources":["../../../src/sync/mailbox.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ import type { IEventBus } from "../events/interfaces.js";
2
+ import { type SyncResult } from "./types.js";
3
+ /**
4
+ * Provides a promise-based interface for waiting on sync completion.
5
+ * Subscribes to sync events at construction and tracks completed sync results
6
+ * to provide a fast path for jobs that have already synced.
7
+ */
8
+ export declare class SyncAwaiter {
9
+ private readonly eventBus;
10
+ private readonly completedResults;
11
+ private readonly pendingWaiters;
12
+ private readonly unsubscribers;
13
+ private isShutdown;
14
+ constructor(eventBus: IEventBus);
15
+ /**
16
+ * Waits for sync operations for a job to complete.
17
+ * Resolves when SYNC_SUCCEEDED is emitted.
18
+ * Rejects when SYNC_FAILED is emitted.
19
+ *
20
+ * @param jobId - The job id to wait for
21
+ * @param signal - Optional abort signal
22
+ * @returns The sync result
23
+ */
24
+ waitForSync(jobId: string, signal?: AbortSignal): Promise<SyncResult>;
25
+ /**
26
+ * Shuts down the sync awaiter. This will synchronously reject all pending waiters.
27
+ */
28
+ shutdown(): void;
29
+ private subscribeToEvents;
30
+ private handleSyncSucceeded;
31
+ private handleSyncFailed;
32
+ private resolveWaiters;
33
+ }
34
+ //# sourceMappingURL=sync-awaiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync-awaiter.d.ts","sourceRoot":"","sources":["../../../src/sync/sync-awaiter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAGL,KAAK,UAAU,EAEhB,MAAM,YAAY,CAAC;AAQpB;;;;GAIG;AACH,qBAAa,WAAW;IAMV,OAAO,CAAC,QAAQ,CAAC,QAAQ;IALrC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAiC;IAClE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAmC;IAClE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAqB;IACnD,OAAO,CAAC,UAAU,CAAS;gBAEE,QAAQ,EAAE,SAAS;IAIhD;;;;;;;;OAQG;IACH,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC;IAyCrE;;OAEG;IACH,QAAQ,IAAI,IAAI;IAgBhB,OAAO,CAAC,iBAAiB;IAoBzB,OAAO,CAAC,mBAAmB;IAc3B,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,cAAc;CAgBvB"}
@@ -0,0 +1,124 @@
1
+ import { SyncEventTypes, } from "./types.js";
2
+ /**
3
+ * Provides a promise-based interface for waiting on sync completion.
4
+ * Subscribes to sync events at construction and tracks completed sync results
5
+ * to provide a fast path for jobs that have already synced.
6
+ */
7
+ export class SyncAwaiter {
8
+ eventBus;
9
+ completedResults = new Map();
10
+ pendingWaiters = new Map();
11
+ unsubscribers = [];
12
+ isShutdown = false;
13
+ constructor(eventBus) {
14
+ this.eventBus = eventBus;
15
+ this.subscribeToEvents();
16
+ }
17
+ /**
18
+ * Waits for sync operations for a job to complete.
19
+ * Resolves when SYNC_SUCCEEDED is emitted.
20
+ * Rejects when SYNC_FAILED is emitted.
21
+ *
22
+ * @param jobId - The job id to wait for
23
+ * @param signal - Optional abort signal
24
+ * @returns The sync result
25
+ */
26
+ waitForSync(jobId, signal) {
27
+ if (signal?.aborted) {
28
+ return Promise.reject(new Error("Operation aborted"));
29
+ }
30
+ if (this.isShutdown) {
31
+ return Promise.reject(new Error("SyncAwaiter is shutdown"));
32
+ }
33
+ const completedResult = this.completedResults.get(jobId);
34
+ if (completedResult) {
35
+ return Promise.resolve(completedResult);
36
+ }
37
+ return new Promise((resolve, reject) => {
38
+ const waiter = { resolve, reject, signal };
39
+ const existingWaiters = this.pendingWaiters.get(jobId) || [];
40
+ existingWaiters.push(waiter);
41
+ this.pendingWaiters.set(jobId, existingWaiters);
42
+ if (signal) {
43
+ const abortHandler = () => {
44
+ const waiters = this.pendingWaiters.get(jobId);
45
+ if (waiters) {
46
+ const index = waiters.indexOf(waiter);
47
+ if (index !== -1) {
48
+ waiters.splice(index, 1);
49
+ if (waiters.length === 0) {
50
+ this.pendingWaiters.delete(jobId);
51
+ }
52
+ waiter.reject(new Error("Operation aborted"));
53
+ }
54
+ }
55
+ };
56
+ signal.addEventListener("abort", abortHandler, { once: true });
57
+ }
58
+ });
59
+ }
60
+ /**
61
+ * Shuts down the sync awaiter. This will synchronously reject all pending waiters.
62
+ */
63
+ shutdown() {
64
+ this.isShutdown = true;
65
+ for (const unsubscribe of this.unsubscribers) {
66
+ unsubscribe();
67
+ }
68
+ this.unsubscribers.length = 0;
69
+ for (const [, waiters] of this.pendingWaiters) {
70
+ for (const waiter of waiters) {
71
+ waiter.reject(new Error("SyncAwaiter shutdown"));
72
+ }
73
+ }
74
+ this.pendingWaiters.clear();
75
+ }
76
+ subscribeToEvents() {
77
+ this.unsubscribers.push(this.eventBus.subscribe(SyncEventTypes.SYNC_SUCCEEDED, (_type, event) => {
78
+ this.handleSyncSucceeded(event);
79
+ }));
80
+ this.unsubscribers.push(this.eventBus.subscribe(SyncEventTypes.SYNC_FAILED, (_type, event) => {
81
+ this.handleSyncFailed(event);
82
+ }));
83
+ }
84
+ handleSyncSucceeded(event) {
85
+ const result = {
86
+ jobId: event.jobId,
87
+ status: "succeeded",
88
+ syncOperationCount: event.syncOperationCount,
89
+ successCount: event.syncOperationCount,
90
+ failureCount: 0,
91
+ errors: [],
92
+ };
93
+ this.completedResults.set(event.jobId, result);
94
+ this.resolveWaiters(event.jobId, result);
95
+ }
96
+ handleSyncFailed(event) {
97
+ const result = {
98
+ jobId: event.jobId,
99
+ status: "failed",
100
+ syncOperationCount: event.successCount + event.failureCount,
101
+ successCount: event.successCount,
102
+ failureCount: event.failureCount,
103
+ errors: event.errors,
104
+ };
105
+ this.completedResults.set(event.jobId, result);
106
+ this.resolveWaiters(event.jobId, result);
107
+ }
108
+ resolveWaiters(jobId, result) {
109
+ const waiters = this.pendingWaiters.get(jobId);
110
+ if (!waiters || waiters.length === 0) {
111
+ return;
112
+ }
113
+ this.pendingWaiters.delete(jobId);
114
+ for (const waiter of waiters) {
115
+ if (waiter.signal?.aborted) {
116
+ waiter.reject(new Error("Operation aborted"));
117
+ }
118
+ else {
119
+ waiter.resolve(result);
120
+ }
121
+ }
122
+ }
123
+ }
124
+ //# sourceMappingURL=sync-awaiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync-awaiter.js","sourceRoot":"","sources":["../../../src/sync/sync-awaiter.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,cAAc,GAIf,MAAM,YAAY,CAAC;AAQpB;;;;GAIG;AACH,MAAM,OAAO,WAAW;IAMO;IALZ,gBAAgB,GAAG,IAAI,GAAG,EAAsB,CAAC;IACjD,cAAc,GAAG,IAAI,GAAG,EAAwB,CAAC;IACjD,aAAa,GAAkB,EAAE,CAAC;IAC3C,UAAU,GAAG,KAAK,CAAC;IAE3B,YAA6B,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QAC9C,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED;;;;;;;;OAQG;IACH,WAAW,CAAC,KAAa,EAAE,MAAoB;QAC7C,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACxD,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC,CAAC;QAC9D,CAAC;QAED,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACzD,IAAI,eAAe,EAAE,CAAC;YACpB,OAAO,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC1C,CAAC;QAED,OAAO,IAAI,OAAO,CAAa,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACjD,MAAM,MAAM,GAAe,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;YAEvD,MAAM,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAC7D,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;YAEhD,IAAI,MAAM,EAAE,CAAC;gBACX,MAAM,YAAY,GAAG,GAAG,EAAE;oBACxB,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBAC/C,IAAI,OAAO,EAAE,CAAC;wBACZ,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;wBACtC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;4BACjB,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;4BACzB,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gCACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;4BACpC,CAAC;4BACD,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;wBAChD,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC;gBAEF,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YACjE,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAEvB,KAAK,MAAM,WAAW,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YAC7C,WAAW,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;QAE9B,KAAK,MAAM,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YAC9C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC,CAAC;YACnD,CAAC;QACH,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,QAAQ,CAAC,SAAS,CACrB,cAAc,CAAC,cAAc,EAC7B,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACf,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAClC,CAAC,CACF,CACF,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,QAAQ,CAAC,SAAS,CACrB,cAAc,CAAC,WAAW,EAC1B,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACf,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC/B,CAAC,CACF,CACF,CAAC;IACJ,CAAC;IAEO,mBAAmB,CAAC,KAAyB;QACnD,MAAM,MAAM,GAAe;YACzB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,MAAM,EAAE,WAAW;YACnB,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;YAC5C,YAAY,EAAE,KAAK,CAAC,kBAAkB;YACtC,YAAY,EAAE,CAAC;YACf,MAAM,EAAE,EAAE;SACX,CAAC;QAEF,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC3C,CAAC;IAEO,gBAAgB,CAAC,KAAsB;QAC7C,MAAM,MAAM,GAAe;YACzB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,MAAM,EAAE,QAAQ;YAChB,kBAAkB,EAAE,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY;YAC3D,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,MAAM,EAAE,KAAK,CAAC,MAAM;SACrB,CAAC;QAEF,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC/C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC3C,CAAC;IAEO,cAAc,CAAC,KAAa,EAAE,MAAkB;QACtD,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACrC,OAAO;QACT,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAElC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,EAAE,CAAC;gBAC3B,MAAM,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAChD,CAAC;iBAAM,CAAC;gBACN,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;CACF"}
@@ -3,16 +3,20 @@ import type { IOperationIndex } from "../cache/operation-index-types.js";
3
3
  import type { IReactor, SyncModule } from "../core/types.js";
4
4
  import type { IEventBus } from "../events/interfaces.js";
5
5
  import type { ILogger } from "../logging/types.js";
6
- import type { ISyncCursorStorage, ISyncRemoteStorage } from "../storage/interfaces.js";
6
+ import type { ISyncCursorStorage, ISyncDeadLetterStorage, ISyncRemoteStorage } from "../storage/interfaces.js";
7
7
  import type { Database } from "../storage/kysely/types.js";
8
8
  import type { IChannelFactory, ISyncManager } from "./interfaces.js";
9
9
  export declare class SyncBuilder {
10
10
  private channelFactory?;
11
11
  private remoteStorage?;
12
12
  private cursorStorage?;
13
+ private deadLetterStorage?;
14
+ private maxDeadLettersPerRemote;
13
15
  withChannelFactory(factory: IChannelFactory): this;
14
16
  withRemoteStorage(storage: ISyncRemoteStorage): this;
15
17
  withCursorStorage(storage: ISyncCursorStorage): this;
18
+ withDeadLetterStorage(storage: ISyncDeadLetterStorage): this;
19
+ withMaxDeadLettersPerRemote(limit: number): this;
16
20
  build(reactor: IReactor, logger: ILogger, operationIndex: IOperationIndex, eventBus: IEventBus, db: Kysely<Database>): ISyncManager;
17
21
  buildModule(reactor: IReactor, logger: ILogger, operationIndex: IOperationIndex, eventBus: IEventBus, db: Kysely<Database>): SyncModule;
18
22
  }
@@ -1 +1 @@
1
- {"version":3,"file":"sync-builder.d.ts","sourceRoot":"","sources":["../../../src/sync/sync-builder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EACV,kBAAkB,EAClB,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAGlC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,KAAK,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAGrE,qBAAa,WAAW;IACtB,OAAO,CAAC,cAAc,CAAC,CAAkB;IACzC,OAAO,CAAC,aAAa,CAAC,CAAqB;IAC3C,OAAO,CAAC,aAAa,CAAC,CAAqB;IAE3C,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAKlD,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAKpD,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAKpD,KAAK,CACH,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,OAAO,EACf,cAAc,EAAE,eAAe,EAC/B,QAAQ,EAAE,SAAS,EACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,GACnB,YAAY;IAWf,WAAW,CACT,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,OAAO,EACf,cAAc,EAAE,eAAe,EAC/B,QAAQ,EAAE,SAAS,EACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,GACnB,UAAU;CAyBd"}
1
+ {"version":3,"file":"sync-builder.d.ts","sourceRoot":"","sources":["../../../src/sync/sync-builder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACzD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,KAAK,EACV,kBAAkB,EAClB,sBAAsB,EACtB,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAIlC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,KAAK,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAGrE,qBAAa,WAAW;IACtB,OAAO,CAAC,cAAc,CAAC,CAAkB;IACzC,OAAO,CAAC,aAAa,CAAC,CAAqB;IAC3C,OAAO,CAAC,aAAa,CAAC,CAAqB;IAC3C,OAAO,CAAC,iBAAiB,CAAC,CAAyB;IACnD,OAAO,CAAC,uBAAuB,CAAe;IAE9C,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAKlD,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAKpD,iBAAiB,CAAC,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAKpD,qBAAqB,CAAC,OAAO,EAAE,sBAAsB,GAAG,IAAI;IAK5D,2BAA2B,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKhD,KAAK,CACH,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,OAAO,EACf,cAAc,EAAE,eAAe,EAC/B,QAAQ,EAAE,SAAS,EACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,GACnB,YAAY;IAWf,WAAW,CACT,OAAO,EAAE,QAAQ,EACjB,MAAM,EAAE,OAAO,EACf,cAAc,EAAE,eAAe,EAC/B,QAAQ,EAAE,SAAS,EACnB,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,GACnB,UAAU;CA8Bd"}