@powerhousedao/reactor 6.0.0-dev.69 → 6.0.0-dev.77

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 (240) hide show
  1. package/dist/src/index.d.ts +1 -1
  2. package/dist/src/index.d.ts.map +1 -1
  3. package/dist/src/index.js +19998 -62
  4. package/dist/src/sync/index.d.ts +1 -1
  5. package/dist/src/sync/index.d.ts.map +1 -1
  6. package/dist/src/sync/sync-manager.d.ts.map +1 -1
  7. package/dist/src/sync/types.d.ts +11 -0
  8. package/dist/src/sync/types.d.ts.map +1 -1
  9. package/package.json +17 -10
  10. package/dist/src/actions/index.js +0 -76
  11. package/dist/src/actions/index.js.map +0 -1
  12. package/dist/src/cache/buffer/ring-buffer.js +0 -69
  13. package/dist/src/cache/buffer/ring-buffer.js.map +0 -1
  14. package/dist/src/cache/collection-membership-cache.js +0 -33
  15. package/dist/src/cache/collection-membership-cache.js.map +0 -1
  16. package/dist/src/cache/document-meta-cache-types.js +0 -2
  17. package/dist/src/cache/document-meta-cache-types.js.map +0 -1
  18. package/dist/src/cache/document-meta-cache.js +0 -129
  19. package/dist/src/cache/document-meta-cache.js.map +0 -1
  20. package/dist/src/cache/index.js +0 -2
  21. package/dist/src/cache/index.js.map +0 -1
  22. package/dist/src/cache/kysely-operation-index.js +0 -345
  23. package/dist/src/cache/kysely-operation-index.js.map +0 -1
  24. package/dist/src/cache/kysely-write-cache.js +0 -411
  25. package/dist/src/cache/kysely-write-cache.js.map +0 -1
  26. package/dist/src/cache/lru/lru-tracker.js +0 -96
  27. package/dist/src/cache/lru/lru-tracker.js.map +0 -1
  28. package/dist/src/cache/operation-index-types.js +0 -4
  29. package/dist/src/cache/operation-index-types.js.map +0 -1
  30. package/dist/src/cache/write/interfaces.js +0 -2
  31. package/dist/src/cache/write/interfaces.js.map +0 -1
  32. package/dist/src/cache/write-cache-types.js +0 -2
  33. package/dist/src/cache/write-cache-types.js.map +0 -1
  34. package/dist/src/client/reactor-client.js +0 -497
  35. package/dist/src/client/reactor-client.js.map +0 -1
  36. package/dist/src/client/types.js +0 -14
  37. package/dist/src/client/types.js.map +0 -1
  38. package/dist/src/core/reactor-builder.js +0 -306
  39. package/dist/src/core/reactor-builder.js.map +0 -1
  40. package/dist/src/core/reactor-client-builder.js +0 -132
  41. package/dist/src/core/reactor-client-builder.js.map +0 -1
  42. package/dist/src/core/reactor.js +0 -640
  43. package/dist/src/core/reactor.js.map +0 -1
  44. package/dist/src/core/types.js +0 -2
  45. package/dist/src/core/types.js.map +0 -1
  46. package/dist/src/core/utils.js +0 -225
  47. package/dist/src/core/utils.js.map +0 -1
  48. package/dist/src/events/event-bus.js +0 -53
  49. package/dist/src/events/event-bus.js.map +0 -1
  50. package/dist/src/events/interfaces.js +0 -2
  51. package/dist/src/events/interfaces.js.map +0 -1
  52. package/dist/src/events/types.js +0 -30
  53. package/dist/src/events/types.js.map +0 -1
  54. package/dist/src/executor/document-action-handler.js +0 -356
  55. package/dist/src/executor/document-action-handler.js.map +0 -1
  56. package/dist/src/executor/interfaces.js +0 -2
  57. package/dist/src/executor/interfaces.js.map +0 -1
  58. package/dist/src/executor/signature-verifier.js +0 -70
  59. package/dist/src/executor/signature-verifier.js.map +0 -1
  60. package/dist/src/executor/simple-job-executor-manager.js +0 -345
  61. package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
  62. package/dist/src/executor/simple-job-executor.js +0 -423
  63. package/dist/src/executor/simple-job-executor.js.map +0 -1
  64. package/dist/src/executor/types.js +0 -11
  65. package/dist/src/executor/types.js.map +0 -1
  66. package/dist/src/executor/util.js +0 -230
  67. package/dist/src/executor/util.js.map +0 -1
  68. package/dist/src/index.js.map +0 -1
  69. package/dist/src/job-tracker/in-memory-job-tracker.js +0 -114
  70. package/dist/src/job-tracker/in-memory-job-tracker.js.map +0 -1
  71. package/dist/src/job-tracker/index.js +0 -2
  72. package/dist/src/job-tracker/index.js.map +0 -1
  73. package/dist/src/job-tracker/interfaces.js +0 -2
  74. package/dist/src/job-tracker/interfaces.js.map +0 -1
  75. package/dist/src/logging/console.js +0 -2
  76. package/dist/src/logging/console.js.map +0 -1
  77. package/dist/src/logging/types.js +0 -2
  78. package/dist/src/logging/types.js.map +0 -1
  79. package/dist/src/processors/index.js +0 -2
  80. package/dist/src/processors/index.js.map +0 -1
  81. package/dist/src/processors/processor-manager.js +0 -165
  82. package/dist/src/processors/processor-manager.js.map +0 -1
  83. package/dist/src/processors/relational/types.js +0 -2
  84. package/dist/src/processors/relational/types.js.map +0 -1
  85. package/dist/src/processors/relational/utils.js +0 -2
  86. package/dist/src/processors/relational/utils.js.map +0 -1
  87. package/dist/src/processors/utils.js +0 -59
  88. package/dist/src/processors/utils.js.map +0 -1
  89. package/dist/src/queue/interfaces.js +0 -2
  90. package/dist/src/queue/interfaces.js.map +0 -1
  91. package/dist/src/queue/job-execution-handle.js +0 -71
  92. package/dist/src/queue/job-execution-handle.js.map +0 -1
  93. package/dist/src/queue/queue.js +0 -493
  94. package/dist/src/queue/queue.js.map +0 -1
  95. package/dist/src/queue/types.js +0 -19
  96. package/dist/src/queue/types.js.map +0 -1
  97. package/dist/src/read-models/base-read-model.js +0 -143
  98. package/dist/src/read-models/base-read-model.js.map +0 -1
  99. package/dist/src/read-models/coordinator.js +0 -72
  100. package/dist/src/read-models/coordinator.js.map +0 -1
  101. package/dist/src/read-models/document-view.js +0 -457
  102. package/dist/src/read-models/document-view.js.map +0 -1
  103. package/dist/src/read-models/interfaces.js +0 -2
  104. package/dist/src/read-models/interfaces.js.map +0 -1
  105. package/dist/src/read-models/types.js +0 -2
  106. package/dist/src/read-models/types.js.map +0 -1
  107. package/dist/src/registry/document-model-resolver.js +0 -81
  108. package/dist/src/registry/document-model-resolver.js.map +0 -1
  109. package/dist/src/registry/implementation.js +0 -226
  110. package/dist/src/registry/implementation.js.map +0 -1
  111. package/dist/src/registry/index.js +0 -3
  112. package/dist/src/registry/index.js.map +0 -1
  113. package/dist/src/registry/interfaces.js +0 -2
  114. package/dist/src/registry/interfaces.js.map +0 -1
  115. package/dist/src/shared/awaiter.js +0 -123
  116. package/dist/src/shared/awaiter.js.map +0 -1
  117. package/dist/src/shared/collect-all-pages.js +0 -17
  118. package/dist/src/shared/collect-all-pages.js.map +0 -1
  119. package/dist/src/shared/consistency-tracker.js +0 -123
  120. package/dist/src/shared/consistency-tracker.js.map +0 -1
  121. package/dist/src/shared/drive-url.js +0 -17
  122. package/dist/src/shared/drive-url.js.map +0 -1
  123. package/dist/src/shared/errors.js +0 -93
  124. package/dist/src/shared/errors.js.map +0 -1
  125. package/dist/src/shared/factories.js +0 -41
  126. package/dist/src/shared/factories.js.map +0 -1
  127. package/dist/src/shared/types.js +0 -38
  128. package/dist/src/shared/types.js.map +0 -1
  129. package/dist/src/shared/utils.js +0 -8
  130. package/dist/src/shared/utils.js.map +0 -1
  131. package/dist/src/signer/passthrough-signer.js +0 -17
  132. package/dist/src/signer/passthrough-signer.js.map +0 -1
  133. package/dist/src/signer/types.js +0 -2
  134. package/dist/src/signer/types.js.map +0 -1
  135. package/dist/src/storage/index.js +0 -3
  136. package/dist/src/storage/index.js.map +0 -1
  137. package/dist/src/storage/interfaces.js +0 -29
  138. package/dist/src/storage/interfaces.js.map +0 -1
  139. package/dist/src/storage/kysely/document-indexer.js +0 -421
  140. package/dist/src/storage/kysely/document-indexer.js.map +0 -1
  141. package/dist/src/storage/kysely/keyframe-store.js +0 -64
  142. package/dist/src/storage/kysely/keyframe-store.js.map +0 -1
  143. package/dist/src/storage/kysely/store.js +0 -264
  144. package/dist/src/storage/kysely/store.js.map +0 -1
  145. package/dist/src/storage/kysely/sync-cursor-storage.js +0 -97
  146. package/dist/src/storage/kysely/sync-cursor-storage.js.map +0 -1
  147. package/dist/src/storage/kysely/sync-dead-letter-storage.js +0 -110
  148. package/dist/src/storage/kysely/sync-dead-letter-storage.js.map +0 -1
  149. package/dist/src/storage/kysely/sync-remote-storage.js +0 -133
  150. package/dist/src/storage/kysely/sync-remote-storage.js.map +0 -1
  151. package/dist/src/storage/kysely/types.js +0 -2
  152. package/dist/src/storage/kysely/types.js.map +0 -1
  153. package/dist/src/storage/migrations/001_create_operation_table.js +0 -41
  154. package/dist/src/storage/migrations/001_create_operation_table.js.map +0 -1
  155. package/dist/src/storage/migrations/002_create_keyframe_table.js +0 -27
  156. package/dist/src/storage/migrations/002_create_keyframe_table.js.map +0 -1
  157. package/dist/src/storage/migrations/003_create_document_table.js +0 -10
  158. package/dist/src/storage/migrations/003_create_document_table.js.map +0 -1
  159. package/dist/src/storage/migrations/004_create_document_relationship_table.js +0 -35
  160. package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +0 -1
  161. package/dist/src/storage/migrations/005_create_indexer_state_table.js +0 -10
  162. package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +0 -1
  163. package/dist/src/storage/migrations/006_create_document_snapshot_table.js +0 -49
  164. package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +0 -1
  165. package/dist/src/storage/migrations/007_create_slug_mapping_table.js +0 -24
  166. package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +0 -1
  167. package/dist/src/storage/migrations/008_create_view_state_table.js +0 -10
  168. package/dist/src/storage/migrations/008_create_view_state_table.js.map +0 -1
  169. package/dist/src/storage/migrations/009_create_operation_index_tables.js +0 -50
  170. package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +0 -1
  171. package/dist/src/storage/migrations/010_create_sync_tables.js +0 -43
  172. package/dist/src/storage/migrations/010_create_sync_tables.js.map +0 -1
  173. package/dist/src/storage/migrations/011_add_cursor_type_column.js +0 -29
  174. package/dist/src/storage/migrations/011_add_cursor_type_column.js.map +0 -1
  175. package/dist/src/storage/migrations/012_add_source_remote_column.js +0 -7
  176. package/dist/src/storage/migrations/012_add_source_remote_column.js.map +0 -1
  177. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js +0 -24
  178. package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js.map +0 -1
  179. package/dist/src/storage/migrations/index.js +0 -3
  180. package/dist/src/storage/migrations/index.js.map +0 -1
  181. package/dist/src/storage/migrations/migrator.js +0 -84
  182. package/dist/src/storage/migrations/migrator.js.map +0 -1
  183. package/dist/src/storage/migrations/run-migrations.js +0 -58
  184. package/dist/src/storage/migrations/run-migrations.js.map +0 -1
  185. package/dist/src/storage/migrations/types.js +0 -2
  186. package/dist/src/storage/migrations/types.js.map +0 -1
  187. package/dist/src/storage/txn.js +0 -42
  188. package/dist/src/storage/txn.js.map +0 -1
  189. package/dist/src/subs/default-error-handler.js +0 -27
  190. package/dist/src/subs/default-error-handler.js.map +0 -1
  191. package/dist/src/subs/react-subscription-manager.js +0 -185
  192. package/dist/src/subs/react-subscription-manager.js.map +0 -1
  193. package/dist/src/subs/subscription-notification-read-model.js +0 -62
  194. package/dist/src/subs/subscription-notification-read-model.js.map +0 -1
  195. package/dist/src/subs/types.js +0 -2
  196. package/dist/src/subs/types.js.map +0 -1
  197. package/dist/src/sync/batch-aggregator.js +0 -94
  198. package/dist/src/sync/batch-aggregator.js.map +0 -1
  199. package/dist/src/sync/buffered-mailbox.js +0 -164
  200. package/dist/src/sync/buffered-mailbox.js.map +0 -1
  201. package/dist/src/sync/channels/gql-req-channel.js +0 -548
  202. package/dist/src/sync/channels/gql-req-channel.js.map +0 -1
  203. package/dist/src/sync/channels/gql-request-channel-factory.js +0 -105
  204. package/dist/src/sync/channels/gql-request-channel-factory.js.map +0 -1
  205. package/dist/src/sync/channels/gql-res-channel.js +0 -79
  206. package/dist/src/sync/channels/gql-res-channel.js.map +0 -1
  207. package/dist/src/sync/channels/gql-response-channel-factory.js +0 -14
  208. package/dist/src/sync/channels/gql-response-channel-factory.js.map +0 -1
  209. package/dist/src/sync/channels/index.js +0 -8
  210. package/dist/src/sync/channels/index.js.map +0 -1
  211. package/dist/src/sync/channels/interval-poll-timer.js +0 -123
  212. package/dist/src/sync/channels/interval-poll-timer.js.map +0 -1
  213. package/dist/src/sync/channels/poll-timer.js +0 -2
  214. package/dist/src/sync/channels/poll-timer.js.map +0 -1
  215. package/dist/src/sync/channels/utils.js +0 -161
  216. package/dist/src/sync/channels/utils.js.map +0 -1
  217. package/dist/src/sync/errors.js +0 -17
  218. package/dist/src/sync/errors.js.map +0 -1
  219. package/dist/src/sync/index.js +0 -11
  220. package/dist/src/sync/index.js.map +0 -1
  221. package/dist/src/sync/interfaces.js +0 -2
  222. package/dist/src/sync/interfaces.js.map +0 -1
  223. package/dist/src/sync/mailbox.js +0 -142
  224. package/dist/src/sync/mailbox.js.map +0 -1
  225. package/dist/src/sync/sync-awaiter.js +0 -124
  226. package/dist/src/sync/sync-awaiter.js.map +0 -1
  227. package/dist/src/sync/sync-builder.js +0 -52
  228. package/dist/src/sync/sync-builder.js.map +0 -1
  229. package/dist/src/sync/sync-manager.js +0 -447
  230. package/dist/src/sync/sync-manager.js.map +0 -1
  231. package/dist/src/sync/sync-operation.js +0 -70
  232. package/dist/src/sync/sync-operation.js.map +0 -1
  233. package/dist/src/sync/sync-status-tracker.js +0 -137
  234. package/dist/src/sync/sync-status-tracker.js.map +0 -1
  235. package/dist/src/sync/types.js +0 -31
  236. package/dist/src/sync/types.js.map +0 -1
  237. package/dist/src/sync/utils.js +0 -283
  238. package/dist/src/sync/utils.js.map +0 -1
  239. package/dist/src/utils/reshuffle.js +0 -91
  240. package/dist/src/utils/reshuffle.js.map +0 -1
@@ -1,41 +0,0 @@
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())
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
- .addUniqueConstraint("unique_operation_instance", ["opId", "index", "skip"])
27
- .execute();
28
- // Create index for streaming operations
29
- await db.schema
30
- .createIndex("streamOperations")
31
- .on("Operation")
32
- .columns(["documentId", "scope", "branch", "id"])
33
- .execute();
34
- // Create index for branchless streaming operations
35
- await db.schema
36
- .createIndex("branchlessStreamOperations")
37
- .on("Operation")
38
- .columns(["documentId", "scope", "id"])
39
- .execute();
40
- }
41
- //# sourceMappingURL=001_create_operation_table.js.map
@@ -1 +0,0 @@
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;SACjD,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,mBAAmB,CAAC,2BAA2B,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;SAC3E,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"}
@@ -1,27 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,10 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,35 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,10 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,49 +0,0 @@
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
@@ -1 +0,0 @@
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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"}
@@ -1,24 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,10 +0,0 @@
1
- import { sql } from "kysely";
2
- export async function up(db) {
3
- await db.schema
4
- .createTable("ViewState")
5
- .addColumn("readModelId", "text", (col) => col.primaryKey())
6
- .addColumn("lastOrdinal", "integer", (col) => col.notNull().defaultTo(0))
7
- .addColumn("lastOperationTimestamp", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
8
- .execute();
9
- }
10
- //# sourceMappingURL=008_create_view_state_table.js.map
@@ -1 +0,0 @@
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,EAAmB;IAC1C,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,WAAW,CAAC;SACxB,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SAC3D,SAAS,CAAC,aAAa,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;SACxE,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"}
@@ -1,50 +0,0 @@
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", "text", (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
@@ -1 +0,0 @@
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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"}
@@ -1,43 +0,0 @@
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", "text")
16
- .addColumn("push_last_failure_utc_ms", "text")
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", "text")
20
- .addColumn("pull_last_failure_utc_ms", "text")
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", "text")
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
@@ -1 +0,0 @@
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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"}
@@ -1,29 +0,0 @@
1
- import { sql } from "kysely";
2
- export async function up(db) {
3
- // Delete any leftover fake "outbox::" cursor rows and remote records
4
- await db
5
- .deleteFrom("sync_cursors")
6
- .where("remote_name", "like", "outbox::%")
7
- .execute();
8
- await db
9
- .deleteFrom("sync_remotes")
10
- .where("name", "like", "outbox::%")
11
- .execute();
12
- // Recreate sync_cursors with cursor_type column and composite PK (no FK)
13
- await db.schema.dropTable("sync_cursors").execute();
14
- await db.schema
15
- .createTable("sync_cursors")
16
- .addColumn("remote_name", "text", (col) => col.notNull())
17
- .addColumn("cursor_type", "text", (col) => col.notNull().defaultTo("inbox"))
18
- .addColumn("cursor_ordinal", "bigint", (col) => col.notNull().defaultTo(0))
19
- .addColumn("last_synced_at_utc_ms", "text")
20
- .addColumn("updated_at", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
21
- .addPrimaryKeyConstraint("sync_cursors_pk", ["remote_name", "cursor_type"])
22
- .execute();
23
- await db.schema
24
- .createIndex("idx_sync_cursors_ordinal")
25
- .on("sync_cursors")
26
- .column("cursor_ordinal")
27
- .execute();
28
- }
29
- //# sourceMappingURL=011_add_cursor_type_column.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"011_add_cursor_type_column.js","sourceRoot":"","sources":["../../../../src/storage/migrations/011_add_cursor_type_column.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAE7B,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,qEAAqE;IACrE,MAAM,EAAE;SACL,UAAU,CAAC,cAAc,CAAC;SAC1B,KAAK,CAAC,aAAa,EAAE,MAAM,EAAE,WAAW,CAAC;SACzC,OAAO,EAAE,CAAC;IACb,MAAM,EAAE;SACL,UAAU,CAAC,cAAc,CAAC;SAC1B,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC;SAClC,OAAO,EAAE,CAAC;IAEb,yEAAyE;IACzE,MAAM,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,OAAO,EAAE,CAAC;IAEpD,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,cAAc,CAAC;SAC3B,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACxD,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;SAC3E,SAAS,CAAC,gBAAgB,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;SAC1E,SAAS,CAAC,uBAAuB,EAAE,MAAM,CAAC;SAC1C,SAAS,CAAC,YAAY,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC9C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,uBAAuB,CAAC,iBAAiB,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;SAC1E,OAAO,EAAE,CAAC;IAEb,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,0BAA0B,CAAC;SACvC,EAAE,CAAC,cAAc,CAAC;SAClB,MAAM,CAAC,gBAAgB,CAAC;SACxB,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -1,7 +0,0 @@
1
- export async function up(db) {
2
- await db.schema
3
- .alterTable("operation_index_operations")
4
- .addColumn("sourceRemote", "text", (col) => col.notNull().defaultTo(""))
5
- .execute();
6
- }
7
- //# sourceMappingURL=012_add_source_remote_column.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"012_add_source_remote_column.js","sourceRoot":"","sources":["../../../../src/storage/migrations/012_add_source_remote_column.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,EAAE,CAAC,EAAe;IACtC,MAAM,EAAE,CAAC,MAAM;SACZ,UAAU,CAAC,4BAA4B,CAAC;SACxC,SAAS,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;SACvE,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -1,24 +0,0 @@
1
- import { sql } from "kysely";
2
- export async function up(db) {
3
- await db.schema
4
- .createTable("sync_dead_letters")
5
- .addColumn("ordinal", "serial", (col) => col.primaryKey())
6
- .addColumn("id", "text", (col) => col.unique().notNull())
7
- .addColumn("job_id", "text", (col) => col.notNull())
8
- .addColumn("job_dependencies", "jsonb", (col) => col.notNull().defaultTo(sql `'[]'::jsonb`))
9
- .addColumn("remote_name", "text", (col) => col.notNull().references("sync_remotes.name").onDelete("cascade"))
10
- .addColumn("document_id", "text", (col) => col.notNull())
11
- .addColumn("scopes", "jsonb", (col) => col.notNull().defaultTo(sql `'[]'::jsonb`))
12
- .addColumn("branch", "text", (col) => col.notNull())
13
- .addColumn("operations", "jsonb", (col) => col.notNull().defaultTo(sql `'[]'::jsonb`))
14
- .addColumn("error_source", "text", (col) => col.notNull())
15
- .addColumn("error_message", "text", (col) => col.notNull())
16
- .addColumn("created_at", "timestamptz", (col) => col.notNull().defaultTo(sql `NOW()`))
17
- .execute();
18
- await db.schema
19
- .createIndex("idx_sync_dead_letters_remote")
20
- .on("sync_dead_letters")
21
- .column("remote_name")
22
- .execute();
23
- }
24
- //# sourceMappingURL=013_create_sync_dead_letters_table.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"013_create_sync_dead_letters_table.js","sourceRoot":"","sources":["../../../../src/storage/migrations/013_create_sync_dead_letters_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,mBAAmB,CAAC;SAChC,SAAS,CAAC,SAAS,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;SACzD,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;SACxD,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACnD,SAAS,CAAC,kBAAkB,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAC9C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,aAAa,CAAC,CAC1C;SACA,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CACxC,GAAG,CAAC,OAAO,EAAE,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAClE;SACA,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACxD,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CACpC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,aAAa,CAAC,CAC1C;SACA,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACnD,SAAS,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CACxC,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,aAAa,CAAC,CAC1C;SACA,SAAS,CAAC,cAAc,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SACzD,SAAS,CAAC,eAAe,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;SAC1D,SAAS,CAAC,YAAY,EAAE,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE,CAC9C,GAAG,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,GAAG,CAAA,OAAO,CAAC,CACpC;SACA,OAAO,EAAE,CAAC;IAEb,MAAM,EAAE,CAAC,MAAM;SACZ,WAAW,CAAC,8BAA8B,CAAC;SAC3C,EAAE,CAAC,mBAAmB,CAAC;SACvB,MAAM,CAAC,aAAa,CAAC;SACrB,OAAO,EAAE,CAAC;AACf,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from "./types.js";
2
- export * from "./migrator.js";
3
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/storage/migrations/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC"}
@@ -1,84 +0,0 @@
1
- import { Migrator, sql } from "kysely";
2
- export const REACTOR_SCHEMA = "reactor";
3
- import * as migration001 from "./001_create_operation_table.js";
4
- import * as migration002 from "./002_create_keyframe_table.js";
5
- import * as migration003 from "./003_create_document_table.js";
6
- import * as migration004 from "./004_create_document_relationship_table.js";
7
- import * as migration005 from "./005_create_indexer_state_table.js";
8
- import * as migration006 from "./006_create_document_snapshot_table.js";
9
- import * as migration007 from "./007_create_slug_mapping_table.js";
10
- import * as migration008 from "./008_create_view_state_table.js";
11
- import * as migration009 from "./009_create_operation_index_tables.js";
12
- import * as migration010 from "./010_create_sync_tables.js";
13
- import * as migration011 from "./011_add_cursor_type_column.js";
14
- import * as migration012 from "./012_add_source_remote_column.js";
15
- import * as migration013 from "./013_create_sync_dead_letters_table.js";
16
- const migrations = {
17
- "001_create_operation_table": migration001,
18
- "002_create_keyframe_table": migration002,
19
- "003_create_document_table": migration003,
20
- "004_create_document_relationship_table": migration004,
21
- "005_create_indexer_state_table": migration005,
22
- "006_create_document_snapshot_table": migration006,
23
- "007_create_slug_mapping_table": migration007,
24
- "008_create_view_state_table": migration008,
25
- "009_create_operation_index_tables": migration009,
26
- "010_create_sync_tables": migration010,
27
- "011_add_cursor_type_column": migration011,
28
- "012_add_source_remote_column": migration012,
29
- "013_create_sync_dead_letters_table": migration013,
30
- };
31
- class ProgrammaticMigrationProvider {
32
- getMigrations() {
33
- return Promise.resolve(migrations);
34
- }
35
- }
36
- export async function runMigrations(db, schema = REACTOR_SCHEMA) {
37
- try {
38
- await sql `CREATE SCHEMA IF NOT EXISTS ${sql.id(schema)}`.execute(db);
39
- }
40
- catch (error) {
41
- return {
42
- success: false,
43
- migrationsExecuted: [],
44
- error: error instanceof Error ? error : new Error("Failed to create schema"),
45
- };
46
- }
47
- const migrator = new Migrator({
48
- db: db.withSchema(schema),
49
- provider: new ProgrammaticMigrationProvider(),
50
- migrationTableSchema: schema,
51
- });
52
- let error;
53
- let results;
54
- try {
55
- const result = await migrator.migrateToLatest();
56
- error = result.error;
57
- results = result.results;
58
- }
59
- catch (e) {
60
- error = e;
61
- results = [];
62
- }
63
- const migrationsExecuted = results?.map((result) => result.migrationName) ?? [];
64
- if (error) {
65
- return {
66
- success: false,
67
- migrationsExecuted,
68
- error: error instanceof Error ? error : new Error("Unknown migration error"),
69
- };
70
- }
71
- return {
72
- success: true,
73
- migrationsExecuted,
74
- };
75
- }
76
- export async function getMigrationStatus(db, schema = REACTOR_SCHEMA) {
77
- const migrator = new Migrator({
78
- db: db.withSchema(schema),
79
- provider: new ProgrammaticMigrationProvider(),
80
- migrationTableSchema: schema,
81
- });
82
- return await migrator.getMigrations();
83
- }
84
- //# sourceMappingURL=migrator.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../../src/storage/migrations/migrator.ts"],"names":[],"mappings":"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"}
@@ -1,58 +0,0 @@
1
- import { PGlite } from "@electric-sql/pglite";
2
- import { Kysely } from "kysely";
3
- import { PGliteDialect } from "kysely-pglite-dialect";
4
- import { runMigrations, getMigrationStatus } from "./migrator.js";
5
- async function main() {
6
- const command = process.argv[2];
7
- const db = new Kysely({
8
- dialect: new PGliteDialect(new PGlite()),
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
@@ -1 +0,0 @@
1
- {"version":3,"file":"run-migrations.js","sourceRoot":"","sources":["../../../../src/storage/migrations/run-migrations.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=types.js.map