@powerhousedao/reactor 4.1.0-dev.11 → 4.1.0-dev.110

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 (286) 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/kysely-write-cache.d.ts +134 -0
  6. package/dist/src/cache/kysely-write-cache.d.ts.map +1 -0
  7. package/dist/src/cache/kysely-write-cache.js +375 -0
  8. package/dist/src/cache/kysely-write-cache.js.map +1 -0
  9. package/dist/src/cache/lru/lru-tracker.d.ts +15 -0
  10. package/dist/src/cache/lru/lru-tracker.d.ts.map +1 -0
  11. package/dist/src/cache/lru/lru-tracker.js +96 -0
  12. package/dist/src/cache/lru/lru-tracker.js.map +1 -0
  13. package/dist/src/cache/types.d.ts +42 -0
  14. package/dist/src/cache/types.d.ts.map +1 -0
  15. package/dist/src/cache/types.js +2 -0
  16. package/dist/src/cache/types.js.map +1 -0
  17. package/dist/src/cache/write/interfaces.d.ts +83 -0
  18. package/dist/src/cache/write/interfaces.d.ts.map +1 -0
  19. package/dist/src/cache/write/interfaces.js +2 -0
  20. package/dist/src/cache/write/interfaces.js.map +1 -0
  21. package/dist/src/client/reactor-client.d.ts +103 -0
  22. package/dist/src/client/reactor-client.d.ts.map +1 -0
  23. package/dist/src/client/reactor-client.js +184 -0
  24. package/dist/src/client/reactor-client.js.map +1 -0
  25. package/dist/src/client/types.d.ts +213 -0
  26. package/dist/src/client/types.d.ts.map +1 -0
  27. package/dist/src/client/types.js +14 -0
  28. package/dist/src/client/types.js.map +1 -0
  29. package/dist/src/core/builder.d.ts +20 -0
  30. package/dist/src/core/builder.d.ts.map +1 -0
  31. package/dist/src/core/builder.js +47 -0
  32. package/dist/src/core/builder.js.map +1 -0
  33. package/dist/src/core/reactor-builder.d.ts +32 -0
  34. package/dist/src/core/reactor-builder.d.ts.map +1 -0
  35. package/dist/src/core/reactor-builder.js +120 -0
  36. package/dist/src/core/reactor-builder.js.map +1 -0
  37. package/dist/src/core/reactor.d.ts +107 -0
  38. package/dist/src/core/reactor.d.ts.map +1 -0
  39. package/dist/src/core/reactor.js +989 -0
  40. package/dist/src/core/reactor.js.map +1 -0
  41. package/dist/src/core/types.d.ts +178 -0
  42. package/dist/src/core/types.d.ts.map +1 -0
  43. package/dist/src/core/types.js +2 -0
  44. package/dist/src/core/types.js.map +1 -0
  45. package/dist/src/core/utils.d.ts +55 -0
  46. package/dist/src/core/utils.d.ts.map +1 -0
  47. package/dist/src/core/utils.js +150 -0
  48. package/dist/src/core/utils.js.map +1 -0
  49. package/dist/src/events/event-bus.d.ts +3 -3
  50. package/dist/src/events/event-bus.d.ts.map +1 -1
  51. package/dist/src/events/event-bus.js.map +1 -1
  52. package/dist/src/events/interfaces.d.ts +1 -1
  53. package/dist/src/events/interfaces.d.ts.map +1 -1
  54. package/dist/src/events/types.d.ts +15 -1
  55. package/dist/src/events/types.d.ts.map +1 -1
  56. package/dist/src/events/types.js +6 -0
  57. package/dist/src/events/types.js.map +1 -1
  58. package/dist/src/executor/interfaces.d.ts +31 -54
  59. package/dist/src/executor/interfaces.d.ts.map +1 -1
  60. package/dist/src/executor/simple-job-executor-manager.d.ts +32 -0
  61. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -0
  62. package/dist/src/executor/simple-job-executor-manager.js +214 -0
  63. package/dist/src/executor/simple-job-executor-manager.js.map +1 -0
  64. package/dist/src/executor/simple-job-executor.d.ts +60 -0
  65. package/dist/src/executor/simple-job-executor.d.ts.map +1 -0
  66. package/dist/src/executor/simple-job-executor.js +622 -0
  67. package/dist/src/executor/simple-job-executor.js.map +1 -0
  68. package/dist/src/executor/types.d.ts +32 -8
  69. package/dist/src/executor/types.d.ts.map +1 -1
  70. package/dist/src/executor/types.js.map +1 -1
  71. package/dist/src/executor/util.d.ts +65 -0
  72. package/dist/src/executor/util.d.ts.map +1 -0
  73. package/dist/src/executor/util.js +154 -0
  74. package/dist/src/executor/util.js.map +1 -0
  75. package/dist/src/index.d.ts +33 -3
  76. package/dist/src/index.d.ts.map +1 -1
  77. package/dist/src/index.js +40 -2
  78. package/dist/src/index.js.map +1 -1
  79. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +16 -0
  80. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -0
  81. package/dist/src/job-tracker/in-memory-job-tracker.js +84 -0
  82. package/dist/src/job-tracker/in-memory-job-tracker.js.map +1 -0
  83. package/dist/src/job-tracker/index.d.ts +3 -0
  84. package/dist/src/job-tracker/index.d.ts.map +1 -0
  85. package/dist/src/job-tracker/index.js +2 -0
  86. package/dist/src/job-tracker/index.js.map +1 -0
  87. package/dist/src/job-tracker/interfaces.d.ts +42 -0
  88. package/dist/src/job-tracker/interfaces.d.ts.map +1 -0
  89. package/dist/src/job-tracker/interfaces.js +2 -0
  90. package/dist/src/job-tracker/interfaces.js.map +1 -0
  91. package/dist/src/queue/interfaces.d.ts +46 -5
  92. package/dist/src/queue/interfaces.d.ts.map +1 -1
  93. package/dist/src/queue/job-execution-handle.d.ts +25 -0
  94. package/dist/src/queue/job-execution-handle.d.ts.map +1 -0
  95. package/dist/src/queue/job-execution-handle.js +62 -0
  96. package/dist/src/queue/job-execution-handle.js.map +1 -0
  97. package/dist/src/queue/queue.d.ts +56 -5
  98. package/dist/src/queue/queue.d.ts.map +1 -1
  99. package/dist/src/queue/queue.js +284 -36
  100. package/dist/src/queue/queue.js.map +1 -1
  101. package/dist/src/queue/types.d.ts +38 -5
  102. package/dist/src/queue/types.d.ts.map +1 -1
  103. package/dist/src/queue/types.js +12 -0
  104. package/dist/src/queue/types.js.map +1 -1
  105. package/dist/src/read-models/coordinator.d.ts +38 -0
  106. package/dist/src/read-models/coordinator.d.ts.map +1 -0
  107. package/dist/src/read-models/coordinator.js +62 -0
  108. package/dist/src/read-models/coordinator.js.map +1 -0
  109. package/dist/src/read-models/document-view.d.ts +24 -0
  110. package/dist/src/read-models/document-view.d.ts.map +1 -0
  111. package/dist/src/read-models/document-view.js +368 -0
  112. package/dist/src/read-models/document-view.js.map +1 -0
  113. package/dist/src/read-models/interfaces.d.ts +29 -0
  114. package/dist/src/read-models/interfaces.d.ts.map +1 -0
  115. package/dist/src/read-models/interfaces.js +2 -0
  116. package/dist/src/read-models/interfaces.js.map +1 -0
  117. package/dist/src/read-models/types.d.ts +46 -0
  118. package/dist/src/read-models/types.d.ts.map +1 -0
  119. package/dist/src/read-models/types.js +2 -0
  120. package/dist/src/read-models/types.js.map +1 -0
  121. package/dist/src/registry/implementation.d.ts +62 -0
  122. package/dist/src/registry/implementation.d.ts.map +1 -0
  123. package/dist/src/registry/implementation.js +96 -0
  124. package/dist/src/registry/implementation.js.map +1 -0
  125. package/dist/src/registry/index.d.ts +3 -0
  126. package/dist/src/registry/index.d.ts.map +1 -0
  127. package/dist/src/registry/index.js +2 -0
  128. package/dist/src/registry/index.js.map +1 -0
  129. package/dist/src/registry/interfaces.d.ts +39 -0
  130. package/dist/src/registry/interfaces.d.ts.map +1 -0
  131. package/dist/src/registry/interfaces.js +2 -0
  132. package/dist/src/registry/interfaces.js.map +1 -0
  133. package/dist/src/shared/awaiter.d.ts +32 -0
  134. package/dist/src/shared/awaiter.d.ts.map +1 -0
  135. package/dist/src/shared/awaiter.js +132 -0
  136. package/dist/src/shared/awaiter.js.map +1 -0
  137. package/dist/src/shared/consistency-tracker.d.ts +48 -0
  138. package/dist/src/shared/consistency-tracker.d.ts.map +1 -0
  139. package/dist/src/shared/consistency-tracker.js +123 -0
  140. package/dist/src/shared/consistency-tracker.js.map +1 -0
  141. package/dist/src/shared/errors.d.ts +17 -0
  142. package/dist/src/shared/errors.d.ts.map +1 -0
  143. package/dist/src/shared/errors.js +33 -0
  144. package/dist/src/shared/errors.js.map +1 -0
  145. package/dist/src/shared/factories.d.ts +16 -0
  146. package/dist/src/shared/factories.d.ts.map +1 -0
  147. package/dist/src/shared/factories.js +33 -0
  148. package/dist/src/shared/factories.js.map +1 -0
  149. package/dist/src/shared/types.d.ts +126 -20
  150. package/dist/src/shared/types.d.ts.map +1 -1
  151. package/dist/src/shared/types.js +35 -1
  152. package/dist/src/shared/types.js.map +1 -1
  153. package/dist/src/shared/utils.d.ts +3 -0
  154. package/dist/src/shared/utils.d.ts.map +1 -0
  155. package/dist/src/shared/utils.js +8 -0
  156. package/dist/src/shared/utils.js.map +1 -0
  157. package/dist/src/signer/passthrough-signer.d.ts +6 -0
  158. package/dist/src/signer/passthrough-signer.d.ts.map +1 -0
  159. package/dist/src/signer/passthrough-signer.js +6 -0
  160. package/dist/src/signer/passthrough-signer.js.map +1 -0
  161. package/dist/src/signer/types.d.ts +15 -0
  162. package/dist/src/signer/types.d.ts.map +1 -0
  163. package/dist/src/signer/types.js +2 -0
  164. package/dist/src/signer/types.js.map +1 -0
  165. package/dist/src/storage/interfaces.d.ts +267 -0
  166. package/dist/src/storage/interfaces.d.ts.map +1 -0
  167. package/dist/src/storage/interfaces.js +19 -0
  168. package/dist/src/storage/interfaces.js.map +1 -0
  169. package/dist/src/storage/kysely/document-indexer.d.ts +28 -0
  170. package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -0
  171. package/dist/src/storage/kysely/document-indexer.js +350 -0
  172. package/dist/src/storage/kysely/document-indexer.js.map +1 -0
  173. package/dist/src/storage/kysely/keyframe-store.d.ts +15 -0
  174. package/dist/src/storage/kysely/keyframe-store.d.ts.map +1 -0
  175. package/dist/src/storage/kysely/keyframe-store.js +64 -0
  176. package/dist/src/storage/kysely/keyframe-store.js.map +1 -0
  177. package/dist/src/storage/kysely/store.d.ts +15 -0
  178. package/dist/src/storage/kysely/store.d.ts.map +1 -0
  179. package/dist/src/storage/kysely/store.js +196 -0
  180. package/dist/src/storage/kysely/store.js.map +1 -0
  181. package/dist/src/storage/kysely/types.d.ts +72 -0
  182. package/dist/src/storage/kysely/types.d.ts.map +1 -0
  183. package/dist/src/storage/kysely/types.js +2 -0
  184. package/dist/src/storage/kysely/types.js.map +1 -0
  185. package/dist/src/storage/migrations/001_create_operation_table.d.ts +3 -0
  186. package/dist/src/storage/migrations/001_create_operation_table.d.ts.map +1 -0
  187. package/dist/src/storage/migrations/001_create_operation_table.js +40 -0
  188. package/dist/src/storage/migrations/001_create_operation_table.js.map +1 -0
  189. package/dist/src/storage/migrations/002_create_keyframe_table.d.ts +3 -0
  190. package/dist/src/storage/migrations/002_create_keyframe_table.d.ts.map +1 -0
  191. package/dist/src/storage/migrations/002_create_keyframe_table.js +27 -0
  192. package/dist/src/storage/migrations/002_create_keyframe_table.js.map +1 -0
  193. package/dist/src/storage/migrations/003_create_document_table.d.ts +3 -0
  194. package/dist/src/storage/migrations/003_create_document_table.d.ts.map +1 -0
  195. package/dist/src/storage/migrations/003_create_document_table.js +10 -0
  196. package/dist/src/storage/migrations/003_create_document_table.js.map +1 -0
  197. package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts +3 -0
  198. package/dist/src/storage/migrations/004_create_document_relationship_table.d.ts.map +1 -0
  199. package/dist/src/storage/migrations/004_create_document_relationship_table.js +35 -0
  200. package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +1 -0
  201. package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts +3 -0
  202. package/dist/src/storage/migrations/005_create_indexer_state_table.d.ts.map +1 -0
  203. package/dist/src/storage/migrations/005_create_indexer_state_table.js +10 -0
  204. package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +1 -0
  205. package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts +3 -0
  206. package/dist/src/storage/migrations/006_create_document_snapshot_table.d.ts.map +1 -0
  207. package/dist/src/storage/migrations/006_create_document_snapshot_table.js +49 -0
  208. package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +1 -0
  209. package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts +3 -0
  210. package/dist/src/storage/migrations/007_create_slug_mapping_table.d.ts.map +1 -0
  211. package/dist/src/storage/migrations/007_create_slug_mapping_table.js +24 -0
  212. package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +1 -0
  213. package/dist/src/storage/migrations/008_create_view_state_table.d.ts +3 -0
  214. package/dist/src/storage/migrations/008_create_view_state_table.d.ts.map +1 -0
  215. package/dist/src/storage/migrations/008_create_view_state_table.js +9 -0
  216. package/dist/src/storage/migrations/008_create_view_state_table.js.map +1 -0
  217. package/dist/src/storage/migrations/index.d.ts +3 -0
  218. package/dist/src/storage/migrations/index.d.ts.map +1 -0
  219. package/dist/src/storage/migrations/index.js +3 -0
  220. package/dist/src/storage/migrations/index.js.map +1 -0
  221. package/dist/src/storage/migrations/migrator.d.ts +5 -0
  222. package/dist/src/storage/migrations/migrator.d.ts.map +1 -0
  223. package/dist/src/storage/migrations/migrator.js +51 -0
  224. package/dist/src/storage/migrations/migrator.js.map +1 -0
  225. package/dist/src/storage/migrations/run-migrations.d.ts +2 -0
  226. package/dist/src/storage/migrations/run-migrations.d.ts.map +1 -0
  227. package/dist/src/storage/migrations/run-migrations.js +58 -0
  228. package/dist/src/storage/migrations/run-migrations.js.map +1 -0
  229. package/dist/src/storage/migrations/types.d.ts +9 -0
  230. package/dist/src/storage/migrations/types.d.ts.map +1 -0
  231. package/dist/src/storage/migrations/types.js +2 -0
  232. package/dist/src/storage/migrations/types.js.map +1 -0
  233. package/dist/src/storage/txn.d.ts +15 -0
  234. package/dist/src/storage/txn.d.ts.map +1 -0
  235. package/dist/src/storage/txn.js +43 -0
  236. package/dist/src/storage/txn.js.map +1 -0
  237. package/dist/src/subs/default-error-handler.d.ts +13 -0
  238. package/dist/src/subs/default-error-handler.d.ts.map +1 -0
  239. package/dist/src/subs/default-error-handler.js +27 -0
  240. package/dist/src/subs/default-error-handler.js.map +1 -0
  241. package/dist/src/subs/react-subscription-manager.d.ts +45 -0
  242. package/dist/src/subs/react-subscription-manager.d.ts.map +1 -0
  243. package/dist/src/subs/react-subscription-manager.js +185 -0
  244. package/dist/src/subs/react-subscription-manager.js.map +1 -0
  245. package/dist/src/subs/types.d.ts +64 -0
  246. package/dist/src/subs/types.d.ts.map +1 -0
  247. package/dist/src/subs/types.js +2 -0
  248. package/dist/src/subs/types.js.map +1 -0
  249. package/dist/src/utils/reshuffle.d.ts +30 -0
  250. package/dist/src/utils/reshuffle.d.ts.map +1 -0
  251. package/dist/src/utils/reshuffle.js +47 -0
  252. package/dist/src/utils/reshuffle.js.map +1 -0
  253. package/package.json +21 -7
  254. package/dist/bench/end-to-end-flow.bench.d.ts +0 -2
  255. package/dist/bench/end-to-end-flow.bench.d.ts.map +0 -1
  256. package/dist/bench/end-to-end-flow.bench.js +0 -256
  257. package/dist/bench/end-to-end-flow.bench.js.map +0 -1
  258. package/dist/bench/event-bus.bench.d.ts +0 -2
  259. package/dist/bench/event-bus.bench.d.ts.map +0 -1
  260. package/dist/bench/event-bus.bench.js +0 -238
  261. package/dist/bench/event-bus.bench.js.map +0 -1
  262. package/dist/bench/queue-only.bench.d.ts +0 -2
  263. package/dist/bench/queue-only.bench.d.ts.map +0 -1
  264. package/dist/bench/queue-only.bench.js +0 -40
  265. package/dist/bench/queue-only.bench.js.map +0 -1
  266. package/dist/bench/reactor-throughput.bench.d.ts +0 -2
  267. package/dist/bench/reactor-throughput.bench.d.ts.map +0 -1
  268. package/dist/bench/reactor-throughput.bench.js +0 -137
  269. package/dist/bench/reactor-throughput.bench.js.map +0 -1
  270. package/dist/src/executor/job-executor.d.ts +0 -62
  271. package/dist/src/executor/job-executor.d.ts.map +0 -1
  272. package/dist/src/executor/job-executor.js +0 -325
  273. package/dist/src/executor/job-executor.js.map +0 -1
  274. package/dist/test/event-bus.test.d.ts +0 -2
  275. package/dist/test/event-bus.test.d.ts.map +0 -1
  276. package/dist/test/event-bus.test.js +0 -532
  277. package/dist/test/event-bus.test.js.map +0 -1
  278. package/dist/test/job-executor.test.d.ts +0 -2
  279. package/dist/test/job-executor.test.d.ts.map +0 -1
  280. package/dist/test/job-executor.test.js +0 -581
  281. package/dist/test/job-executor.test.js.map +0 -1
  282. package/dist/test/queue.test.d.ts +0 -2
  283. package/dist/test/queue.test.d.ts.map +0 -1
  284. package/dist/test/queue.test.js +0 -396
  285. package/dist/test/queue.test.js.map +0 -1
  286. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,196 @@
1
+ import {} from "document-model";
2
+ import { DuplicateOperationError, RevisionMismatchError, } from "../interfaces.js";
3
+ import { AtomicTransaction } from "../txn.js";
4
+ export class KyselyOperationStore {
5
+ db;
6
+ constructor(db) {
7
+ this.db = db;
8
+ }
9
+ async apply(documentId, documentType, scope, branch, revision, fn, signal) {
10
+ await this.db.transaction().execute(async (trx) => {
11
+ // Check for abort signal
12
+ if (signal?.aborted) {
13
+ throw new Error("Operation aborted");
14
+ }
15
+ // Get the latest operation for this stream to verify revision
16
+ const latestOp = await trx
17
+ .selectFrom("Operation")
18
+ .selectAll()
19
+ .where("documentId", "=", documentId)
20
+ .where("scope", "=", scope)
21
+ .where("branch", "=", branch)
22
+ .orderBy("index", "desc")
23
+ .limit(1)
24
+ .executeTakeFirst();
25
+ // Check revision matches
26
+ const currentRevision = latestOp ? latestOp.index : -1;
27
+ if (currentRevision !== revision - 1) {
28
+ throw new RevisionMismatchError(revision - 1, currentRevision);
29
+ }
30
+ // Create atomic transaction
31
+ const atomicTxn = new AtomicTransaction(documentId, documentType, scope, branch, revision);
32
+ await fn(atomicTxn);
33
+ // Get operations and header updates
34
+ const operations = atomicTxn.getOperations();
35
+ // Insert operations
36
+ if (operations.length > 0) {
37
+ // Set prevOpId for each operation
38
+ let prevOpId = latestOp?.opId || "";
39
+ for (const op of operations) {
40
+ op.prevOpId = prevOpId;
41
+ prevOpId = op.opId;
42
+ }
43
+ try {
44
+ await trx.insertInto("Operation").values(operations).execute();
45
+ }
46
+ catch (error) {
47
+ if (error instanceof Error) {
48
+ if (error.message.includes("unique constraint")) {
49
+ // Extract the opId from the error if possible
50
+ const opId = operations[0]?.opId || "unknown";
51
+ throw new DuplicateOperationError(opId);
52
+ }
53
+ throw error;
54
+ }
55
+ throw error;
56
+ }
57
+ }
58
+ });
59
+ }
60
+ async getSince(documentId, scope, branch, revision, paging, signal) {
61
+ if (signal?.aborted) {
62
+ throw new Error("Operation aborted");
63
+ }
64
+ let query = this.db
65
+ .selectFrom("Operation")
66
+ .selectAll()
67
+ .where("documentId", "=", documentId)
68
+ .where("scope", "=", scope)
69
+ .where("branch", "=", branch)
70
+ .where("index", ">", revision)
71
+ .orderBy("index", "asc");
72
+ // Handle cursor-based pagination
73
+ if (paging) {
74
+ // Cursor encodes the last seen index
75
+ if (paging.cursor) {
76
+ const lastIndex = Number.parseInt(paging.cursor, 10);
77
+ query = query.where("index", ">", lastIndex);
78
+ }
79
+ // Apply limit if specified (fetch one extra to determine hasMore)
80
+ if (paging.limit) {
81
+ query = query.limit(paging.limit + 1);
82
+ }
83
+ }
84
+ const rows = await query.execute();
85
+ // Determine if there are more results
86
+ let hasMore = false;
87
+ let items = rows;
88
+ if (paging?.limit && rows.length > paging.limit) {
89
+ hasMore = true;
90
+ items = rows.slice(0, paging.limit);
91
+ }
92
+ // Generate next cursor from last item's index
93
+ const nextCursor = hasMore && items.length > 0
94
+ ? items[items.length - 1].index.toString()
95
+ : undefined;
96
+ return {
97
+ items: items.map((row) => this.rowToOperation(row)),
98
+ nextCursor,
99
+ hasMore,
100
+ };
101
+ }
102
+ async getSinceId(id, paging, signal) {
103
+ if (signal?.aborted) {
104
+ throw new Error("Operation aborted");
105
+ }
106
+ let query = this.db
107
+ .selectFrom("Operation")
108
+ .selectAll()
109
+ .where("id", ">", id)
110
+ .orderBy("id", "asc");
111
+ // Handle cursor-based pagination
112
+ if (paging) {
113
+ // Cursor encodes the last seen id
114
+ if (paging.cursor) {
115
+ const lastId = Number.parseInt(paging.cursor, 10);
116
+ query = query.where("id", ">", lastId);
117
+ }
118
+ // Apply limit if specified (fetch one extra to determine hasMore)
119
+ if (paging.limit) {
120
+ query = query.limit(paging.limit + 1);
121
+ }
122
+ }
123
+ const rows = await query.execute();
124
+ // Determine if there are more results
125
+ let hasMore = false;
126
+ let items = rows;
127
+ if (paging?.limit && rows.length > paging.limit) {
128
+ hasMore = true;
129
+ items = rows.slice(0, paging.limit);
130
+ }
131
+ // Generate next cursor from last item's id
132
+ const nextCursor = hasMore && items.length > 0
133
+ ? items[items.length - 1].id.toString()
134
+ : undefined;
135
+ return {
136
+ items: items.map((row) => this.rowToOperationWithContext(row)),
137
+ nextCursor,
138
+ hasMore,
139
+ };
140
+ }
141
+ async getRevisions(documentId, branch, signal) {
142
+ if (signal?.aborted) {
143
+ throw new Error("Operation aborted");
144
+ }
145
+ // Get the latest operation for each scope in a single query
146
+ // Uses a subquery to find operations where the index equals the max index for that scope
147
+ const scopeRevisions = await this.db
148
+ .selectFrom("Operation as o1")
149
+ .select(["o1.scope", "o1.index", "o1.timestampUtcMs"])
150
+ .where("o1.documentId", "=", documentId)
151
+ .where("o1.branch", "=", branch)
152
+ .where((eb) => eb("o1.index", "=", eb
153
+ .selectFrom("Operation as o2")
154
+ .select((eb2) => eb2.fn.max("o2.index").as("maxIndex"))
155
+ .where("o2.documentId", "=", eb.ref("o1.documentId"))
156
+ .where("o2.branch", "=", eb.ref("o1.branch"))
157
+ .where("o2.scope", "=", eb.ref("o1.scope"))))
158
+ .execute();
159
+ const revision = {};
160
+ let latestTimestamp = new Date(0).toISOString();
161
+ for (const row of scopeRevisions) {
162
+ revision[row.scope] = row.index + 1;
163
+ const timestamp = row.timestampUtcMs.toISOString();
164
+ if (timestamp > latestTimestamp) {
165
+ latestTimestamp = timestamp;
166
+ }
167
+ }
168
+ return {
169
+ revision,
170
+ latestTimestamp,
171
+ };
172
+ }
173
+ rowToOperation(row) {
174
+ return {
175
+ index: row.index,
176
+ timestampUtcMs: row.timestampUtcMs.toISOString(),
177
+ hash: row.hash,
178
+ skip: row.skip,
179
+ error: row.error || undefined,
180
+ id: row.opId,
181
+ action: row.action,
182
+ };
183
+ }
184
+ rowToOperationWithContext(row) {
185
+ return {
186
+ operation: this.rowToOperation(row),
187
+ context: {
188
+ documentId: row.documentId,
189
+ documentType: row.documentType,
190
+ scope: row.scope,
191
+ branch: row.branch,
192
+ },
193
+ };
194
+ }
195
+ }
196
+ //# sourceMappingURL=store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../src/storage/kysely/store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ import type { Generated, Insertable, Selectable, Updateable } from "kysely";
2
+ export interface OperationTable {
3
+ id: Generated<number>;
4
+ jobId: string;
5
+ opId: string;
6
+ prevOpId: string;
7
+ writeTimestampUtcMs: Generated<Date>;
8
+ documentId: string;
9
+ documentType: string;
10
+ scope: string;
11
+ branch: string;
12
+ timestampUtcMs: Date;
13
+ index: number;
14
+ action: unknown;
15
+ skip: number;
16
+ error?: string | null;
17
+ hash: string;
18
+ }
19
+ export interface KeyframeTable {
20
+ id: Generated<number>;
21
+ documentId: string;
22
+ documentType: string;
23
+ scope: string;
24
+ branch: string;
25
+ revision: number;
26
+ document: unknown;
27
+ createdAt: Generated<Date>;
28
+ }
29
+ export interface Database {
30
+ Operation: OperationTable;
31
+ Keyframe: KeyframeTable;
32
+ }
33
+ export type OperationRow = Selectable<OperationTable>;
34
+ export type InsertableOperation = Insertable<OperationTable>;
35
+ export type UpdateableOperation = Updateable<OperationTable>;
36
+ export type KeyframeRow = Selectable<KeyframeTable>;
37
+ export type InsertableKeyframe = Insertable<KeyframeTable>;
38
+ export type UpdateableKeyframe = Updateable<KeyframeTable>;
39
+ export interface DocumentTable {
40
+ id: string;
41
+ createdAt: Generated<Date>;
42
+ updatedAt: Generated<Date>;
43
+ }
44
+ export interface DocumentRelationshipTable {
45
+ id: Generated<string>;
46
+ sourceId: string;
47
+ targetId: string;
48
+ relationshipType: string;
49
+ metadata: unknown;
50
+ createdAt: Generated<Date>;
51
+ updatedAt: Generated<Date>;
52
+ }
53
+ export interface IndexerStateTable {
54
+ id: Generated<number>;
55
+ lastOperationId: number;
56
+ lastOperationTimestamp: Generated<Date>;
57
+ }
58
+ export interface DocumentIndexerDatabase {
59
+ Document: DocumentTable;
60
+ DocumentRelationship: DocumentRelationshipTable;
61
+ IndexerState: IndexerStateTable;
62
+ }
63
+ export type DocumentRow = Selectable<DocumentTable>;
64
+ export type InsertableDocument = Insertable<DocumentTable>;
65
+ export type UpdateableDocument = Updateable<DocumentTable>;
66
+ export type DocumentRelationshipRow = Selectable<DocumentRelationshipTable>;
67
+ export type InsertableDocumentRelationship = Insertable<DocumentRelationshipTable>;
68
+ export type UpdateableDocumentRelationship = Updateable<DocumentRelationshipTable>;
69
+ export type IndexerStateRow = Selectable<IndexerStateTable>;
70
+ export type InsertableIndexerState = Insertable<IndexerStateTable>;
71
+ export type UpdateableIndexerState = Updateable<IndexerStateTable>;
72
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/storage/kysely/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/storage/kysely/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ import type { Kysely } from "kysely";
2
+ export declare function up(db: Kysely<any>): Promise<void>;
3
+ //# sourceMappingURL=001_create_operation_table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"001_create_operation_table.d.ts","sourceRoot":"","sources":["../../../../src/storage/migrations/001_create_operation_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,CAyCvD"}
@@ -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"}