@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,40 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("Operation")
5
+ .addColumn("id", "serial", (col) => col.primaryKey())
6
+ .addColumn("jobId", "text", (col) => col.notNull())
7
+ .addColumn("opId", "text", (col) => col.notNull().unique())
8
+ .addColumn("prevOpId", "text", (col) => col.notNull())
9
+ .addColumn("writeTimestampUtcMs", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
10
+ .addColumn("documentId", "text", (col) => col.notNull())
11
+ .addColumn("documentType", "text", (col) => col.notNull())
12
+ .addColumn("scope", "text", (col) => col.notNull())
13
+ .addColumn("branch", "text", (col) => col.notNull())
14
+ .addColumn("timestampUtcMs", "timestamptz", (col) => col.notNull())
15
+ .addColumn("index", "integer", (col) => col.notNull())
16
+ .addColumn("action", "jsonb", (col) => col.notNull())
17
+ .addColumn("skip", "integer", (col) => col.notNull())
18
+ .addColumn("error", "text")
19
+ .addColumn("hash", "text", (col) => col.notNull())
20
+ .addUniqueConstraint("unique_revision", [
21
+ "documentId",
22
+ "scope",
23
+ "branch",
24
+ "index",
25
+ ])
26
+ .execute();
27
+ // Create index for streaming operations
28
+ await db.schema
29
+ .createIndex("streamOperations")
30
+ .on("Operation")
31
+ .columns(["documentId", "scope", "branch", "id"])
32
+ .execute();
33
+ // Create index for branchless streaming operations
34
+ await db.schema
35
+ .createIndex("branchlessStreamOperations")
36
+ .on("Operation")
37
+ .columns(["documentId", "scope", "id"])
38
+ .execute();
39
+ }
40
+ //# sourceMappingURL=001_create_operation_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"001_create_operation_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/001_create_operation_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,WAAW,CAAC;SACxB,SAAS,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SACpD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAClD,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC;SAC1D,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACrD,SAAS,CAAC,qBAAqB,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CACvD,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACvD,SAAS,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACzD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAClD,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACnD,SAAS,CAAC,gBAAgB,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAClE,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACrD,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACpD,SAAS,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACpD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;SAC1B,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACjD,mBAAmB,CAAC,iBAAiB,EAAE;QACtC,YAAY;QACZ,OAAO;QACP,QAAQ;QACR,OAAO;KACR,CAAC;SACD,OAAO,EAAE,CAAC;IAEb,wCAAwC;IACxC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,kBAAkB,CAAC;SAC/B,EAAE,CAAC,WAAW,CAAC;SACf,OAAO,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;SAChD,OAAO,EAAE,CAAC;IAEb,mDAAmD;IACnD,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,4BAA4B,CAAC;SACzC,EAAE,CAAC,WAAW,CAAC;SACf,OAAO,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;SACtC,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=002_create_keyframe_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"002_create_keyframe_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/002_create_keyframe_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BvD"}
@@ -0,0 +1,27 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("Keyframe")
5
+ .addColumn("id", "serial", (col) => col.primaryKey())
6
+ .addColumn("documentId", "text", (col) => col.notNull())
7
+ .addColumn("documentType", "text", (col) => col.notNull())
8
+ .addColumn("scope", "text", (col) => col.notNull())
9
+ .addColumn("branch", "text", (col) => col.notNull())
10
+ .addColumn("revision", "integer", (col) => col.notNull())
11
+ .addColumn("document", "jsonb", (col) => col.notNull())
12
+ .addColumn("createdAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
13
+ .addUniqueConstraint("unique_keyframe", [
14
+ "documentId",
15
+ "scope",
16
+ "branch",
17
+ "revision",
18
+ ])
19
+ .execute();
20
+ // Create index for keyframe lookup
21
+ await db.schema
22
+ .createIndex("keyframe_lookup")
23
+ .on("Keyframe")
24
+ .columns(["documentId", "scope", "branch", "revision"])
25
+ .execute();
26
+ }
27
+ //# sourceMappingURL=002_create_keyframe_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"002_create_keyframe_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/002_create_keyframe_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,UAAU,CAAC;SACvB,SAAS,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SACpD,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACvD,SAAS,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACzD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAClD,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACnD,SAAS,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACxD,SAAS,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACtD,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,mBAAmB,CAAC,iBAAiB,EAAE;QACtC,YAAY;QACZ,OAAO;QACP,QAAQ;QACR,UAAU;KACX,CAAC;SACD,OAAO,EAAE,CAAC;IAEb,mCAAmC;IACnC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,iBAAiB,CAAC;SAC9B,EAAE,CAAC,UAAU,CAAC;SACd,OAAO,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;SACtD,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=003_create_document_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"003_create_document_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/003_create_document_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAWvD"}
@@ -0,0 +1,10 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("Document")
5
+ .addColumn("id", "text", (col) => col.primaryKey())
6
+ .addColumn("createdAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
7
+ .addColumn("updatedAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
8
+ .execute();
9
+ }
10
+ //# sourceMappingURL=003_create_document_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"003_create_document_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/003_create_document_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,UAAU,CAAC;SACvB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SAClD,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=004_create_document_relationship_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"004_create_document_relationship_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/004_create_document_relationship_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CA2CvD"}
@@ -0,0 +1,35 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("DocumentRelationship")
5
+ .addColumn("id", "text", (col) => col.primaryKey())
6
+ .addColumn("sourceId", "text", (col) => col.notNull().references("Document.id").onDelete("cascade"))
7
+ .addColumn("targetId", "text", (col) => col.notNull().references("Document.id").onDelete("cascade"))
8
+ .addColumn("relationshipType", "text", (col) => col.notNull())
9
+ .addColumn("metadata", "jsonb")
10
+ .addColumn("createdAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
11
+ .addColumn("updatedAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
12
+ .addUniqueConstraint("unique_source_target_type", [
13
+ "sourceId",
14
+ "targetId",
15
+ "relationshipType",
16
+ ])
17
+ .execute();
18
+ // Create indexes for efficient graph traversal
19
+ await db.schema
20
+ .createIndex("idx_relationship_source")
21
+ .on("DocumentRelationship")
22
+ .column("sourceId")
23
+ .execute();
24
+ await db.schema
25
+ .createIndex("idx_relationship_target")
26
+ .on("DocumentRelationship")
27
+ .column("targetId")
28
+ .execute();
29
+ await db.schema
30
+ .createIndex("idx_relationship_type")
31
+ .on("DocumentRelationship")
32
+ .column("relationshipType")
33
+ .execute();
34
+ }
35
+ //# sourceMappingURL=004_create_document_relationship_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"004_create_document_relationship_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/004_create_document_relationship_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,sBAAsB,CAAC;SACnC,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SAClD,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CACrC,GAAG,CAAC,OAAO,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAC5D;SACA,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CACrC,GAAG,CAAC,OAAO,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAC5D;SACA,SAAS,CAAC,kBAAkB,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAC7D,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC;SAC9B,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,mBAAmB,CAAC,2BAA2B,EAAE;QAChD,UAAU;QACV,UAAU;QACV,kBAAkB;KACnB,CAAC;SACD,OAAO,EAAE,CAAC;IAEb,+CAA+C;IAC/C,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,yBAAyB,CAAC;SACtC,EAAE,CAAC,sBAAsB,CAAC;SAC1B,MAAM,CAAC,UAAU,CAAC;SAClB,OAAO,EAAE,CAAC;IAEb,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,yBAAyB,CAAC;SACtC,EAAE,CAAC,sBAAsB,CAAC;SAC1B,MAAM,CAAC,UAAU,CAAC;SAClB,OAAO,EAAE,CAAC;IAEb,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,uBAAuB,CAAC;SACpC,EAAE,CAAC,sBAAsB,CAAC;SAC1B,MAAM,CAAC,kBAAkB,CAAC;SAC1B,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=005_create_indexer_state_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"005_create_indexer_state_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/005_create_indexer_state_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAWvD"}
@@ -0,0 +1,10 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("IndexerState")
5
+ .addColumn("id", "integer", (col) => col.primaryKey().generatedAlwaysAsIdentity())
6
+ .addColumn("lastOperationId", "integer", (col) => col.notNull())
7
+ .addColumn("lastOperationTimestamp", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
8
+ .execute();
9
+ }
10
+ //# sourceMappingURL=005_create_indexer_state_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"005_create_indexer_state_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/005_create_indexer_state_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,cAAc,CAAC;SAC3B,SAAS,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAClC,GAAG,CAAC,UAAU,EAAE,CAAC,yBAAyB,EAAE,CAC7C;SACA,SAAS,CAAC,iBAAiB,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAC/D,SAAS,CAAC,wBAAwB,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC1D,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=006_create_document_snapshot_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"006_create_document_snapshot_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/006_create_document_snapshot_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAsDvD"}
@@ -0,0 +1,49 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("DocumentSnapshot")
5
+ .addColumn("id", "text", (col) => col.primaryKey())
6
+ .addColumn("documentId", "text", (col) => col.notNull())
7
+ .addColumn("slug", "text")
8
+ .addColumn("name", "text")
9
+ .addColumn("scope", "text", (col) => col.notNull())
10
+ .addColumn("branch", "text", (col) => col.notNull())
11
+ .addColumn("content", "jsonb", (col) => col.notNull())
12
+ .addColumn("documentType", "text", (col) => col.notNull())
13
+ .addColumn("lastOperationIndex", "integer", (col) => col.notNull())
14
+ .addColumn("lastOperationHash", "text", (col) => col.notNull())
15
+ .addColumn("lastUpdatedAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
16
+ .addColumn("snapshotVersion", "integer", (col) => col.notNull().defaultTo(1))
17
+ .addColumn("identifiers", "jsonb")
18
+ .addColumn("metadata", "jsonb")
19
+ .addColumn("isDeleted", "boolean", (col) => col.notNull().defaultTo(false))
20
+ .addColumn("deletedAt", "timestamptz")
21
+ .addUniqueConstraint("unique_doc_scope_branch", [
22
+ "documentId",
23
+ "scope",
24
+ "branch",
25
+ ])
26
+ .execute();
27
+ // Create indexes for query optimization
28
+ await db.schema
29
+ .createIndex("idx_slug_scope_branch")
30
+ .on("DocumentSnapshot")
31
+ .columns(["slug", "scope", "branch"])
32
+ .execute();
33
+ await db.schema
34
+ .createIndex("idx_doctype_scope_branch")
35
+ .on("DocumentSnapshot")
36
+ .columns(["documentType", "scope", "branch"])
37
+ .execute();
38
+ await db.schema
39
+ .createIndex("idx_last_updated")
40
+ .on("DocumentSnapshot")
41
+ .column("lastUpdatedAt")
42
+ .execute();
43
+ await db.schema
44
+ .createIndex("idx_is_deleted")
45
+ .on("DocumentSnapshot")
46
+ .column("isDeleted")
47
+ .execute();
48
+ }
49
+ //# sourceMappingURL=006_create_document_snapshot_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"006_create_document_snapshot_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/006_create_document_snapshot_table.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=007_create_slug_mapping_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"007_create_slug_mapping_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/007_create_slug_mapping_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CA0BvD"}
@@ -0,0 +1,24 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("SlugMapping")
5
+ .addColumn("slug", "text", (col) => col.primaryKey())
6
+ .addColumn("documentId", "text", (col) => col.notNull())
7
+ .addColumn("scope", "text", (col) => col.notNull())
8
+ .addColumn("branch", "text", (col) => col.notNull())
9
+ .addColumn("createdAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
10
+ .addColumn("updatedAt", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
11
+ .addUniqueConstraint("unique_docid_scope_branch", [
12
+ "documentId",
13
+ "scope",
14
+ "branch",
15
+ ])
16
+ .execute();
17
+ // Create index for reverse lookup (documentId -> slug)
18
+ await db.schema
19
+ .createIndex("idx_slug_documentid")
20
+ .on("SlugMapping")
21
+ .column("documentId")
22
+ .execute();
23
+ }
24
+ //# sourceMappingURL=007_create_slug_mapping_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"007_create_slug_mapping_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/007_create_slug_mapping_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,aAAa,CAAC;SAC1B,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SACpD,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACvD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAClD,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACnD,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,SAAS,CAAC,WAAW,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC7C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,mBAAmB,CAAC,2BAA2B,EAAE;QAChD,YAAY;QACZ,OAAO;QACP,QAAQ;KACT,CAAC;SACD,OAAO,EAAE,CAAC;IAEb,uDAAuD;IACvD,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,qBAAqB,CAAC;SAClC,EAAE,CAAC,aAAa,CAAC;SACjB,MAAM,CAAC,YAAY,CAAC;SACpB,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=008_create_view_state_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"008_create_view_state_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/008_create_view_state_table.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAQvD"}
@@ -0,0 +1,9 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("ViewState")
5
+ .addColumn("lastOperationId", "integer", (col) => col.primaryKey())
6
+ .addColumn("lastOperationTimestamp", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
7
+ .execute();
8
+ }
9
+ //# sourceMappingURL=008_create_view_state_table.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"008_create_view_state_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/008_create_view_state_table.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,WAAW,CAAC;SACxB,SAAS,CAAC,iBAAiB,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SAClE,SAAS,CAAC,wBAAwB,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC1D,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=009_create_operation_index_tables.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"009_create_operation_index_tables.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/009_create_operation_index_tables.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAsDvD"}
@@ -0,0 +1,50 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("document_collections")
5
+ .addColumn("documentId", "text", (col) => col.notNull())
6
+ .addColumn("collectionId", "text", (col) => col.notNull())
7
+ .addColumn("joinedOrdinal", "bigint", (col) => col.notNull().defaultTo(0))
8
+ .addColumn("leftOrdinal", "bigint")
9
+ .addPrimaryKeyConstraint("document_collections_pkey", [
10
+ "documentId",
11
+ "collectionId",
12
+ ])
13
+ .execute();
14
+ await db.schema
15
+ .createIndex("idx_document_collections_collectionId")
16
+ .on("document_collections")
17
+ .column("collectionId")
18
+ .execute();
19
+ await db.schema
20
+ .createIndex("idx_doc_collections_collection_range")
21
+ .on("document_collections")
22
+ .columns(["collectionId", "joinedOrdinal"])
23
+ .execute();
24
+ await db.schema
25
+ .createTable("operation_index_operations")
26
+ .addColumn("ordinal", "serial", (col) => col.primaryKey())
27
+ .addColumn("opId", "text", (col) => col.notNull())
28
+ .addColumn("documentId", "text", (col) => col.notNull())
29
+ .addColumn("documentType", "text", (col) => col.notNull())
30
+ .addColumn("scope", "text", (col) => col.notNull())
31
+ .addColumn("branch", "text", (col) => col.notNull())
32
+ .addColumn("timestampUtcMs", "bigint", (col) => col.notNull())
33
+ .addColumn("writeTimestampUtcMs", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
34
+ .addColumn("index", "integer", (col) => col.notNull())
35
+ .addColumn("skip", "integer", (col) => col.notNull())
36
+ .addColumn("hash", "text", (col) => col.notNull())
37
+ .addColumn("action", "jsonb", (col) => col.notNull())
38
+ .execute();
39
+ await db.schema
40
+ .createIndex("idx_operation_index_operations_document")
41
+ .on("operation_index_operations")
42
+ .columns(["documentId", "branch", "scope"])
43
+ .execute();
44
+ await db.schema
45
+ .createIndex("idx_operation_index_operations_ordinal")
46
+ .on("operation_index_operations")
47
+ .column("ordinal")
48
+ .execute();
49
+ }
50
+ //# sourceMappingURL=009_create_operation_index_tables.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"009_create_operation_index_tables.js","sourceRoot":"","sources":["../../../../src/storage/migrations/009_create_operation_index_tables.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=010_create_sync_tables.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"010_create_sync_tables.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/010_create_sync_tables.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAGrC,wBAAsB,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CA2DvD"}
@@ -0,0 +1,43 @@
1
+ import { sql } from "kysely";
2
+ export async function up(db) {
3
+ await db.schema
4
+ .createTable("sync_remotes")
5
+ .addColumn("name", "text", (col) => col.primaryKey())
6
+ .addColumn("collection_id", "text", (col) => col.notNull())
7
+ .addColumn("channel_type", "text", (col) => col.notNull())
8
+ .addColumn("channel_id", "text", (col) => col.notNull().defaultTo(""))
9
+ .addColumn("remote_name", "text", (col) => col.notNull().defaultTo(""))
10
+ .addColumn("channel_parameters", "jsonb", (col) => col.notNull().defaultTo(sql `'{}'::jsonb`))
11
+ .addColumn("filter_document_ids", "jsonb")
12
+ .addColumn("filter_scopes", "jsonb")
13
+ .addColumn("filter_branch", "text", (col) => col.notNull().defaultTo("main"))
14
+ .addColumn("push_state", "text", (col) => col.notNull().defaultTo("idle"))
15
+ .addColumn("push_last_success_utc_ms", "bigint")
16
+ .addColumn("push_last_failure_utc_ms", "bigint")
17
+ .addColumn("push_failure_count", "integer", (col) => col.notNull().defaultTo(0))
18
+ .addColumn("pull_state", "text", (col) => col.notNull().defaultTo("idle"))
19
+ .addColumn("pull_last_success_utc_ms", "bigint")
20
+ .addColumn("pull_last_failure_utc_ms", "bigint")
21
+ .addColumn("pull_failure_count", "integer", (col) => col.notNull().defaultTo(0))
22
+ .addColumn("created_at", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
23
+ .addColumn("updated_at", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
24
+ .execute();
25
+ await db.schema
26
+ .createIndex("idx_sync_remotes_collection")
27
+ .on("sync_remotes")
28
+ .column("collection_id")
29
+ .execute();
30
+ await db.schema
31
+ .createTable("sync_cursors")
32
+ .addColumn("remote_name", "text", (col) => col.primaryKey().references("sync_remotes.name").onDelete("cascade"))
33
+ .addColumn("cursor_ordinal", "bigint", (col) => col.notNull().defaultTo(0))
34
+ .addColumn("last_synced_at_utc_ms", "bigint")
35
+ .addColumn("updated_at", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
36
+ .execute();
37
+ await db.schema
38
+ .createIndex("idx_sync_cursors_ordinal")
39
+ .on("sync_cursors")
40
+ .column("cursor_ordinal")
41
+ .execute();
42
+ }
43
+ //# sourceMappingURL=010_create_sync_tables.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"010_create_sync_tables.js","sourceRoot":"","sources":["../../../../src/storage/migrations/010_create_sync_tables.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export * from "./types.js";
2
+ export * from "./migrator.js";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from "./types.js";
2
+ export * from "./migrator.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/storage/migrations/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Kysely } from "kysely";
2
+ import type { MigrationResult } from "./types.js";
3
+ export declare function runMigrations(db: Kysely<any>): Promise<MigrationResult>;
4
+ export declare function getMigrationStatus(db: Kysely<any>): Promise<readonly import("kysely").MigrationInfo[]>;
5
+ //# sourceMappingURL=migrator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/migrator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAqB,MAAM,EAAE,MAAM,QAAQ,CAAC;AACxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AA+BlD,wBAAsB,aAAa,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,eAAe,CAAC,CAwB7E;AAED,wBAAsB,kBAAkB,CAAC,EAAE,EAAE,MAAM,CAAC,GAAG,CAAC,sDAOvD"}
@@ -0,0 +1,55 @@
1
+ import { Migrator } from "kysely";
2
+ import * as migration001 from "./001_create_operation_table.js";
3
+ import * as migration002 from "./002_create_keyframe_table.js";
4
+ import * as migration003 from "./003_create_document_table.js";
5
+ import * as migration004 from "./004_create_document_relationship_table.js";
6
+ import * as migration005 from "./005_create_indexer_state_table.js";
7
+ import * as migration006 from "./006_create_document_snapshot_table.js";
8
+ import * as migration007 from "./007_create_slug_mapping_table.js";
9
+ import * as migration008 from "./008_create_view_state_table.js";
10
+ import * as migration009 from "./009_create_operation_index_tables.js";
11
+ import * as migration010 from "./010_create_sync_tables.js";
12
+ const migrations = {
13
+ "001_create_operation_table": migration001,
14
+ "002_create_keyframe_table": migration002,
15
+ "003_create_document_table": migration003,
16
+ "004_create_document_relationship_table": migration004,
17
+ "005_create_indexer_state_table": migration005,
18
+ "006_create_document_snapshot_table": migration006,
19
+ "007_create_slug_mapping_table": migration007,
20
+ "008_create_view_state_table": migration008,
21
+ "009_create_operation_index_tables": migration009,
22
+ "010_create_sync_tables": migration010,
23
+ };
24
+ class ProgrammaticMigrationProvider {
25
+ getMigrations() {
26
+ return Promise.resolve(migrations);
27
+ }
28
+ }
29
+ export async function runMigrations(db) {
30
+ const migrator = new Migrator({
31
+ db,
32
+ provider: new ProgrammaticMigrationProvider(),
33
+ });
34
+ const { error, results } = await migrator.migrateToLatest();
35
+ const migrationsExecuted = results?.map((result) => result.migrationName) ?? [];
36
+ if (error) {
37
+ return {
38
+ success: false,
39
+ migrationsExecuted,
40
+ error: error instanceof Error ? error : new Error("Unknown migration error"),
41
+ };
42
+ }
43
+ return {
44
+ success: true,
45
+ migrationsExecuted,
46
+ };
47
+ }
48
+ export async function getMigrationStatus(db) {
49
+ const migrator = new Migrator({
50
+ db,
51
+ provider: new ProgrammaticMigrationProvider(),
52
+ });
53
+ return await migrator.getMigrations();
54
+ }
55
+ //# sourceMappingURL=migrator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../../src/storage/migrations/migrator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAGlC,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,YAAY,MAAM,gCAAgC,CAAC;AAC/D,OAAO,KAAK,YAAY,MAAM,gCAAgC,CAAC;AAC/D,OAAO,KAAK,YAAY,MAAM,6CAA6C,CAAC;AAC5E,OAAO,KAAK,YAAY,MAAM,qCAAqC,CAAC;AACpE,OAAO,KAAK,YAAY,MAAM,yCAAyC,CAAC;AACxE,OAAO,KAAK,YAAY,MAAM,oCAAoC,CAAC;AACnE,OAAO,KAAK,YAAY,MAAM,kCAAkC,CAAC;AACjE,OAAO,KAAK,YAAY,MAAM,wCAAwC,CAAC;AACvE,OAAO,KAAK,YAAY,MAAM,6BAA6B,CAAC;AAE5D,MAAM,UAAU,GAAG;IACjB,4BAA4B,EAAE,YAAY;IAC1C,2BAA2B,EAAE,YAAY;IACzC,2BAA2B,EAAE,YAAY;IACzC,wCAAwC,EAAE,YAAY;IACtD,gCAAgC,EAAE,YAAY;IAC9C,oCAAoC,EAAE,YAAY;IAClD,+BAA+B,EAAE,YAAY;IAC7C,6BAA6B,EAAE,YAAY;IAC3C,mCAAmC,EAAE,YAAY;IACjD,wBAAwB,EAAE,YAAY;CACvC,CAAC;AAEF,MAAM,6BAA6B;IACjC,aAAa;QACX,OAAO,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;CACF;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,EAAe;IACjD,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;QAC5B,EAAE;QACF,QAAQ,EAAE,IAAI,6BAA6B,EAAE;KAC9C,CAAC,CAAC;IAEH,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,MAAM,QAAQ,CAAC,eAAe,EAAE,CAAC;IAE5D,MAAM,kBAAkB,GACtB,OAAO,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAEvD,IAAI,KAAK,EAAE,CAAC;QACV,OAAO;YACL,OAAO,EAAE,KAAK;YACd,kBAAkB;YAClB,KAAK,EACH,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,yBAAyB,CAAC;SACxE,CAAC;IACJ,CAAC;IAED,OAAO;QACL,OAAO,EAAE,IAAI;QACb,kBAAkB;KACnB,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,EAAe;IACtD,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;QAC5B,EAAE;QACF,QAAQ,EAAE,IAAI,6BAA6B,EAAE;KAC9C,CAAC,CAAC;IAEH,OAAO,MAAM,QAAQ,CAAC,aAAa,EAAE,CAAC;AACxC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=run-migrations.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run-migrations.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/run-migrations.ts"],"names":[],"mappings":""}
@@ -0,0 +1,58 @@
1
+ import { Kysely } from "kysely";
2
+ import { KyselyPGlite } from "kysely-pglite";
3
+ import { runMigrations, getMigrationStatus } from "./migrator.js";
4
+ async function main() {
5
+ const command = process.argv[2];
6
+ const kyselyPGlite = await KyselyPGlite.create();
7
+ const db = new Kysely({
8
+ dialect: kyselyPGlite.dialect,
9
+ });
10
+ try {
11
+ if (command === "up" || !command) {
12
+ console.log("Running migrations...");
13
+ const result = await runMigrations(db);
14
+ if (!result.success) {
15
+ console.error("Migration failed:", result.error?.message);
16
+ process.exit(1);
17
+ }
18
+ if (result.migrationsExecuted.length === 0) {
19
+ console.log("No migrations to run - database is up to date");
20
+ }
21
+ else {
22
+ console.log(`Successfully executed ${result.migrationsExecuted.length} migration(s):`);
23
+ for (const name of result.migrationsExecuted) {
24
+ console.log(` - ${name}`);
25
+ }
26
+ }
27
+ }
28
+ else if (command === "status") {
29
+ console.log("Checking migration status...");
30
+ const migrations = await getMigrationStatus(db);
31
+ console.log("\nMigration Status:");
32
+ console.log("=================");
33
+ for (const migration of migrations) {
34
+ const status = migration.executedAt
35
+ ? `✓ Executed at ${migration.executedAt.toISOString()}`
36
+ : "○ Pending";
37
+ console.log(`${status} - ${migration.name}`);
38
+ }
39
+ }
40
+ else {
41
+ console.error(`Unknown command: ${command}`);
42
+ console.log("\nUsage:");
43
+ console.log(" pnpm migrate - Run pending migrations");
44
+ console.log(" pnpm migrate up - Run pending migrations");
45
+ console.log(" pnpm migrate status - Show migration status");
46
+ process.exit(1);
47
+ }
48
+ }
49
+ catch (error) {
50
+ console.error("Error:", error instanceof Error ? error.message : String(error));
51
+ process.exit(1);
52
+ }
53
+ finally {
54
+ await db.destroy();
55
+ }
56
+ }
57
+ void main();
58
+ //# sourceMappingURL=run-migrations.js.map