@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.
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +19998 -62
- package/dist/src/sync/index.d.ts +1 -1
- package/dist/src/sync/index.d.ts.map +1 -1
- package/dist/src/sync/sync-manager.d.ts.map +1 -1
- package/dist/src/sync/types.d.ts +11 -0
- package/dist/src/sync/types.d.ts.map +1 -1
- package/package.json +17 -10
- package/dist/src/actions/index.js +0 -76
- package/dist/src/actions/index.js.map +0 -1
- package/dist/src/cache/buffer/ring-buffer.js +0 -69
- package/dist/src/cache/buffer/ring-buffer.js.map +0 -1
- package/dist/src/cache/collection-membership-cache.js +0 -33
- package/dist/src/cache/collection-membership-cache.js.map +0 -1
- package/dist/src/cache/document-meta-cache-types.js +0 -2
- package/dist/src/cache/document-meta-cache-types.js.map +0 -1
- package/dist/src/cache/document-meta-cache.js +0 -129
- package/dist/src/cache/document-meta-cache.js.map +0 -1
- package/dist/src/cache/index.js +0 -2
- package/dist/src/cache/index.js.map +0 -1
- package/dist/src/cache/kysely-operation-index.js +0 -345
- package/dist/src/cache/kysely-operation-index.js.map +0 -1
- package/dist/src/cache/kysely-write-cache.js +0 -411
- package/dist/src/cache/kysely-write-cache.js.map +0 -1
- package/dist/src/cache/lru/lru-tracker.js +0 -96
- package/dist/src/cache/lru/lru-tracker.js.map +0 -1
- package/dist/src/cache/operation-index-types.js +0 -4
- package/dist/src/cache/operation-index-types.js.map +0 -1
- package/dist/src/cache/write/interfaces.js +0 -2
- package/dist/src/cache/write/interfaces.js.map +0 -1
- package/dist/src/cache/write-cache-types.js +0 -2
- package/dist/src/cache/write-cache-types.js.map +0 -1
- package/dist/src/client/reactor-client.js +0 -497
- package/dist/src/client/reactor-client.js.map +0 -1
- package/dist/src/client/types.js +0 -14
- package/dist/src/client/types.js.map +0 -1
- package/dist/src/core/reactor-builder.js +0 -306
- package/dist/src/core/reactor-builder.js.map +0 -1
- package/dist/src/core/reactor-client-builder.js +0 -132
- package/dist/src/core/reactor-client-builder.js.map +0 -1
- package/dist/src/core/reactor.js +0 -640
- package/dist/src/core/reactor.js.map +0 -1
- package/dist/src/core/types.js +0 -2
- package/dist/src/core/types.js.map +0 -1
- package/dist/src/core/utils.js +0 -225
- package/dist/src/core/utils.js.map +0 -1
- package/dist/src/events/event-bus.js +0 -53
- package/dist/src/events/event-bus.js.map +0 -1
- package/dist/src/events/interfaces.js +0 -2
- package/dist/src/events/interfaces.js.map +0 -1
- package/dist/src/events/types.js +0 -30
- package/dist/src/events/types.js.map +0 -1
- package/dist/src/executor/document-action-handler.js +0 -356
- package/dist/src/executor/document-action-handler.js.map +0 -1
- package/dist/src/executor/interfaces.js +0 -2
- package/dist/src/executor/interfaces.js.map +0 -1
- package/dist/src/executor/signature-verifier.js +0 -70
- package/dist/src/executor/signature-verifier.js.map +0 -1
- package/dist/src/executor/simple-job-executor-manager.js +0 -345
- package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
- package/dist/src/executor/simple-job-executor.js +0 -423
- package/dist/src/executor/simple-job-executor.js.map +0 -1
- package/dist/src/executor/types.js +0 -11
- package/dist/src/executor/types.js.map +0 -1
- package/dist/src/executor/util.js +0 -230
- package/dist/src/executor/util.js.map +0 -1
- package/dist/src/index.js.map +0 -1
- package/dist/src/job-tracker/in-memory-job-tracker.js +0 -114
- package/dist/src/job-tracker/in-memory-job-tracker.js.map +0 -1
- package/dist/src/job-tracker/index.js +0 -2
- package/dist/src/job-tracker/index.js.map +0 -1
- package/dist/src/job-tracker/interfaces.js +0 -2
- package/dist/src/job-tracker/interfaces.js.map +0 -1
- package/dist/src/logging/console.js +0 -2
- package/dist/src/logging/console.js.map +0 -1
- package/dist/src/logging/types.js +0 -2
- package/dist/src/logging/types.js.map +0 -1
- package/dist/src/processors/index.js +0 -2
- package/dist/src/processors/index.js.map +0 -1
- package/dist/src/processors/processor-manager.js +0 -165
- package/dist/src/processors/processor-manager.js.map +0 -1
- package/dist/src/processors/relational/types.js +0 -2
- package/dist/src/processors/relational/types.js.map +0 -1
- package/dist/src/processors/relational/utils.js +0 -2
- package/dist/src/processors/relational/utils.js.map +0 -1
- package/dist/src/processors/utils.js +0 -59
- package/dist/src/processors/utils.js.map +0 -1
- package/dist/src/queue/interfaces.js +0 -2
- package/dist/src/queue/interfaces.js.map +0 -1
- package/dist/src/queue/job-execution-handle.js +0 -71
- package/dist/src/queue/job-execution-handle.js.map +0 -1
- package/dist/src/queue/queue.js +0 -493
- package/dist/src/queue/queue.js.map +0 -1
- package/dist/src/queue/types.js +0 -19
- package/dist/src/queue/types.js.map +0 -1
- package/dist/src/read-models/base-read-model.js +0 -143
- package/dist/src/read-models/base-read-model.js.map +0 -1
- package/dist/src/read-models/coordinator.js +0 -72
- package/dist/src/read-models/coordinator.js.map +0 -1
- package/dist/src/read-models/document-view.js +0 -457
- package/dist/src/read-models/document-view.js.map +0 -1
- package/dist/src/read-models/interfaces.js +0 -2
- package/dist/src/read-models/interfaces.js.map +0 -1
- package/dist/src/read-models/types.js +0 -2
- package/dist/src/read-models/types.js.map +0 -1
- package/dist/src/registry/document-model-resolver.js +0 -81
- package/dist/src/registry/document-model-resolver.js.map +0 -1
- package/dist/src/registry/implementation.js +0 -226
- package/dist/src/registry/implementation.js.map +0 -1
- package/dist/src/registry/index.js +0 -3
- package/dist/src/registry/index.js.map +0 -1
- package/dist/src/registry/interfaces.js +0 -2
- package/dist/src/registry/interfaces.js.map +0 -1
- package/dist/src/shared/awaiter.js +0 -123
- package/dist/src/shared/awaiter.js.map +0 -1
- package/dist/src/shared/collect-all-pages.js +0 -17
- package/dist/src/shared/collect-all-pages.js.map +0 -1
- package/dist/src/shared/consistency-tracker.js +0 -123
- package/dist/src/shared/consistency-tracker.js.map +0 -1
- package/dist/src/shared/drive-url.js +0 -17
- package/dist/src/shared/drive-url.js.map +0 -1
- package/dist/src/shared/errors.js +0 -93
- package/dist/src/shared/errors.js.map +0 -1
- package/dist/src/shared/factories.js +0 -41
- package/dist/src/shared/factories.js.map +0 -1
- package/dist/src/shared/types.js +0 -38
- package/dist/src/shared/types.js.map +0 -1
- package/dist/src/shared/utils.js +0 -8
- package/dist/src/shared/utils.js.map +0 -1
- package/dist/src/signer/passthrough-signer.js +0 -17
- package/dist/src/signer/passthrough-signer.js.map +0 -1
- package/dist/src/signer/types.js +0 -2
- package/dist/src/signer/types.js.map +0 -1
- package/dist/src/storage/index.js +0 -3
- package/dist/src/storage/index.js.map +0 -1
- package/dist/src/storage/interfaces.js +0 -29
- package/dist/src/storage/interfaces.js.map +0 -1
- package/dist/src/storage/kysely/document-indexer.js +0 -421
- package/dist/src/storage/kysely/document-indexer.js.map +0 -1
- package/dist/src/storage/kysely/keyframe-store.js +0 -64
- package/dist/src/storage/kysely/keyframe-store.js.map +0 -1
- package/dist/src/storage/kysely/store.js +0 -264
- package/dist/src/storage/kysely/store.js.map +0 -1
- package/dist/src/storage/kysely/sync-cursor-storage.js +0 -97
- package/dist/src/storage/kysely/sync-cursor-storage.js.map +0 -1
- package/dist/src/storage/kysely/sync-dead-letter-storage.js +0 -110
- package/dist/src/storage/kysely/sync-dead-letter-storage.js.map +0 -1
- package/dist/src/storage/kysely/sync-remote-storage.js +0 -133
- package/dist/src/storage/kysely/sync-remote-storage.js.map +0 -1
- package/dist/src/storage/kysely/types.js +0 -2
- package/dist/src/storage/kysely/types.js.map +0 -1
- package/dist/src/storage/migrations/001_create_operation_table.js +0 -41
- package/dist/src/storage/migrations/001_create_operation_table.js.map +0 -1
- package/dist/src/storage/migrations/002_create_keyframe_table.js +0 -27
- package/dist/src/storage/migrations/002_create_keyframe_table.js.map +0 -1
- package/dist/src/storage/migrations/003_create_document_table.js +0 -10
- package/dist/src/storage/migrations/003_create_document_table.js.map +0 -1
- package/dist/src/storage/migrations/004_create_document_relationship_table.js +0 -35
- package/dist/src/storage/migrations/004_create_document_relationship_table.js.map +0 -1
- package/dist/src/storage/migrations/005_create_indexer_state_table.js +0 -10
- package/dist/src/storage/migrations/005_create_indexer_state_table.js.map +0 -1
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js +0 -49
- package/dist/src/storage/migrations/006_create_document_snapshot_table.js.map +0 -1
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js +0 -24
- package/dist/src/storage/migrations/007_create_slug_mapping_table.js.map +0 -1
- package/dist/src/storage/migrations/008_create_view_state_table.js +0 -10
- package/dist/src/storage/migrations/008_create_view_state_table.js.map +0 -1
- package/dist/src/storage/migrations/009_create_operation_index_tables.js +0 -50
- package/dist/src/storage/migrations/009_create_operation_index_tables.js.map +0 -1
- package/dist/src/storage/migrations/010_create_sync_tables.js +0 -43
- package/dist/src/storage/migrations/010_create_sync_tables.js.map +0 -1
- package/dist/src/storage/migrations/011_add_cursor_type_column.js +0 -29
- package/dist/src/storage/migrations/011_add_cursor_type_column.js.map +0 -1
- package/dist/src/storage/migrations/012_add_source_remote_column.js +0 -7
- package/dist/src/storage/migrations/012_add_source_remote_column.js.map +0 -1
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js +0 -24
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.js.map +0 -1
- package/dist/src/storage/migrations/index.js +0 -3
- package/dist/src/storage/migrations/index.js.map +0 -1
- package/dist/src/storage/migrations/migrator.js +0 -84
- package/dist/src/storage/migrations/migrator.js.map +0 -1
- package/dist/src/storage/migrations/run-migrations.js +0 -58
- package/dist/src/storage/migrations/run-migrations.js.map +0 -1
- package/dist/src/storage/migrations/types.js +0 -2
- package/dist/src/storage/migrations/types.js.map +0 -1
- package/dist/src/storage/txn.js +0 -42
- package/dist/src/storage/txn.js.map +0 -1
- package/dist/src/subs/default-error-handler.js +0 -27
- package/dist/src/subs/default-error-handler.js.map +0 -1
- package/dist/src/subs/react-subscription-manager.js +0 -185
- package/dist/src/subs/react-subscription-manager.js.map +0 -1
- package/dist/src/subs/subscription-notification-read-model.js +0 -62
- package/dist/src/subs/subscription-notification-read-model.js.map +0 -1
- package/dist/src/subs/types.js +0 -2
- package/dist/src/subs/types.js.map +0 -1
- package/dist/src/sync/batch-aggregator.js +0 -94
- package/dist/src/sync/batch-aggregator.js.map +0 -1
- package/dist/src/sync/buffered-mailbox.js +0 -164
- package/dist/src/sync/buffered-mailbox.js.map +0 -1
- package/dist/src/sync/channels/gql-req-channel.js +0 -548
- package/dist/src/sync/channels/gql-req-channel.js.map +0 -1
- package/dist/src/sync/channels/gql-request-channel-factory.js +0 -105
- package/dist/src/sync/channels/gql-request-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/gql-res-channel.js +0 -79
- package/dist/src/sync/channels/gql-res-channel.js.map +0 -1
- package/dist/src/sync/channels/gql-response-channel-factory.js +0 -14
- package/dist/src/sync/channels/gql-response-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/index.js +0 -8
- package/dist/src/sync/channels/index.js.map +0 -1
- package/dist/src/sync/channels/interval-poll-timer.js +0 -123
- package/dist/src/sync/channels/interval-poll-timer.js.map +0 -1
- package/dist/src/sync/channels/poll-timer.js +0 -2
- package/dist/src/sync/channels/poll-timer.js.map +0 -1
- package/dist/src/sync/channels/utils.js +0 -161
- package/dist/src/sync/channels/utils.js.map +0 -1
- package/dist/src/sync/errors.js +0 -17
- package/dist/src/sync/errors.js.map +0 -1
- package/dist/src/sync/index.js +0 -11
- package/dist/src/sync/index.js.map +0 -1
- package/dist/src/sync/interfaces.js +0 -2
- package/dist/src/sync/interfaces.js.map +0 -1
- package/dist/src/sync/mailbox.js +0 -142
- package/dist/src/sync/mailbox.js.map +0 -1
- package/dist/src/sync/sync-awaiter.js +0 -124
- package/dist/src/sync/sync-awaiter.js.map +0 -1
- package/dist/src/sync/sync-builder.js +0 -52
- package/dist/src/sync/sync-builder.js.map +0 -1
- package/dist/src/sync/sync-manager.js +0 -447
- package/dist/src/sync/sync-manager.js.map +0 -1
- package/dist/src/sync/sync-operation.js +0 -70
- package/dist/src/sync/sync-operation.js.map +0 -1
- package/dist/src/sync/sync-status-tracker.js +0 -137
- package/dist/src/sync/sync-status-tracker.js.map +0 -1
- package/dist/src/sync/types.js +0 -31
- package/dist/src/sync/types.js.map +0 -1
- package/dist/src/sync/utils.js +0 -283
- package/dist/src/sync/utils.js.map +0 -1
- package/dist/src/utils/reshuffle.js +0 -91
- 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 +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 +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":"AAAA,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAC;AAIvC,MAAM,CAAC,MAAM,cAAc,GAAG,SAAS,CAAC;AACxC,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,YAAY,MAAM,gCAAgC,CAAC;AAC/D,OAAO,KAAK,YAAY,MAAM,gCAAgC,CAAC;AAC/D,OAAO,KAAK,YAAY,MAAM,6CAA6C,CAAC;AAC5E,OAAO,KAAK,YAAY,MAAM,qCAAqC,CAAC;AACpE,OAAO,KAAK,YAAY,MAAM,yCAAyC,CAAC;AACxE,OAAO,KAAK,YAAY,MAAM,oCAAoC,CAAC;AACnE,OAAO,KAAK,YAAY,MAAM,kCAAkC,CAAC;AACjE,OAAO,KAAK,YAAY,MAAM,wCAAwC,CAAC;AACvE,OAAO,KAAK,YAAY,MAAM,6BAA6B,CAAC;AAC5D,OAAO,KAAK,YAAY,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,YAAY,MAAM,mCAAmC,CAAC;AAClE,OAAO,KAAK,YAAY,MAAM,yCAAyC,CAAC;AAExE,MAAM,UAAU,GAAG;IACjB,4BAA4B,EAAE,YAAY;IAC1C,2BAA2B,EAAE,YAAY;IACzC,2BAA2B,EAAE,YAAY;IACzC,wCAAwC,EAAE,YAAY;IACtD,gCAAgC,EAAE,YAAY;IAC9C,oCAAoC,EAAE,YAAY;IAClD,+BAA+B,EAAE,YAAY;IAC7C,6BAA6B,EAAE,YAAY;IAC3C,mCAAmC,EAAE,YAAY;IACjD,wBAAwB,EAAE,YAAY;IACtC,4BAA4B,EAAE,YAAY;IAC1C,8BAA8B,EAAE,YAAY;IAC5C,oCAAoC,EAAE,YAAY;CACnD,CAAC;AAEF,MAAM,6BAA6B;IACjC,aAAa;QACX,OAAO,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;CACF;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,EAAe,EACf,SAAiB,cAAc;IAE/B,IAAI,CAAC;QACH,MAAM,GAAG,CAAA,+BAA+B,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACvE,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO;YACL,OAAO,EAAE,KAAK;YACd,kBAAkB,EAAE,EAAE;YACtB,KAAK,EACH,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,yBAAyB,CAAC;SACxE,CAAC;IACJ,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;QAC5B,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QACzB,QAAQ,EAAE,IAAI,6BAA6B,EAAE;QAC7C,oBAAoB,EAAE,MAAM;KAC7B,CAAC,CAAC;IAEH,IAAI,KAAc,CAAC;IACnB,IAAI,OAAwE,CAAC;IAC7E,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,eAAe,EAAE,CAAC;QAChD,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QACrB,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;IAC3B,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,KAAK,GAAG,CAAC,CAAC;QACV,OAAO,GAAG,EAAE,CAAC;IACf,CAAC;IAED,MAAM,kBAAkB,GACtB,OAAO,EAAE,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAEvD,IAAI,KAAK,EAAE,CAAC;QACV,OAAO;YACL,OAAO,EAAE,KAAK;YACd,kBAAkB;YAClB,KAAK,EACH,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,yBAAyB,CAAC;SACxE,CAAC;IACJ,CAAC;IAED,OAAO;QACL,OAAO,EAAE,IAAI;QACb,kBAAkB;KACnB,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,EAAe,EACf,SAAiB,cAAc;IAE/B,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;QAC5B,EAAE,EAAE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC;QACzB,QAAQ,EAAE,IAAI,6BAA6B,EAAE;QAC7C,oBAAoB,EAAE,MAAM;KAC7B,CAAC,CAAC;IAEH,OAAO,MAAM,QAAQ,CAAC,aAAa,EAAE,CAAC;AACxC,CAAC"}
|
|
@@ -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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"}
|