@powerhousedao/reactor 4.1.0-dev.12 → 4.1.0-dev.121

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 (366) hide show
  1. package/dist/src/cache/buffer/ring-buffer.d.ts +37 -0
  2. package/dist/src/cache/buffer/ring-buffer.d.ts.map +1 -0
  3. package/dist/src/cache/buffer/ring-buffer.js +69 -0
  4. package/dist/src/cache/buffer/ring-buffer.js.map +1 -0
  5. package/dist/src/cache/index.d.ts +3 -0
  6. package/dist/src/cache/index.d.ts.map +1 -0
  7. package/dist/src/cache/index.js +2 -0
  8. package/dist/src/cache/index.js.map +1 -0
  9. package/dist/src/cache/kysely-operation-index.d.ts +13 -0
  10. package/dist/src/cache/kysely-operation-index.d.ts.map +1 -0
  11. package/dist/src/cache/kysely-operation-index.js +207 -0
  12. package/dist/src/cache/kysely-operation-index.js.map +1 -0
  13. package/dist/src/cache/kysely-write-cache.d.ts +134 -0
  14. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -0
  15. package/dist/src/cache/kysely-write-cache.js +375 -0
  16. package/dist/src/cache/kysely-write-cache.js.map +1 -0
  17. package/dist/src/cache/lru/lru-tracker.d.ts +15 -0
  18. package/dist/src/cache/lru/lru-tracker.d.ts.map +1 -0
  19. package/dist/src/cache/lru/lru-tracker.js +96 -0
  20. package/dist/src/cache/lru/lru-tracker.js.map +1 -0
  21. package/dist/src/cache/operation-index-types.d.ts +49 -0
  22. package/dist/src/cache/operation-index-types.d.ts.map +1 -0
  23. package/dist/src/cache/operation-index-types.js +4 -0
  24. package/dist/src/cache/operation-index-types.js.map +1 -0
  25. package/dist/src/cache/write/interfaces.d.ts +83 -0
  26. package/dist/src/cache/write/interfaces.d.ts.map +1 -0
  27. package/dist/src/cache/write/interfaces.js +2 -0
  28. package/dist/src/cache/write/interfaces.js.map +1 -0
  29. package/dist/src/cache/write-cache-types.d.ts +42 -0
  30. package/dist/src/cache/write-cache-types.d.ts.map +1 -0
  31. package/dist/src/cache/write-cache-types.js +2 -0
  32. package/dist/src/cache/write-cache-types.js.map +1 -0
  33. package/dist/src/client/reactor-client.d.ts +103 -0
  34. package/dist/src/client/reactor-client.d.ts.map +1 -0
  35. package/dist/src/client/reactor-client.js +184 -0
  36. package/dist/src/client/reactor-client.js.map +1 -0
  37. package/dist/src/client/types.d.ts +213 -0
  38. package/dist/src/client/types.d.ts.map +1 -0
  39. package/dist/src/client/types.js +14 -0
  40. package/dist/src/client/types.js.map +1 -0
  41. package/dist/src/core/builder.d.ts +20 -0
  42. package/dist/src/core/builder.d.ts.map +1 -0
  43. package/dist/src/core/builder.js +47 -0
  44. package/dist/src/core/builder.js.map +1 -0
  45. package/dist/src/core/reactor-builder.d.ts +37 -0
  46. package/dist/src/core/reactor-builder.d.ts.map +1 -0
  47. package/dist/src/core/reactor-builder.js +138 -0
  48. package/dist/src/core/reactor-builder.js.map +1 -0
  49. package/dist/src/core/reactor.d.ts +111 -0
  50. package/dist/src/core/reactor.d.ts.map +1 -0
  51. package/dist/src/core/reactor.js +952 -0
  52. package/dist/src/core/reactor.js.map +1 -0
  53. package/dist/src/core/types.d.ts +183 -0
  54. package/dist/src/core/types.d.ts.map +1 -0
  55. package/dist/src/core/types.js +2 -0
  56. package/dist/src/core/types.js.map +1 -0
  57. package/dist/src/core/utils.d.ts +51 -0
  58. package/dist/src/core/utils.d.ts.map +1 -0
  59. package/dist/src/core/utils.js +141 -0
  60. package/dist/src/core/utils.js.map +1 -0
  61. package/dist/src/events/event-bus.d.ts +3 -3
  62. package/dist/src/events/event-bus.d.ts.map +1 -1
  63. package/dist/src/events/event-bus.js.map +1 -1
  64. package/dist/src/events/interfaces.d.ts +1 -1
  65. package/dist/src/events/interfaces.d.ts.map +1 -1
  66. package/dist/src/events/types.d.ts +31 -1
  67. package/dist/src/events/types.d.ts.map +1 -1
  68. package/dist/src/events/types.js +7 -0
  69. package/dist/src/events/types.js.map +1 -1
  70. package/dist/src/executor/interfaces.d.ts +31 -54
  71. package/dist/src/executor/interfaces.d.ts.map +1 -1
  72. package/dist/src/executor/simple-job-executor-manager.d.ts +32 -0
  73. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -0
  74. package/dist/src/executor/simple-job-executor-manager.js +214 -0
  75. package/dist/src/executor/simple-job-executor-manager.js.map +1 -0
  76. package/dist/src/executor/simple-job-executor.d.ts +62 -0
  77. package/dist/src/executor/simple-job-executor.d.ts.map +1 -0
  78. package/dist/src/executor/simple-job-executor.js +705 -0
  79. package/dist/src/executor/simple-job-executor.js.map +1 -0
  80. package/dist/src/executor/types.d.ts +32 -8
  81. package/dist/src/executor/types.d.ts.map +1 -1
  82. package/dist/src/executor/types.js.map +1 -1
  83. package/dist/src/executor/util.d.ts +65 -0
  84. package/dist/src/executor/util.d.ts.map +1 -0
  85. package/dist/src/executor/util.js +154 -0
  86. package/dist/src/executor/util.js.map +1 -0
  87. package/dist/src/index.d.ts +35 -3
  88. package/dist/src/index.d.ts.map +1 -1
  89. package/dist/src/index.js +43 -2
  90. package/dist/src/index.js.map +1 -1
  91. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +16 -0
  92. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -0
  93. package/dist/src/job-tracker/in-memory-job-tracker.js +84 -0
  94. package/dist/src/job-tracker/in-memory-job-tracker.js.map +1 -0
  95. package/dist/src/job-tracker/index.d.ts +3 -0
  96. package/dist/src/job-tracker/index.d.ts.map +1 -0
  97. package/dist/src/job-tracker/index.js +2 -0
  98. package/dist/src/job-tracker/index.js.map +1 -0
  99. package/dist/src/job-tracker/interfaces.d.ts +42 -0
  100. package/dist/src/job-tracker/interfaces.d.ts.map +1 -0
  101. package/dist/src/job-tracker/interfaces.js +2 -0
  102. package/dist/src/job-tracker/interfaces.js.map +1 -0
  103. package/dist/src/queue/interfaces.d.ts +46 -5
  104. package/dist/src/queue/interfaces.d.ts.map +1 -1
  105. package/dist/src/queue/job-execution-handle.d.ts +25 -0
  106. package/dist/src/queue/job-execution-handle.d.ts.map +1 -0
  107. package/dist/src/queue/job-execution-handle.js +62 -0
  108. package/dist/src/queue/job-execution-handle.js.map +1 -0
  109. package/dist/src/queue/queue.d.ts +56 -5
  110. package/dist/src/queue/queue.d.ts.map +1 -1
  111. package/dist/src/queue/queue.js +284 -36
  112. package/dist/src/queue/queue.js.map +1 -1
  113. package/dist/src/queue/types.d.ts +38 -5
  114. package/dist/src/queue/types.d.ts.map +1 -1
  115. package/dist/src/queue/types.js +12 -0
  116. package/dist/src/queue/types.js.map +1 -1
  117. package/dist/src/read-models/coordinator.d.ts +38 -0
  118. package/dist/src/read-models/coordinator.d.ts.map +1 -0
  119. package/dist/src/read-models/coordinator.js +72 -0
  120. package/dist/src/read-models/coordinator.js.map +1 -0
  121. package/dist/src/read-models/document-view.d.ts +24 -0
  122. package/dist/src/read-models/document-view.d.ts.map +1 -0
  123. package/dist/src/read-models/document-view.js +368 -0
  124. package/dist/src/read-models/document-view.js.map +1 -0
  125. package/dist/src/read-models/interfaces.d.ts +29 -0
  126. package/dist/src/read-models/interfaces.d.ts.map +1 -0
  127. package/dist/src/read-models/interfaces.js +2 -0
  128. package/dist/src/read-models/interfaces.js.map +1 -0
  129. package/dist/src/read-models/types.d.ts +46 -0
  130. package/dist/src/read-models/types.d.ts.map +1 -0
  131. package/dist/src/read-models/types.js +2 -0
  132. package/dist/src/read-models/types.js.map +1 -0
  133. package/dist/src/registry/implementation.d.ts +62 -0
  134. package/dist/src/registry/implementation.d.ts.map +1 -0
  135. package/dist/src/registry/implementation.js +96 -0
  136. package/dist/src/registry/implementation.js.map +1 -0
  137. package/dist/src/registry/index.d.ts +3 -0
  138. package/dist/src/registry/index.d.ts.map +1 -0
  139. package/dist/src/registry/index.js +2 -0
  140. package/dist/src/registry/index.js.map +1 -0
  141. package/dist/src/registry/interfaces.d.ts +39 -0
  142. package/dist/src/registry/interfaces.d.ts.map +1 -0
  143. package/dist/src/registry/interfaces.js +2 -0
  144. package/dist/src/registry/interfaces.js.map +1 -0
  145. package/dist/src/shared/awaiter.d.ts +32 -0
  146. package/dist/src/shared/awaiter.d.ts.map +1 -0
  147. package/dist/src/shared/awaiter.js +132 -0
  148. package/dist/src/shared/awaiter.js.map +1 -0
  149. package/dist/src/shared/consistency-tracker.d.ts +48 -0
  150. package/dist/src/shared/consistency-tracker.d.ts.map +1 -0
  151. package/dist/src/shared/consistency-tracker.js +123 -0
  152. package/dist/src/shared/consistency-tracker.js.map +1 -0
  153. package/dist/src/shared/errors.d.ts +17 -0
  154. package/dist/src/shared/errors.d.ts.map +1 -0
  155. package/dist/src/shared/errors.js +33 -0
  156. package/dist/src/shared/errors.js.map +1 -0
  157. package/dist/src/shared/factories.d.ts +16 -0
  158. package/dist/src/shared/factories.d.ts.map +1 -0
  159. package/dist/src/shared/factories.js +33 -0
  160. package/dist/src/shared/factories.js.map +1 -0
  161. package/dist/src/shared/types.d.ts +126 -20
  162. package/dist/src/shared/types.d.ts.map +1 -1
  163. package/dist/src/shared/types.js +35 -1
  164. package/dist/src/shared/types.js.map +1 -1
  165. package/dist/src/shared/utils.d.ts +3 -0
  166. package/dist/src/shared/utils.d.ts.map +1 -0
  167. package/dist/src/shared/utils.js +8 -0
  168. package/dist/src/shared/utils.js.map +1 -0
  169. package/dist/src/signer/passthrough-signer.d.ts +6 -0
  170. package/dist/src/signer/passthrough-signer.d.ts.map +1 -0
  171. package/dist/src/signer/passthrough-signer.js +6 -0
  172. package/dist/src/signer/passthrough-signer.js.map +1 -0
  173. package/dist/src/signer/types.d.ts +15 -0
  174. package/dist/src/signer/types.d.ts.map +1 -0
  175. package/dist/src/signer/types.js +2 -0
  176. package/dist/src/signer/types.js.map +1 -0
  177. package/dist/src/storage/index.d.ts +4 -0
  178. package/dist/src/storage/index.d.ts.map +1 -0
  179. package/dist/src/storage/index.js +3 -0
  180. package/dist/src/storage/index.js.map +1 -0
  181. package/dist/src/storage/interfaces.d.ts +335 -0
  182. package/dist/src/storage/interfaces.d.ts.map +1 -0
  183. package/dist/src/storage/interfaces.js +19 -0
  184. package/dist/src/storage/interfaces.js.map +1 -0
  185. package/dist/src/storage/kysely/document-indexer.d.ts +28 -0
  186. package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -0
  187. package/dist/src/storage/kysely/document-indexer.js +350 -0
  188. package/dist/src/storage/kysely/document-indexer.js.map +1 -0
  189. package/dist/src/storage/kysely/keyframe-store.d.ts +15 -0
  190. package/dist/src/storage/kysely/keyframe-store.d.ts.map +1 -0
  191. package/dist/src/storage/kysely/keyframe-store.js +64 -0
  192. package/dist/src/storage/kysely/keyframe-store.js.map +1 -0
  193. package/dist/src/storage/kysely/store.d.ts +15 -0
  194. package/dist/src/storage/kysely/store.d.ts.map +1 -0
  195. package/dist/src/storage/kysely/store.js +196 -0
  196. package/dist/src/storage/kysely/store.js.map +1 -0
  197. package/dist/src/storage/kysely/sync-cursor-storage.d.ts +13 -0
  198. package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -0
  199. package/dist/src/storage/kysely/sync-cursor-storage.js +93 -0
  200. package/dist/src/storage/kysely/sync-cursor-storage.js.map +1 -0
  201. package/dist/src/storage/kysely/sync-remote-storage.d.ts +13 -0
  202. package/dist/src/storage/kysely/sync-remote-storage.d.ts.map +1 -0
  203. package/dist/src/storage/kysely/sync-remote-storage.js +134 -0
  204. package/dist/src/storage/kysely/sync-remote-storage.js.map +1 -0
  205. package/dist/src/storage/kysely/types.d.ts +135 -0
  206. package/dist/src/storage/kysely/types.d.ts.map +1 -0
  207. package/dist/src/storage/kysely/types.js +2 -0
  208. package/dist/src/storage/kysely/types.js.map +1 -0
  209. package/dist/src/storage/migrations/001_create_operation_table.d.ts +3 -0
  210. package/dist/src/storage/migrations/001_create_operation_table.d.ts.map +1 -0
  211. package/dist/src/storage/migrations/001_create_operation_table.js +40 -0
  212. package/dist/src/storage/migrations/001_create_operation_table.js.map +1 -0
  213. package/dist/src/storage/migrations/002_create_keyframe_table.d.ts +3 -0
  214. package/dist/src/storage/migrations/002_create_keyframe_table.d.ts.map +1 -0
  215. package/dist/src/storage/migrations/002_create_keyframe_table.js +27 -0
  216. package/dist/src/storage/migrations/002_create_keyframe_table.js.map +1 -0
  217. package/dist/src/storage/migrations/003_create_document_table.d.ts +3 -0
  218. package/dist/src/storage/migrations/003_create_document_table.d.ts.map +1 -0
  219. package/dist/src/storage/migrations/003_create_document_table.js +10 -0
  220. package/dist/src/storage/migrations/003_create_document_table.js.map +1 -0
  221. package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts +3 -0
  222. package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts.map +1 -0
  223. package/dist/src/storage/migrations/004_create_document_relationship_table.js +35 -0
  224. package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +1 -0
  225. package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts +3 -0
  226. package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts.map +1 -0
  227. package/dist/src/storage/migrations/005_create_indexer_state_table.js +10 -0
  228. package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +1 -0
  229. package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts +3 -0
  230. package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts.map +1 -0
  231. package/dist/src/storage/migrations/006_create_document_snapshot_table.js +49 -0
  232. package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +1 -0
  233. package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts +3 -0
  234. package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts.map +1 -0
  235. package/dist/src/storage/migrations/007_create_slug_mapping_table.js +24 -0
  236. package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +1 -0
  237. package/dist/src/storage/migrations/008_create_view_state_table.d.ts +3 -0
  238. package/dist/src/storage/migrations/008_create_view_state_table.d.ts.map +1 -0
  239. package/dist/src/storage/migrations/008_create_view_state_table.js +9 -0
  240. package/dist/src/storage/migrations/008_create_view_state_table.js.map +1 -0
  241. package/dist/src/storage/migrations/009_create_operation_index_tables.d.ts +3 -0
  242. package/dist/src/storage/migrations/009_create_operation_index_tables.d.ts.map +1 -0
  243. package/dist/src/storage/migrations/009_create_operation_index_tables.js +50 -0
  244. package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +1 -0
  245. package/dist/src/storage/migrations/010_create_sync_tables.d.ts +3 -0
  246. package/dist/src/storage/migrations/010_create_sync_tables.d.ts.map +1 -0
  247. package/dist/src/storage/migrations/010_create_sync_tables.js +43 -0
  248. package/dist/src/storage/migrations/010_create_sync_tables.js.map +1 -0
  249. package/dist/src/storage/migrations/index.d.ts +3 -0
  250. package/dist/src/storage/migrations/index.d.ts.map +1 -0
  251. package/dist/src/storage/migrations/index.js +3 -0
  252. package/dist/src/storage/migrations/index.js.map +1 -0
  253. package/dist/src/storage/migrations/migrator.d.ts +5 -0
  254. package/dist/src/storage/migrations/migrator.d.ts.map +1 -0
  255. package/dist/src/storage/migrations/migrator.js +55 -0
  256. package/dist/src/storage/migrations/migrator.js.map +1 -0
  257. package/dist/src/storage/migrations/run-migrations.d.ts +2 -0
  258. package/dist/src/storage/migrations/run-migrations.d.ts.map +1 -0
  259. package/dist/src/storage/migrations/run-migrations.js +58 -0
  260. package/dist/src/storage/migrations/run-migrations.js.map +1 -0
  261. package/dist/src/storage/migrations/types.d.ts +9 -0
  262. package/dist/src/storage/migrations/types.d.ts.map +1 -0
  263. package/dist/src/storage/migrations/types.js +2 -0
  264. package/dist/src/storage/migrations/types.js.map +1 -0
  265. package/dist/src/storage/txn.d.ts +15 -0
  266. package/dist/src/storage/txn.d.ts.map +1 -0
  267. package/dist/src/storage/txn.js +43 -0
  268. package/dist/src/storage/txn.js.map +1 -0
  269. package/dist/src/subs/default-error-handler.d.ts +13 -0
  270. package/dist/src/subs/default-error-handler.d.ts.map +1 -0
  271. package/dist/src/subs/default-error-handler.js +27 -0
  272. package/dist/src/subs/default-error-handler.js.map +1 -0
  273. package/dist/src/subs/react-subscription-manager.d.ts +45 -0
  274. package/dist/src/subs/react-subscription-manager.d.ts.map +1 -0
  275. package/dist/src/subs/react-subscription-manager.js +185 -0
  276. package/dist/src/subs/react-subscription-manager.js.map +1 -0
  277. package/dist/src/subs/types.d.ts +64 -0
  278. package/dist/src/subs/types.d.ts.map +1 -0
  279. package/dist/src/subs/types.js +2 -0
  280. package/dist/src/subs/types.js.map +1 -0
  281. package/dist/src/sync/channels/index.d.ts +3 -0
  282. package/dist/src/sync/channels/index.d.ts.map +1 -0
  283. package/dist/src/sync/channels/index.js +3 -0
  284. package/dist/src/sync/channels/index.js.map +1 -0
  285. package/dist/src/sync/channels/internal-channel.d.ts +57 -0
  286. package/dist/src/sync/channels/internal-channel.d.ts.map +1 -0
  287. package/dist/src/sync/channels/internal-channel.js +106 -0
  288. package/dist/src/sync/channels/internal-channel.js.map +1 -0
  289. package/dist/src/sync/channels/utils.d.ts +15 -0
  290. package/dist/src/sync/channels/utils.d.ts.map +1 -0
  291. package/dist/src/sync/channels/utils.js +26 -0
  292. package/dist/src/sync/channels/utils.js.map +1 -0
  293. package/dist/src/sync/errors.d.ts +10 -0
  294. package/dist/src/sync/errors.d.ts.map +1 -0
  295. package/dist/src/sync/errors.js +17 -0
  296. package/dist/src/sync/errors.js.map +1 -0
  297. package/dist/src/sync/index.d.ts +12 -0
  298. package/dist/src/sync/index.d.ts.map +1 -0
  299. package/dist/src/sync/index.js +9 -0
  300. package/dist/src/sync/index.js.map +1 -0
  301. package/dist/src/sync/interfaces.d.ts +150 -0
  302. package/dist/src/sync/interfaces.d.ts.map +1 -0
  303. package/dist/src/sync/interfaces.js +2 -0
  304. package/dist/src/sync/interfaces.js.map +1 -0
  305. package/dist/src/sync/mailbox.d.ts +21 -0
  306. package/dist/src/sync/mailbox.d.ts.map +1 -0
  307. package/dist/src/sync/mailbox.js +59 -0
  308. package/dist/src/sync/mailbox.js.map +1 -0
  309. package/dist/src/sync/sync-builder.d.ts +17 -0
  310. package/dist/src/sync/sync-builder.d.ts.map +1 -0
  311. package/dist/src/sync/sync-builder.js +29 -0
  312. package/dist/src/sync/sync-builder.js.map +1 -0
  313. package/dist/src/sync/sync-manager.d.ts +33 -0
  314. package/dist/src/sync/sync-manager.d.ts.map +1 -0
  315. package/dist/src/sync/sync-manager.js +196 -0
  316. package/dist/src/sync/sync-manager.js.map +1 -0
  317. package/dist/src/sync/sync-operation.d.ts +28 -0
  318. package/dist/src/sync/sync-operation.d.ts.map +1 -0
  319. package/dist/src/sync/sync-operation.js +63 -0
  320. package/dist/src/sync/sync-operation.js.map +1 -0
  321. package/dist/src/sync/types.d.ts +61 -0
  322. package/dist/src/sync/types.d.ts.map +1 -0
  323. package/dist/src/sync/types.js +16 -0
  324. package/dist/src/sync/types.js.map +1 -0
  325. package/dist/src/sync/utils.d.ts +17 -0
  326. package/dist/src/sync/utils.d.ts.map +1 -0
  327. package/dist/src/sync/utils.js +34 -0
  328. package/dist/src/sync/utils.js.map +1 -0
  329. package/dist/src/utils/reshuffle.d.ts +30 -0
  330. package/dist/src/utils/reshuffle.d.ts.map +1 -0
  331. package/dist/src/utils/reshuffle.js +47 -0
  332. package/dist/src/utils/reshuffle.js.map +1 -0
  333. package/package.json +23 -7
  334. package/dist/bench/end-to-end-flow.bench.d.ts +0 -2
  335. package/dist/bench/end-to-end-flow.bench.d.ts.map +0 -1
  336. package/dist/bench/end-to-end-flow.bench.js +0 -256
  337. package/dist/bench/end-to-end-flow.bench.js.map +0 -1
  338. package/dist/bench/event-bus.bench.d.ts +0 -2
  339. package/dist/bench/event-bus.bench.d.ts.map +0 -1
  340. package/dist/bench/event-bus.bench.js +0 -238
  341. package/dist/bench/event-bus.bench.js.map +0 -1
  342. package/dist/bench/queue-only.bench.d.ts +0 -2
  343. package/dist/bench/queue-only.bench.d.ts.map +0 -1
  344. package/dist/bench/queue-only.bench.js +0 -40
  345. package/dist/bench/queue-only.bench.js.map +0 -1
  346. package/dist/bench/reactor-throughput.bench.d.ts +0 -2
  347. package/dist/bench/reactor-throughput.bench.d.ts.map +0 -1
  348. package/dist/bench/reactor-throughput.bench.js +0 -137
  349. package/dist/bench/reactor-throughput.bench.js.map +0 -1
  350. package/dist/src/executor/job-executor.d.ts +0 -62
  351. package/dist/src/executor/job-executor.d.ts.map +0 -1
  352. package/dist/src/executor/job-executor.js +0 -325
  353. package/dist/src/executor/job-executor.js.map +0 -1
  354. package/dist/test/event-bus.test.d.ts +0 -2
  355. package/dist/test/event-bus.test.d.ts.map +0 -1
  356. package/dist/test/event-bus.test.js +0 -532
  357. package/dist/test/event-bus.test.js.map +0 -1
  358. package/dist/test/job-executor.test.d.ts +0 -2
  359. package/dist/test/job-executor.test.d.ts.map +0 -1
  360. package/dist/test/job-executor.test.js +0 -581
  361. package/dist/test/job-executor.test.js.map +0 -1
  362. package/dist/test/queue.test.d.ts +0 -2
  363. package/dist/test/queue.test.d.ts.map +0 -1
  364. package/dist/test/queue.test.js +0 -396
  365. package/dist/test/queue.test.js.map +0 -1
  366. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,705 @@
1
+ import { driveCollectionId } from "../cache/operation-index-types.js";
2
+ import { OperationEventTypes } from "../events/types.js";
3
+ import { DocumentDeletedError } from "../shared/errors.js";
4
+ import { reshuffleByTimestampAndIndex } from "../utils/reshuffle.js";
5
+ import { applyDeleteDocumentAction, applyUpgradeDocumentAction, createDocumentFromAction, getNextIndexForScope, } from "./util.js";
6
+ const MAX_SKIP_THRESHOLD = 100;
7
+ /**
8
+ * Simple job executor that processes a job by applying actions through document model reducers.
9
+ *
10
+ * @see docs/planning/Storage/IOperationStore.md for storage schema
11
+ * @see docs/planning/Operations/index.md for operation structure
12
+ * @see docs/planning/Jobs/reshuffle.md for skip mechanism details
13
+ */
14
+ export class SimpleJobExecutor {
15
+ registry;
16
+ documentStorage;
17
+ operationStorage;
18
+ operationStore;
19
+ eventBus;
20
+ writeCache;
21
+ operationIndex;
22
+ config;
23
+ constructor(registry, documentStorage, operationStorage, operationStore, eventBus, writeCache, operationIndex, config) {
24
+ this.registry = registry;
25
+ this.documentStorage = documentStorage;
26
+ this.operationStorage = operationStorage;
27
+ this.operationStore = operationStore;
28
+ this.eventBus = eventBus;
29
+ this.writeCache = writeCache;
30
+ this.operationIndex = operationIndex;
31
+ this.config = {
32
+ maxConcurrency: config.maxConcurrency ?? 1,
33
+ jobTimeoutMs: config.jobTimeoutMs ?? 30000,
34
+ retryBaseDelayMs: config.retryBaseDelayMs ?? 100,
35
+ retryMaxDelayMs: config.retryMaxDelayMs ?? 5000,
36
+ legacyStorageEnabled: config.legacyStorageEnabled ?? true,
37
+ };
38
+ }
39
+ /**
40
+ * Execute a single job by applying all its actions through the appropriate reducers.
41
+ * Actions are processed sequentially in order.
42
+ */
43
+ async executeJob(job) {
44
+ const startTime = Date.now();
45
+ const indexTxn = this.operationIndex.start();
46
+ if (job.kind === "load") {
47
+ const result = await this.executeLoadJob(job, startTime, indexTxn);
48
+ if (result.success) {
49
+ await this.operationIndex.commit(indexTxn);
50
+ }
51
+ return result;
52
+ }
53
+ const result = await this.processActions(job, job.actions, startTime, indexTxn);
54
+ if (!result.success) {
55
+ return {
56
+ job,
57
+ success: false,
58
+ error: result.error,
59
+ duration: Date.now() - startTime,
60
+ };
61
+ }
62
+ await this.operationIndex.commit(indexTxn);
63
+ if (result.operationsWithContext.length > 0) {
64
+ this.eventBus
65
+ .emit(OperationEventTypes.OPERATION_WRITTEN, {
66
+ operations: result.operationsWithContext,
67
+ })
68
+ .catch(() => {
69
+ // TODO: Log error
70
+ });
71
+ }
72
+ return {
73
+ job,
74
+ success: true,
75
+ operations: result.generatedOperations,
76
+ operationsWithContext: result.operationsWithContext,
77
+ duration: Date.now() - startTime,
78
+ };
79
+ }
80
+ async processActions(job, actions, startTime, indexTxn, skipValues) {
81
+ const generatedOperations = [];
82
+ const operationsWithContext = [];
83
+ let actionIndex = 0;
84
+ for (const action of actions) {
85
+ if (action.type === "CREATE_DOCUMENT") {
86
+ const result = await this.executeCreateDocumentAction(job, action, startTime, indexTxn, skipValues?.[actionIndex]);
87
+ const error = this.accumulateResultOrReturnError(result, generatedOperations, operationsWithContext);
88
+ if (error !== null) {
89
+ return {
90
+ success: false,
91
+ generatedOperations,
92
+ operationsWithContext,
93
+ error: error.error,
94
+ };
95
+ }
96
+ actionIndex++;
97
+ continue;
98
+ }
99
+ if (action.type === "DELETE_DOCUMENT") {
100
+ const result = await this.executeDeleteDocumentAction(job, action, startTime, indexTxn);
101
+ const error = this.accumulateResultOrReturnError(result, generatedOperations, operationsWithContext);
102
+ if (error !== null) {
103
+ return {
104
+ success: false,
105
+ generatedOperations,
106
+ operationsWithContext,
107
+ error: error.error,
108
+ };
109
+ }
110
+ actionIndex++;
111
+ continue;
112
+ }
113
+ if (action.type === "UPGRADE_DOCUMENT") {
114
+ const result = await this.executeUpgradeDocumentAction(job, action, startTime, indexTxn, skipValues?.[actionIndex]);
115
+ const error = this.accumulateResultOrReturnError(result, generatedOperations, operationsWithContext);
116
+ if (error !== null) {
117
+ return {
118
+ success: false,
119
+ generatedOperations,
120
+ operationsWithContext,
121
+ error: error.error,
122
+ };
123
+ }
124
+ actionIndex++;
125
+ continue;
126
+ }
127
+ if (action.type === "ADD_RELATIONSHIP") {
128
+ const result = await this.executeAddRelationshipAction(job, action, startTime, indexTxn);
129
+ const error = this.accumulateResultOrReturnError(result, generatedOperations, operationsWithContext);
130
+ if (error !== null) {
131
+ return {
132
+ success: false,
133
+ generatedOperations,
134
+ operationsWithContext,
135
+ error: error.error,
136
+ };
137
+ }
138
+ actionIndex++;
139
+ continue;
140
+ }
141
+ if (action.type === "REMOVE_RELATIONSHIP") {
142
+ const result = await this.executeRemoveRelationshipAction(job, action, startTime, indexTxn);
143
+ const error = this.accumulateResultOrReturnError(result, generatedOperations, operationsWithContext);
144
+ if (error !== null) {
145
+ return {
146
+ success: false,
147
+ generatedOperations,
148
+ operationsWithContext,
149
+ error: error.error,
150
+ };
151
+ }
152
+ actionIndex++;
153
+ continue;
154
+ }
155
+ let document;
156
+ try {
157
+ document = await this.writeCache.getState(job.documentId, job.scope, job.branch);
158
+ }
159
+ catch (error) {
160
+ return {
161
+ success: false,
162
+ generatedOperations,
163
+ operationsWithContext,
164
+ error: error instanceof Error ? error : new Error(String(error)),
165
+ };
166
+ }
167
+ const documentState = document.state.document;
168
+ if (documentState.isDeleted) {
169
+ return {
170
+ success: false,
171
+ generatedOperations,
172
+ operationsWithContext,
173
+ error: new DocumentDeletedError(job.documentId, documentState.deletedAtUtcIso),
174
+ };
175
+ }
176
+ let module;
177
+ try {
178
+ module = this.registry.getModule(document.header.documentType);
179
+ }
180
+ catch (error) {
181
+ return {
182
+ success: false,
183
+ generatedOperations,
184
+ operationsWithContext,
185
+ error: error instanceof Error ? error : new Error(String(error)),
186
+ };
187
+ }
188
+ let updatedDocument;
189
+ try {
190
+ updatedDocument = module.reducer(document, action);
191
+ }
192
+ catch (error) {
193
+ const contextMessage = `Failed to apply action to document:\n Action type: ${action.type}\n Document ID: ${job.documentId}\n Document type: ${document.header.documentType}\n Scope: ${job.scope}\n Original error: ${error instanceof Error ? error.message : String(error)}`;
194
+ const enhancedError = new Error(contextMessage);
195
+ if (error instanceof Error && error.stack) {
196
+ enhancedError.stack = `${contextMessage}\n\nOriginal stack trace:\n${error.stack}`;
197
+ }
198
+ return {
199
+ success: false,
200
+ generatedOperations,
201
+ operationsWithContext,
202
+ error: enhancedError,
203
+ };
204
+ }
205
+ const scope = job.scope;
206
+ const operations = updatedDocument.operations[scope];
207
+ if (operations.length === 0) {
208
+ return {
209
+ success: false,
210
+ generatedOperations,
211
+ operationsWithContext,
212
+ error: new Error("No operation generated from action"),
213
+ };
214
+ }
215
+ const newOperation = operations[operations.length - 1];
216
+ if (skipValues && actionIndex < skipValues.length) {
217
+ newOperation.skip = skipValues[actionIndex];
218
+ }
219
+ generatedOperations.push(newOperation);
220
+ if (this.config.legacyStorageEnabled) {
221
+ try {
222
+ await this.operationStorage.addDocumentOperations(job.documentId, [newOperation], updatedDocument);
223
+ }
224
+ catch (error) {
225
+ return {
226
+ success: false,
227
+ generatedOperations,
228
+ operationsWithContext,
229
+ error: error instanceof Error ? error : new Error(String(error)),
230
+ };
231
+ }
232
+ }
233
+ const resultingState = JSON.stringify(updatedDocument.state);
234
+ try {
235
+ await this.operationStore.apply(job.documentId, document.header.documentType, scope, job.branch, newOperation.index, (txn) => {
236
+ txn.addOperations(newOperation);
237
+ });
238
+ }
239
+ catch (error) {
240
+ return {
241
+ success: false,
242
+ generatedOperations,
243
+ operationsWithContext,
244
+ error: new Error(`Failed to write operation to IOperationStore: ${error instanceof Error ? error.message : String(error)}`),
245
+ };
246
+ }
247
+ updatedDocument.header.revision = {
248
+ ...updatedDocument.header.revision,
249
+ [scope]: newOperation.index + 1,
250
+ };
251
+ this.writeCache.putState(job.documentId, scope, job.branch, newOperation.index, updatedDocument);
252
+ operationsWithContext.push({
253
+ operation: newOperation,
254
+ context: {
255
+ documentId: job.documentId,
256
+ scope,
257
+ branch: job.branch,
258
+ documentType: document.header.documentType,
259
+ resultingState,
260
+ },
261
+ });
262
+ actionIndex++;
263
+ }
264
+ return {
265
+ success: true,
266
+ generatedOperations,
267
+ operationsWithContext,
268
+ };
269
+ }
270
+ /**
271
+ * Execute a CREATE_DOCUMENT system action.
272
+ * This creates a new document in storage along with its initial operation.
273
+ * For a new document, the operation index is always 0.
274
+ */
275
+ async executeCreateDocumentAction(job, action, startTime, indexTxn, skip = 0) {
276
+ if (job.scope !== "document") {
277
+ return {
278
+ job,
279
+ success: false,
280
+ error: new Error(`CREATE_DOCUMENT must be in "document" scope, got "${job.scope}"`),
281
+ duration: Date.now() - startTime,
282
+ };
283
+ }
284
+ const document = createDocumentFromAction(action);
285
+ // Legacy: Store the document in storage
286
+ if (this.config.legacyStorageEnabled) {
287
+ try {
288
+ await this.documentStorage.create(document);
289
+ }
290
+ catch (error) {
291
+ return this.buildErrorResult(job, new Error(`Failed to create document in storage: ${error instanceof Error ? error.message : String(error)}`), startTime);
292
+ }
293
+ }
294
+ const operation = this.createOperation(action, 0, skip);
295
+ // Legacy: Write the CREATE_DOCUMENT operation to legacy storage
296
+ if (this.config.legacyStorageEnabled) {
297
+ try {
298
+ await this.operationStorage.addDocumentOperations(document.header.id, [operation], document);
299
+ }
300
+ catch (error) {
301
+ return this.buildErrorResult(job, new Error(`Failed to write CREATE_DOCUMENT operation to legacy storage: ${error instanceof Error ? error.message : String(error)}`), startTime);
302
+ }
303
+ }
304
+ // Compute resultingState for passing via context (not persisted)
305
+ // Include header and all scopes present in the document state (auth, document, etc.)
306
+ // but not global/local which aren't initialized by CREATE_DOCUMENT
307
+ const resultingStateObj = {
308
+ header: document.header,
309
+ ...document.state,
310
+ };
311
+ const resultingState = JSON.stringify(resultingStateObj);
312
+ const writeError = await this.writeOperationToStore(document.header.id, document.header.documentType, job.scope, job.branch, operation, job, startTime);
313
+ if (writeError !== null) {
314
+ return writeError;
315
+ }
316
+ this.updateDocumentRevision(document, job.scope, operation.index);
317
+ this.writeCacheState(document.header.id, job.scope, job.branch, operation.index, document);
318
+ indexTxn.write([
319
+ {
320
+ ...operation,
321
+ documentId: document.header.id,
322
+ documentType: document.header.documentType,
323
+ branch: job.branch,
324
+ scope: job.scope,
325
+ },
326
+ ]);
327
+ // collection membership has to be _after_ the write, as it requires the
328
+ // ordinal of the operation to be set
329
+ if (document.header.documentType === "powerhouse/document-drive") {
330
+ const collectionId = driveCollectionId(job.branch, document.header.id);
331
+ indexTxn.createCollection(collectionId);
332
+ indexTxn.addToCollection(collectionId, document.header.id);
333
+ }
334
+ return this.buildSuccessResult(job, operation, document.header.id, document.header.documentType, resultingState, startTime);
335
+ }
336
+ /**
337
+ * Execute a DELETE_DOCUMENT system action.
338
+ * This deletes a document from legacy storage and writes the operation to IOperationStore.
339
+ * The operation index is determined from the document's current operation count.
340
+ */
341
+ async executeDeleteDocumentAction(job, action, startTime, indexTxn) {
342
+ const input = action.input;
343
+ if (!input.documentId) {
344
+ return this.buildErrorResult(job, new Error("DELETE_DOCUMENT action requires a documentId in input"), startTime);
345
+ }
346
+ const documentId = input.documentId;
347
+ let document;
348
+ try {
349
+ document = await this.writeCache.getState(documentId, job.scope, job.branch);
350
+ }
351
+ catch (error) {
352
+ return this.buildErrorResult(job, new Error(`Failed to fetch document before deletion: ${error instanceof Error ? error.message : String(error)}`), startTime);
353
+ }
354
+ // Check if document is already deleted
355
+ const documentState = document.state.document;
356
+ if (documentState.isDeleted) {
357
+ return this.buildErrorResult(job, new DocumentDeletedError(documentId, documentState.deletedAtUtcIso), startTime);
358
+ }
359
+ const nextIndex = getNextIndexForScope(document, job.scope);
360
+ const operation = this.createOperation(action, nextIndex);
361
+ if (this.config.legacyStorageEnabled) {
362
+ try {
363
+ await this.documentStorage.delete(documentId);
364
+ }
365
+ catch (error) {
366
+ return this.buildErrorResult(job, new Error(`Failed to delete document from legacy storage: ${error instanceof Error ? error.message : String(error)}`), startTime);
367
+ }
368
+ }
369
+ // Mark the document as deleted in the state for read model indexing
370
+ applyDeleteDocumentAction(document, action);
371
+ // Compute resultingState for passing via context (not persisted)
372
+ // DELETE_DOCUMENT only affects header and document scopes
373
+ const resultingStateObj = {
374
+ header: document.header,
375
+ document: document.state.document,
376
+ };
377
+ const resultingState = JSON.stringify(resultingStateObj);
378
+ const writeError = await this.writeOperationToStore(documentId, document.header.documentType, job.scope, job.branch, operation, job, startTime);
379
+ if (writeError !== null) {
380
+ return writeError;
381
+ }
382
+ indexTxn.write([
383
+ {
384
+ ...operation,
385
+ documentId: documentId,
386
+ documentType: document.header.documentType,
387
+ branch: job.branch,
388
+ scope: job.scope,
389
+ },
390
+ ]);
391
+ return this.buildSuccessResult(job, operation, documentId, document.header.documentType, resultingState, startTime);
392
+ }
393
+ /**
394
+ * Execute an UPGRADE_DOCUMENT system action.
395
+ * This sets the document's initial state from the upgrade action.
396
+ * The operation index is determined from the document's current operation count.
397
+ */
398
+ async executeUpgradeDocumentAction(job, action, startTime, indexTxn, skip = 0) {
399
+ const input = action.input;
400
+ if (!input.documentId) {
401
+ return this.buildErrorResult(job, new Error("UPGRADE_DOCUMENT action requires a documentId in input"), startTime);
402
+ }
403
+ const documentId = input.documentId;
404
+ let document;
405
+ try {
406
+ document = await this.writeCache.getState(documentId, job.scope, job.branch);
407
+ }
408
+ catch (error) {
409
+ return this.buildErrorResult(job, new Error(`Failed to fetch document for upgrade: ${error instanceof Error ? error.message : String(error)}`), startTime);
410
+ }
411
+ const documentState = document.state.document;
412
+ if (documentState.isDeleted) {
413
+ return this.buildErrorResult(job, new DocumentDeletedError(documentId, documentState.deletedAtUtcIso), startTime);
414
+ }
415
+ const nextIndex = getNextIndexForScope(document, job.scope);
416
+ applyUpgradeDocumentAction(document, action);
417
+ const operation = this.createOperation(action, nextIndex, skip);
418
+ // Write the updated document to legacy storage
419
+ if (this.config.legacyStorageEnabled) {
420
+ try {
421
+ await this.operationStorage.addDocumentOperations(documentId, [operation], document);
422
+ }
423
+ catch (error) {
424
+ return this.buildErrorResult(job, new Error(`Failed to write UPGRADE_DOCUMENT operation to legacy storage: ${error instanceof Error ? error.message : String(error)}`), startTime);
425
+ }
426
+ }
427
+ // Compute resultingState for passing via context (not persisted)
428
+ const resultingStateObj = {
429
+ header: document.header,
430
+ ...document.state,
431
+ };
432
+ const resultingState = JSON.stringify(resultingStateObj);
433
+ const writeError = await this.writeOperationToStore(documentId, document.header.documentType, job.scope, job.branch, operation, job, startTime);
434
+ if (writeError !== null) {
435
+ return writeError;
436
+ }
437
+ this.updateDocumentRevision(document, job.scope, operation.index);
438
+ this.writeCacheState(documentId, job.scope, job.branch, operation.index, document);
439
+ indexTxn.write([
440
+ {
441
+ ...operation,
442
+ documentId: documentId,
443
+ documentType: document.header.documentType,
444
+ branch: job.branch,
445
+ scope: job.scope,
446
+ },
447
+ ]);
448
+ return this.buildSuccessResult(job, operation, documentId, document.header.documentType, resultingState, startTime);
449
+ }
450
+ async executeAddRelationshipAction(job, action, startTime, indexTxn) {
451
+ if (job.scope !== "document") {
452
+ return this.buildErrorResult(job, new Error(`ADD_RELATIONSHIP must be in "document" scope, got "${job.scope}"`), startTime);
453
+ }
454
+ const input = action.input;
455
+ if (!input.sourceId || !input.targetId || !input.relationshipType) {
456
+ return this.buildErrorResult(job, new Error("ADD_RELATIONSHIP action requires sourceId, targetId, and relationshipType in input"), startTime);
457
+ }
458
+ if (input.sourceId === input.targetId) {
459
+ return this.buildErrorResult(job, new Error("ADD_RELATIONSHIP: sourceId and targetId cannot be the same (self-relationships not allowed)"), startTime);
460
+ }
461
+ let sourceDoc;
462
+ try {
463
+ sourceDoc = await this.writeCache.getState(input.sourceId, "document", job.branch);
464
+ }
465
+ catch (error) {
466
+ return this.buildErrorResult(job, new Error(`ADD_RELATIONSHIP: source document ${input.sourceId} not found: ${error instanceof Error ? error.message : String(error)}`), startTime);
467
+ }
468
+ let targetDoc;
469
+ try {
470
+ targetDoc = await this.writeCache.getState(input.targetId, "document", job.branch);
471
+ }
472
+ catch (error) {
473
+ return this.buildErrorResult(job, new Error(`ADD_RELATIONSHIP: target document ${input.targetId} not found: ${error instanceof Error ? error.message : String(error)}`), startTime);
474
+ }
475
+ const targetDocState = targetDoc.state.document;
476
+ if (targetDocState.isDeleted) {
477
+ return this.buildErrorResult(job, new Error(`ADD_RELATIONSHIP: target document ${input.targetId} is deleted`), startTime);
478
+ }
479
+ const nextIndex = getNextIndexForScope(sourceDoc, job.scope);
480
+ const operation = this.createOperation(action, nextIndex);
481
+ const writeError = await this.writeOperationToStore(input.sourceId, sourceDoc.header.documentType, job.scope, job.branch, operation, job, startTime);
482
+ if (writeError !== null) {
483
+ return writeError;
484
+ }
485
+ sourceDoc.header.lastModifiedAtUtcIso =
486
+ operation.timestampUtcMs || new Date().toISOString();
487
+ this.updateDocumentRevision(sourceDoc, job.scope, operation.index);
488
+ sourceDoc.operations = {
489
+ ...sourceDoc.operations,
490
+ [job.scope]: [...(sourceDoc.operations[job.scope] ?? []), operation],
491
+ };
492
+ const scopeState = sourceDoc.state[job.scope];
493
+ const resultingStateObj = {
494
+ header: structuredClone(sourceDoc.header),
495
+ [job.scope]: scopeState === undefined ? {} : structuredClone(scopeState),
496
+ };
497
+ const resultingState = JSON.stringify(resultingStateObj);
498
+ this.writeCacheState(input.sourceId, job.scope, job.branch, operation.index, sourceDoc);
499
+ indexTxn.write([
500
+ {
501
+ ...operation,
502
+ documentId: input.sourceId,
503
+ documentType: sourceDoc.header.documentType,
504
+ branch: job.branch,
505
+ scope: job.scope,
506
+ },
507
+ ]);
508
+ // collection membership has to be _after_ the write, as it requires the
509
+ // ordinal of the operation to be set
510
+ if (sourceDoc.header.documentType === "powerhouse/document-drive") {
511
+ const collectionId = driveCollectionId(job.branch, input.sourceId);
512
+ indexTxn.addToCollection(collectionId, input.targetId);
513
+ }
514
+ return this.buildSuccessResult(job, operation, input.sourceId, sourceDoc.header.documentType, resultingState, startTime);
515
+ }
516
+ async executeRemoveRelationshipAction(job, action, startTime, indexTxn) {
517
+ if (job.scope !== "document") {
518
+ return this.buildErrorResult(job, new Error(`REMOVE_RELATIONSHIP must be in "document" scope, got "${job.scope}"`), startTime);
519
+ }
520
+ const input = action.input;
521
+ if (!input.sourceId || !input.targetId || !input.relationshipType) {
522
+ return this.buildErrorResult(job, new Error("REMOVE_RELATIONSHIP action requires sourceId, targetId, and relationshipType in input"), startTime);
523
+ }
524
+ let sourceDoc;
525
+ try {
526
+ sourceDoc = await this.writeCache.getState(input.sourceId, "document", job.branch);
527
+ }
528
+ catch (error) {
529
+ return this.buildErrorResult(job, new Error(`REMOVE_RELATIONSHIP: source document ${input.sourceId} not found: ${error instanceof Error ? error.message : String(error)}`), startTime);
530
+ }
531
+ const nextIndex = getNextIndexForScope(sourceDoc, job.scope);
532
+ const operation = this.createOperation(action, nextIndex);
533
+ const writeError = await this.writeOperationToStore(input.sourceId, sourceDoc.header.documentType, job.scope, job.branch, operation, job, startTime);
534
+ if (writeError !== null) {
535
+ return writeError;
536
+ }
537
+ sourceDoc.header.lastModifiedAtUtcIso =
538
+ operation.timestampUtcMs || new Date().toISOString();
539
+ this.updateDocumentRevision(sourceDoc, job.scope, operation.index);
540
+ sourceDoc.operations = {
541
+ ...sourceDoc.operations,
542
+ [job.scope]: [...(sourceDoc.operations[job.scope] ?? []), operation],
543
+ };
544
+ const scopeState = sourceDoc.state[job.scope];
545
+ const resultingStateObj = {
546
+ header: structuredClone(sourceDoc.header),
547
+ [job.scope]: scopeState === undefined ? {} : structuredClone(scopeState),
548
+ };
549
+ const resultingState = JSON.stringify(resultingStateObj);
550
+ this.writeCacheState(input.sourceId, job.scope, job.branch, operation.index, sourceDoc);
551
+ indexTxn.write([
552
+ {
553
+ ...operation,
554
+ documentId: input.sourceId,
555
+ documentType: sourceDoc.header.documentType,
556
+ branch: job.branch,
557
+ scope: job.scope,
558
+ },
559
+ ]);
560
+ // collection membership has to be _after_ the write, as it requires the
561
+ // ordinal of the operation to be set
562
+ if (sourceDoc.header.documentType === "powerhouse/document-drive") {
563
+ const collectionId = driveCollectionId(job.branch, input.sourceId);
564
+ indexTxn.removeFromCollection(collectionId, input.targetId);
565
+ }
566
+ return this.buildSuccessResult(job, operation, input.sourceId, sourceDoc.header.documentType, resultingState, startTime);
567
+ }
568
+ createOperation(action, index, skip = 0) {
569
+ return {
570
+ index: index,
571
+ timestampUtcMs: action.timestampUtcMs || new Date().toISOString(),
572
+ hash: "",
573
+ skip: skip,
574
+ action: action,
575
+ };
576
+ }
577
+ async executeLoadJob(job, startTime, indexTxn) {
578
+ if (job.operations.length === 0) {
579
+ return this.buildErrorResult(job, new Error("Load job must include at least one operation"), startTime);
580
+ }
581
+ const scope = job.scope;
582
+ let latestRevision = 0;
583
+ try {
584
+ const revisions = await this.operationStore.getRevisions(job.documentId, job.branch);
585
+ latestRevision = revisions.revision[scope] ?? 0;
586
+ }
587
+ catch {
588
+ latestRevision = 0;
589
+ }
590
+ const minIncomingIndex = job.operations.reduce((min, operation) => Math.min(min, operation.index), Number.POSITIVE_INFINITY);
591
+ const skipCount = minIncomingIndex === Number.POSITIVE_INFINITY
592
+ ? 0
593
+ : Math.max(0, latestRevision - minIncomingIndex);
594
+ if (skipCount > MAX_SKIP_THRESHOLD) {
595
+ return {
596
+ job,
597
+ success: false,
598
+ error: new Error(`Excessive reshuffle detected: skip count of ${skipCount} exceeds threshold of ${MAX_SKIP_THRESHOLD}. ` +
599
+ `This indicates an attempt to insert an operation at index ${minIncomingIndex} when the latest revision is ${latestRevision}.`),
600
+ duration: Date.now() - startTime,
601
+ };
602
+ }
603
+ const reshuffledOperations = reshuffleByTimestampAndIndex({
604
+ index: latestRevision,
605
+ skip: skipCount,
606
+ }, [], job.operations.map((operation) => ({
607
+ ...operation,
608
+ id: operation.id,
609
+ })));
610
+ const actions = reshuffledOperations.map((operation) => operation.action);
611
+ const skipValues = reshuffledOperations.map((operation) => operation.skip);
612
+ const result = await this.processActions(job, actions, startTime, indexTxn, skipValues);
613
+ if (!result.success) {
614
+ return {
615
+ job,
616
+ success: false,
617
+ error: result.error,
618
+ duration: Date.now() - startTime,
619
+ };
620
+ }
621
+ if (result.operationsWithContext.length > 0) {
622
+ this.eventBus
623
+ .emit(OperationEventTypes.OPERATION_WRITTEN, {
624
+ operations: result.operationsWithContext,
625
+ })
626
+ .catch(() => {
627
+ // TODO: log error channel once logging is wired
628
+ });
629
+ }
630
+ this.writeCache.invalidate(job.documentId, scope, job.branch);
631
+ return {
632
+ job,
633
+ success: true,
634
+ operations: result.generatedOperations,
635
+ operationsWithContext: result.operationsWithContext,
636
+ duration: Date.now() - startTime,
637
+ };
638
+ }
639
+ async writeOperationToStore(documentId, documentType, scope, branch, operation, job, startTime) {
640
+ try {
641
+ await this.operationStore.apply(documentId, documentType, scope, branch, operation.index, (txn) => {
642
+ txn.addOperations(operation);
643
+ });
644
+ return null;
645
+ }
646
+ catch (error) {
647
+ return {
648
+ job,
649
+ success: false,
650
+ error: new Error(`Failed to write operation to IOperationStore: ${error instanceof Error ? error.message : String(error)}`),
651
+ duration: Date.now() - startTime,
652
+ };
653
+ }
654
+ }
655
+ updateDocumentRevision(document, scope, operationIndex) {
656
+ document.header.revision = {
657
+ ...document.header.revision,
658
+ [scope]: operationIndex + 1,
659
+ };
660
+ }
661
+ writeCacheState(documentId, scope, branch, operationIndex, document) {
662
+ this.writeCache.putState(documentId, scope, branch, operationIndex, document);
663
+ }
664
+ buildSuccessResult(job, operation, documentId, documentType, resultingState, startTime) {
665
+ return {
666
+ job,
667
+ success: true,
668
+ operations: [operation],
669
+ operationsWithContext: [
670
+ {
671
+ operation,
672
+ context: {
673
+ documentId: documentId,
674
+ scope: job.scope,
675
+ branch: job.branch,
676
+ documentType: documentType,
677
+ resultingState,
678
+ },
679
+ },
680
+ ],
681
+ duration: Date.now() - startTime,
682
+ };
683
+ }
684
+ buildErrorResult(job, error, startTime) {
685
+ return {
686
+ job,
687
+ success: false,
688
+ error: error,
689
+ duration: Date.now() - startTime,
690
+ };
691
+ }
692
+ accumulateResultOrReturnError(result, generatedOperations, operationsWithContext) {
693
+ if (!result.success) {
694
+ return result;
695
+ }
696
+ if (result.operations && result.operations.length > 0) {
697
+ generatedOperations.push(...result.operations);
698
+ }
699
+ if (result.operationsWithContext) {
700
+ operationsWithContext.push(...result.operationsWithContext);
701
+ }
702
+ return null;
703
+ }
704
+ }
705
+ //# sourceMappingURL=simple-job-executor.js.map