@powerhousedao/reactor 6.0.0-dev.8 → 6.0.0-dev.80
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/cache/collection-membership-cache.d.ts +13 -0
- package/dist/src/cache/collection-membership-cache.d.ts.map +1 -0
- package/dist/src/cache/document-meta-cache.d.ts.map +1 -1
- package/dist/src/cache/kysely-operation-index.d.ts +6 -1
- package/dist/src/cache/kysely-operation-index.d.ts.map +1 -1
- package/dist/src/cache/kysely-write-cache.d.ts +9 -2
- package/dist/src/cache/kysely-write-cache.d.ts.map +1 -1
- package/dist/src/cache/operation-index-types.d.ts +16 -2
- package/dist/src/cache/operation-index-types.d.ts.map +1 -1
- package/dist/src/cache/write/interfaces.d.ts +7 -2
- package/dist/src/cache/write/interfaces.d.ts.map +1 -1
- package/dist/src/client/reactor-client.d.ts +13 -10
- package/dist/src/client/reactor-client.d.ts.map +1 -1
- package/dist/src/client/types.d.ts +25 -6
- package/dist/src/client/types.d.ts.map +1 -1
- package/dist/src/core/reactor-builder.d.ts +23 -10
- package/dist/src/core/reactor-builder.d.ts.map +1 -1
- package/dist/src/core/reactor-client-builder.d.ts +5 -4
- package/dist/src/core/reactor-client-builder.d.ts.map +1 -1
- package/dist/src/core/reactor.d.ts +20 -80
- package/dist/src/core/reactor.d.ts.map +1 -1
- package/dist/src/core/types.d.ts +64 -28
- package/dist/src/core/types.d.ts.map +1 -1
- package/dist/src/core/utils.d.ts +39 -3
- package/dist/src/core/utils.d.ts.map +1 -1
- package/dist/src/events/types.d.ts +35 -10
- package/dist/src/events/types.d.ts.map +1 -1
- package/dist/src/executor/document-action-handler.d.ts +37 -0
- package/dist/src/executor/document-action-handler.d.ts.map +1 -0
- package/dist/src/executor/signature-verifier.d.ts +9 -0
- package/dist/src/executor/signature-verifier.d.ts.map +1 -0
- package/dist/src/executor/simple-job-executor-manager.d.ts +6 -1
- package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -1
- package/dist/src/executor/simple-job-executor.d.ts +6 -46
- package/dist/src/executor/simple-job-executor.d.ts.map +1 -1
- package/dist/src/executor/types.d.ts +1 -3
- package/dist/src/executor/types.d.ts.map +1 -1
- package/dist/src/executor/util.d.ts +12 -2
- package/dist/src/executor/util.d.ts.map +1 -1
- package/dist/src/index.d.ts +11 -9
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +20208 -61
- package/dist/src/job-tracker/in-memory-job-tracker.d.ts +4 -3
- package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -1
- package/dist/src/job-tracker/interfaces.d.ts +3 -1
- package/dist/src/job-tracker/interfaces.d.ts.map +1 -1
- package/dist/src/logging/console.d.ts +1 -22
- package/dist/src/logging/console.d.ts.map +1 -1
- package/dist/src/logging/types.d.ts +1 -11
- package/dist/src/logging/types.d.ts.map +1 -1
- package/dist/src/processors/index.d.ts +1 -1
- package/dist/src/processors/index.d.ts.map +1 -1
- package/dist/src/processors/processor-manager.d.ts +19 -6
- package/dist/src/processors/processor-manager.d.ts.map +1 -1
- package/dist/src/processors/relational/types.d.ts +2 -0
- package/dist/src/processors/relational/types.d.ts.map +1 -0
- package/dist/src/processors/relational/utils.d.ts +2 -0
- package/dist/src/processors/relational/utils.d.ts.map +1 -0
- package/dist/src/processors/utils.d.ts +3 -2
- package/dist/src/processors/utils.d.ts.map +1 -1
- package/dist/src/queue/job-execution-handle.d.ts +3 -0
- package/dist/src/queue/job-execution-handle.d.ts.map +1 -1
- package/dist/src/queue/queue.d.ts +30 -1
- package/dist/src/queue/queue.d.ts.map +1 -1
- package/dist/src/queue/types.d.ts +4 -3
- package/dist/src/queue/types.d.ts.map +1 -1
- package/dist/src/read-models/base-read-model.d.ts +11 -9
- package/dist/src/read-models/base-read-model.d.ts.map +1 -1
- package/dist/src/read-models/coordinator.d.ts +2 -2
- package/dist/src/read-models/coordinator.d.ts.map +1 -1
- package/dist/src/read-models/document-view.d.ts +7 -4
- package/dist/src/read-models/document-view.d.ts.map +1 -1
- package/dist/src/read-models/interfaces.d.ts +1 -1
- package/dist/src/read-models/interfaces.d.ts.map +1 -1
- package/dist/src/read-models/types.d.ts +16 -0
- package/dist/src/read-models/types.d.ts.map +1 -1
- package/dist/src/registry/document-model-resolver.d.ts +29 -0
- package/dist/src/registry/document-model-resolver.d.ts.map +1 -0
- package/dist/src/registry/implementation.d.ts +4 -0
- package/dist/src/registry/implementation.d.ts.map +1 -1
- package/dist/src/registry/index.d.ts +3 -1
- package/dist/src/registry/index.d.ts.map +1 -1
- package/dist/src/registry/interfaces.d.ts +8 -0
- package/dist/src/registry/interfaces.d.ts.map +1 -1
- package/dist/src/shared/awaiter.d.ts +2 -2
- package/dist/src/shared/awaiter.d.ts.map +1 -1
- package/dist/src/shared/collect-all-pages.d.ts +7 -0
- package/dist/src/shared/collect-all-pages.d.ts.map +1 -0
- package/dist/src/shared/drive-url.d.ts +15 -0
- package/dist/src/shared/drive-url.d.ts.map +1 -0
- package/dist/src/shared/errors.d.ts +9 -0
- package/dist/src/shared/errors.d.ts.map +1 -1
- package/dist/src/shared/factories.d.ts +6 -2
- package/dist/src/shared/factories.d.ts.map +1 -1
- package/dist/src/shared/types.d.ts +32 -6
- package/dist/src/shared/types.d.ts.map +1 -1
- package/dist/src/signer/passthrough-signer.d.ts +1 -1
- package/dist/src/signer/passthrough-signer.d.ts.map +1 -1
- package/dist/src/storage/interfaces.d.ts +238 -124
- package/dist/src/storage/interfaces.d.ts.map +1 -1
- package/dist/src/storage/kysely/document-indexer.d.ts +17 -18
- package/dist/src/storage/kysely/document-indexer.d.ts.map +1 -1
- package/dist/src/storage/kysely/store.d.ts +5 -4
- package/dist/src/storage/kysely/store.d.ts.map +1 -1
- package/dist/src/storage/kysely/sync-cursor-storage.d.ts +1 -1
- package/dist/src/storage/kysely/sync-cursor-storage.d.ts.map +1 -1
- package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts +17 -0
- package/dist/src/storage/kysely/sync-dead-letter-storage.d.ts.map +1 -0
- package/dist/src/storage/kysely/types.d.ts +22 -0
- package/dist/src/storage/kysely/types.d.ts.map +1 -1
- package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts +3 -0
- package/dist/src/storage/migrations/011_add_cursor_type_column.d.ts.map +1 -0
- package/dist/src/storage/migrations/012_add_source_remote_column.d.ts +3 -0
- package/dist/src/storage/migrations/012_add_source_remote_column.d.ts.map +1 -0
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts +3 -0
- package/dist/src/storage/migrations/013_create_sync_dead_letters_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/014_create_processor_cursor_table.d.ts +3 -0
- package/dist/src/storage/migrations/014_create_processor_cursor_table.d.ts.map +1 -0
- package/dist/src/storage/migrations/migrator.d.ts.map +1 -1
- package/dist/src/subs/default-error-handler.d.ts.map +1 -1
- package/dist/src/subs/subscription-notification-read-model.d.ts +3 -2
- package/dist/src/subs/subscription-notification-read-model.d.ts.map +1 -1
- package/dist/src/sync/batch-aggregator.d.ts +25 -0
- package/dist/src/sync/batch-aggregator.d.ts.map +1 -0
- package/dist/src/sync/buffered-mailbox.d.ts +36 -0
- package/dist/src/sync/buffered-mailbox.d.ts.map +1 -0
- package/dist/src/sync/channels/gql-req-channel.d.ts +121 -0
- package/dist/src/sync/channels/gql-req-channel.d.ts.map +1 -0
- package/dist/src/sync/channels/gql-request-channel-factory.d.ts +32 -0
- package/dist/src/sync/channels/gql-request-channel-factory.d.ts.map +1 -0
- package/dist/src/sync/channels/gql-res-channel.d.ts +31 -0
- package/dist/src/sync/channels/gql-res-channel.d.ts.map +1 -0
- package/dist/src/sync/channels/gql-response-channel-factory.d.ts +13 -0
- package/dist/src/sync/channels/gql-response-channel-factory.d.ts.map +1 -0
- package/dist/src/sync/channels/index.d.ts +6 -4
- package/dist/src/sync/channels/index.d.ts.map +1 -1
- package/dist/src/sync/channels/interval-poll-timer.d.ts +40 -0
- package/dist/src/sync/channels/interval-poll-timer.d.ts.map +1 -0
- package/dist/src/sync/channels/poll-timer.d.ts +14 -0
- package/dist/src/sync/channels/poll-timer.d.ts.map +1 -0
- package/dist/src/sync/channels/utils.d.ts +15 -1
- package/dist/src/sync/channels/utils.d.ts.map +1 -1
- package/dist/src/sync/index.d.ts +11 -7
- package/dist/src/sync/index.d.ts.map +1 -1
- package/dist/src/sync/interfaces.d.ts +42 -19
- package/dist/src/sync/interfaces.d.ts.map +1 -1
- package/dist/src/sync/mailbox.d.ts +51 -12
- package/dist/src/sync/mailbox.d.ts.map +1 -1
- package/dist/src/sync/sync-awaiter.d.ts +34 -0
- package/dist/src/sync/sync-awaiter.d.ts.map +1 -0
- package/dist/src/sync/sync-builder.d.ts +5 -1
- package/dist/src/sync/sync-builder.d.ts.map +1 -1
- package/dist/src/sync/sync-manager.d.ts +22 -8
- package/dist/src/sync/sync-manager.d.ts.map +1 -1
- package/dist/src/sync/sync-operation.d.ts +4 -2
- package/dist/src/sync/sync-operation.d.ts.map +1 -1
- package/dist/src/sync/sync-status-tracker.d.ts +31 -0
- package/dist/src/sync/sync-status-tracker.d.ts.map +1 -0
- package/dist/src/sync/types.d.ts +107 -2
- package/dist/src/sync/types.d.ts.map +1 -1
- package/dist/src/sync/utils.d.ts +37 -2
- package/dist/src/sync/utils.d.ts.map +1 -1
- package/dist/src/utils/reshuffle.d.ts +22 -5
- package/dist/src/utils/reshuffle.d.ts.map +1 -1
- package/package.json +24 -20
- 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/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 -128
- 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 -250
- package/dist/src/cache/kysely-operation-index.js.map +0 -1
- package/dist/src/cache/kysely-write-cache.js +0 -388
- 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 -406
- 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 -231
- package/dist/src/core/reactor-builder.js.map +0 -1
- package/dist/src/core/reactor-client-builder.js +0 -123
- package/dist/src/core/reactor-client-builder.js.map +0 -1
- package/dist/src/core/reactor.js +0 -981
- 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 -171
- 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 -28
- package/dist/src/events/types.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/simple-job-executor-manager.js +0 -233
- package/dist/src/executor/simple-job-executor-manager.js.map +0 -1
- package/dist/src/executor/simple-job-executor.js +0 -898
- 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 -184
- 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 -112
- 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 -108
- 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/types.d.ts +0 -63
- package/dist/src/processors/types.d.ts.map +0 -1
- package/dist/src/processors/types.js +0 -2
- package/dist/src/processors/types.js.map +0 -1
- package/dist/src/processors/utils.js +0 -58
- 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 -62
- package/dist/src/queue/job-execution-handle.js.map +0 -1
- package/dist/src/queue/queue.js +0 -384
- 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 -375
- 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/implementation.js +0 -216
- package/dist/src/registry/implementation.js.map +0 -1
- package/dist/src/registry/index.js +0 -2
- 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/consistency-tracker.js +0 -123
- package/dist/src/shared/consistency-tracker.js.map +0 -1
- package/dist/src/shared/errors.js +0 -75
- package/dist/src/shared/errors.js.map +0 -1
- package/dist/src/shared/factories.js +0 -33
- 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 -19
- 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/consistency-aware-legacy-storage.d.ts +0 -33
- package/dist/src/storage/consistency-aware-legacy-storage.d.ts.map +0 -1
- package/dist/src/storage/consistency-aware-legacy-storage.js +0 -65
- package/dist/src/storage/consistency-aware-legacy-storage.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 -19
- package/dist/src/storage/interfaces.js.map +0 -1
- package/dist/src/storage/kysely/document-indexer.js +0 -350
- 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 -233
- package/dist/src/storage/kysely/store.js.map +0 -1
- package/dist/src/storage/kysely/sync-cursor-storage.js +0 -93
- package/dist/src/storage/kysely/sync-cursor-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/index.js +0 -3
- package/dist/src/storage/migrations/index.js.map +0 -1
- package/dist/src/storage/migrations/migrator.js +0 -78
- 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/channels/composite-channel-factory.d.ts +0 -30
- package/dist/src/sync/channels/composite-channel-factory.d.ts.map +0 -1
- package/dist/src/sync/channels/composite-channel-factory.js +0 -87
- package/dist/src/sync/channels/composite-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/gql-channel-factory.d.ts +0 -25
- package/dist/src/sync/channels/gql-channel-factory.d.ts.map +0 -1
- package/dist/src/sync/channels/gql-channel-factory.js +0 -76
- package/dist/src/sync/channels/gql-channel-factory.js.map +0 -1
- package/dist/src/sync/channels/gql-channel.d.ts +0 -118
- package/dist/src/sync/channels/gql-channel.d.ts.map +0 -1
- package/dist/src/sync/channels/gql-channel.js +0 -423
- package/dist/src/sync/channels/gql-channel.js.map +0 -1
- package/dist/src/sync/channels/index.js +0 -6
- package/dist/src/sync/channels/index.js.map +0 -1
- package/dist/src/sync/channels/polling-channel.d.ts +0 -39
- package/dist/src/sync/channels/polling-channel.d.ts.map +0 -1
- package/dist/src/sync/channels/polling-channel.js +0 -72
- package/dist/src/sync/channels/polling-channel.js.map +0 -1
- package/dist/src/sync/channels/utils.js +0 -96
- 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 -9
- 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 -59
- package/dist/src/sync/mailbox.js.map +0 -1
- package/dist/src/sync/sync-builder.js +0 -39
- package/dist/src/sync/sync-builder.js.map +0 -1
- package/dist/src/sync/sync-manager.js +0 -266
- package/dist/src/sync/sync-manager.js.map +0 -1
- package/dist/src/sync/sync-operation.js +0 -63
- package/dist/src/sync/sync-operation.js.map +0 -1
- package/dist/src/sync/types.js +0 -16
- package/dist/src/sync/types.js.map +0 -1
- package/dist/src/sync/utils.js +0 -78
- package/dist/src/sync/utils.js.map +0 -1
- package/dist/src/utils/reshuffle.js +0 -47
- package/dist/src/utils/reshuffle.js.map +0 -1
|
@@ -1,350 +0,0 @@
|
|
|
1
|
-
import { v4 as uuidv4 } from "uuid";
|
|
2
|
-
export class KyselyDocumentIndexer {
|
|
3
|
-
db;
|
|
4
|
-
operationStore;
|
|
5
|
-
consistencyTracker;
|
|
6
|
-
lastOperationId = 0;
|
|
7
|
-
constructor(db, operationStore, consistencyTracker) {
|
|
8
|
-
this.db = db;
|
|
9
|
-
this.operationStore = operationStore;
|
|
10
|
-
this.consistencyTracker = consistencyTracker;
|
|
11
|
-
}
|
|
12
|
-
async init() {
|
|
13
|
-
const indexerState = await this.db
|
|
14
|
-
.selectFrom("IndexerState")
|
|
15
|
-
.selectAll()
|
|
16
|
-
.executeTakeFirst();
|
|
17
|
-
if (indexerState) {
|
|
18
|
-
this.lastOperationId = indexerState.lastOperationId;
|
|
19
|
-
const missedOperations = await this.operationStore.getSinceId(this.lastOperationId);
|
|
20
|
-
if (missedOperations.items.length > 0) {
|
|
21
|
-
await this.indexOperations(missedOperations.items);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
await this.db
|
|
26
|
-
.insertInto("IndexerState")
|
|
27
|
-
.values({
|
|
28
|
-
lastOperationId: 0,
|
|
29
|
-
})
|
|
30
|
-
.execute();
|
|
31
|
-
const allOperations = await this.operationStore.getSinceId(0);
|
|
32
|
-
if (allOperations.items.length > 0) {
|
|
33
|
-
await this.indexOperations(allOperations.items);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
async indexOperations(items) {
|
|
38
|
-
if (items.length === 0)
|
|
39
|
-
return;
|
|
40
|
-
await this.db.transaction().execute(async (trx) => {
|
|
41
|
-
for (const item of items) {
|
|
42
|
-
const { operation } = item;
|
|
43
|
-
const actionType = operation.action.type;
|
|
44
|
-
if (actionType === "ADD_RELATIONSHIP") {
|
|
45
|
-
await this.handleAddRelationship(trx, operation);
|
|
46
|
-
}
|
|
47
|
-
else if (actionType === "REMOVE_RELATIONSHIP") {
|
|
48
|
-
await this.handleRemoveRelationship(trx, operation);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
const lastOpId = items[items.length - 1].operation.id;
|
|
52
|
-
if (lastOpId && typeof lastOpId === "number") {
|
|
53
|
-
this.lastOperationId = lastOpId;
|
|
54
|
-
await trx
|
|
55
|
-
.updateTable("IndexerState")
|
|
56
|
-
.set({
|
|
57
|
-
lastOperationId: lastOpId,
|
|
58
|
-
lastOperationTimestamp: new Date(),
|
|
59
|
-
})
|
|
60
|
-
.execute();
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
const coordinates = [];
|
|
64
|
-
for (let i = 0; i < items.length; i++) {
|
|
65
|
-
const item = items[i];
|
|
66
|
-
coordinates.push({
|
|
67
|
-
documentId: item.context.documentId,
|
|
68
|
-
scope: item.context.scope,
|
|
69
|
-
branch: item.context.branch,
|
|
70
|
-
operationIndex: item.operation.index,
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
this.consistencyTracker.update(coordinates);
|
|
74
|
-
}
|
|
75
|
-
async waitForConsistency(token, timeoutMs, signal) {
|
|
76
|
-
if (token.coordinates.length === 0) {
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
await this.consistencyTracker.waitFor(token.coordinates, timeoutMs, signal);
|
|
80
|
-
}
|
|
81
|
-
async getOutgoing(documentId, types, consistencyToken, signal) {
|
|
82
|
-
if (consistencyToken) {
|
|
83
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
84
|
-
}
|
|
85
|
-
if (signal?.aborted) {
|
|
86
|
-
throw new Error("Operation aborted");
|
|
87
|
-
}
|
|
88
|
-
let query = this.db
|
|
89
|
-
.selectFrom("DocumentRelationship")
|
|
90
|
-
.selectAll()
|
|
91
|
-
.where("sourceId", "=", documentId);
|
|
92
|
-
if (types && types.length > 0) {
|
|
93
|
-
query = query.where("relationshipType", "in", types);
|
|
94
|
-
}
|
|
95
|
-
const rows = await query.execute();
|
|
96
|
-
return rows.map((row) => ({
|
|
97
|
-
sourceId: row.sourceId,
|
|
98
|
-
targetId: row.targetId,
|
|
99
|
-
relationshipType: row.relationshipType,
|
|
100
|
-
metadata: row.metadata
|
|
101
|
-
? row.metadata
|
|
102
|
-
: undefined,
|
|
103
|
-
createdAt: row.createdAt,
|
|
104
|
-
updatedAt: row.updatedAt,
|
|
105
|
-
}));
|
|
106
|
-
}
|
|
107
|
-
async getIncoming(documentId, types, consistencyToken, signal) {
|
|
108
|
-
if (consistencyToken) {
|
|
109
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
110
|
-
}
|
|
111
|
-
if (signal?.aborted) {
|
|
112
|
-
throw new Error("Operation aborted");
|
|
113
|
-
}
|
|
114
|
-
let query = this.db
|
|
115
|
-
.selectFrom("DocumentRelationship")
|
|
116
|
-
.selectAll()
|
|
117
|
-
.where("targetId", "=", documentId);
|
|
118
|
-
if (types && types.length > 0) {
|
|
119
|
-
query = query.where("relationshipType", "in", types);
|
|
120
|
-
}
|
|
121
|
-
const rows = await query.execute();
|
|
122
|
-
return rows.map((row) => ({
|
|
123
|
-
sourceId: row.sourceId,
|
|
124
|
-
targetId: row.targetId,
|
|
125
|
-
relationshipType: row.relationshipType,
|
|
126
|
-
metadata: row.metadata
|
|
127
|
-
? row.metadata
|
|
128
|
-
: undefined,
|
|
129
|
-
createdAt: row.createdAt,
|
|
130
|
-
updatedAt: row.updatedAt,
|
|
131
|
-
}));
|
|
132
|
-
}
|
|
133
|
-
async hasRelationship(sourceId, targetId, types, consistencyToken, signal) {
|
|
134
|
-
if (consistencyToken) {
|
|
135
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
136
|
-
}
|
|
137
|
-
if (signal?.aborted) {
|
|
138
|
-
throw new Error("Operation aborted");
|
|
139
|
-
}
|
|
140
|
-
let query = this.db
|
|
141
|
-
.selectFrom("DocumentRelationship")
|
|
142
|
-
.select("id")
|
|
143
|
-
.where("sourceId", "=", sourceId)
|
|
144
|
-
.where("targetId", "=", targetId);
|
|
145
|
-
if (types && types.length > 0) {
|
|
146
|
-
query = query.where("relationshipType", "in", types);
|
|
147
|
-
}
|
|
148
|
-
const result = await query.executeTakeFirst();
|
|
149
|
-
return result !== undefined;
|
|
150
|
-
}
|
|
151
|
-
async getUndirectedRelationships(a, b, types, consistencyToken, signal) {
|
|
152
|
-
if (consistencyToken) {
|
|
153
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
154
|
-
}
|
|
155
|
-
if (signal?.aborted) {
|
|
156
|
-
throw new Error("Operation aborted");
|
|
157
|
-
}
|
|
158
|
-
let query = this.db
|
|
159
|
-
.selectFrom("DocumentRelationship")
|
|
160
|
-
.selectAll()
|
|
161
|
-
.where((eb) => eb.or([
|
|
162
|
-
eb.and([eb("sourceId", "=", a), eb("targetId", "=", b)]),
|
|
163
|
-
eb.and([eb("sourceId", "=", b), eb("targetId", "=", a)]),
|
|
164
|
-
]));
|
|
165
|
-
if (types && types.length > 0) {
|
|
166
|
-
query = query.where("relationshipType", "in", types);
|
|
167
|
-
}
|
|
168
|
-
const rows = await query.execute();
|
|
169
|
-
return rows.map((row) => ({
|
|
170
|
-
sourceId: row.sourceId,
|
|
171
|
-
targetId: row.targetId,
|
|
172
|
-
relationshipType: row.relationshipType,
|
|
173
|
-
metadata: row.metadata
|
|
174
|
-
? row.metadata
|
|
175
|
-
: undefined,
|
|
176
|
-
createdAt: row.createdAt,
|
|
177
|
-
updatedAt: row.updatedAt,
|
|
178
|
-
}));
|
|
179
|
-
}
|
|
180
|
-
async getDirectedRelationships(sourceId, targetId, types, consistencyToken, signal) {
|
|
181
|
-
if (consistencyToken) {
|
|
182
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
183
|
-
}
|
|
184
|
-
if (signal?.aborted) {
|
|
185
|
-
throw new Error("Operation aborted");
|
|
186
|
-
}
|
|
187
|
-
let query = this.db
|
|
188
|
-
.selectFrom("DocumentRelationship")
|
|
189
|
-
.selectAll()
|
|
190
|
-
.where("sourceId", "=", sourceId)
|
|
191
|
-
.where("targetId", "=", targetId);
|
|
192
|
-
if (types && types.length > 0) {
|
|
193
|
-
query = query.where("relationshipType", "in", types);
|
|
194
|
-
}
|
|
195
|
-
const rows = await query.execute();
|
|
196
|
-
return rows.map((row) => ({
|
|
197
|
-
sourceId: row.sourceId,
|
|
198
|
-
targetId: row.targetId,
|
|
199
|
-
relationshipType: row.relationshipType,
|
|
200
|
-
metadata: row.metadata
|
|
201
|
-
? row.metadata
|
|
202
|
-
: undefined,
|
|
203
|
-
createdAt: row.createdAt,
|
|
204
|
-
updatedAt: row.updatedAt,
|
|
205
|
-
}));
|
|
206
|
-
}
|
|
207
|
-
async findPath(sourceId, targetId, types, consistencyToken, signal) {
|
|
208
|
-
if (consistencyToken) {
|
|
209
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
210
|
-
}
|
|
211
|
-
if (signal?.aborted) {
|
|
212
|
-
throw new Error("Operation aborted");
|
|
213
|
-
}
|
|
214
|
-
if (sourceId === targetId) {
|
|
215
|
-
return [sourceId];
|
|
216
|
-
}
|
|
217
|
-
const visited = new Set();
|
|
218
|
-
const queue = [
|
|
219
|
-
{ id: sourceId, path: [sourceId] },
|
|
220
|
-
];
|
|
221
|
-
while (queue.length > 0) {
|
|
222
|
-
const current = queue.shift();
|
|
223
|
-
if (current.id === targetId) {
|
|
224
|
-
return current.path;
|
|
225
|
-
}
|
|
226
|
-
if (visited.has(current.id)) {
|
|
227
|
-
continue;
|
|
228
|
-
}
|
|
229
|
-
visited.add(current.id);
|
|
230
|
-
const outgoing = await this.getOutgoing(current.id, types, undefined, signal);
|
|
231
|
-
for (const rel of outgoing) {
|
|
232
|
-
if (!visited.has(rel.targetId)) {
|
|
233
|
-
queue.push({
|
|
234
|
-
id: rel.targetId,
|
|
235
|
-
path: [...current.path, rel.targetId],
|
|
236
|
-
});
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
return null;
|
|
241
|
-
}
|
|
242
|
-
async findAncestors(documentId, types, consistencyToken, signal) {
|
|
243
|
-
if (consistencyToken) {
|
|
244
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
245
|
-
}
|
|
246
|
-
if (signal?.aborted) {
|
|
247
|
-
throw new Error("Operation aborted");
|
|
248
|
-
}
|
|
249
|
-
const nodes = new Set([documentId]);
|
|
250
|
-
const edges = [];
|
|
251
|
-
const queue = [documentId];
|
|
252
|
-
const visited = new Set();
|
|
253
|
-
while (queue.length > 0) {
|
|
254
|
-
const currentId = queue.shift();
|
|
255
|
-
if (visited.has(currentId)) {
|
|
256
|
-
continue;
|
|
257
|
-
}
|
|
258
|
-
visited.add(currentId);
|
|
259
|
-
const incoming = await this.getIncoming(currentId, types, undefined, signal);
|
|
260
|
-
for (const rel of incoming) {
|
|
261
|
-
nodes.add(rel.sourceId);
|
|
262
|
-
edges.push({
|
|
263
|
-
from: rel.sourceId,
|
|
264
|
-
to: rel.targetId,
|
|
265
|
-
type: rel.relationshipType,
|
|
266
|
-
});
|
|
267
|
-
if (!visited.has(rel.sourceId)) {
|
|
268
|
-
queue.push(rel.sourceId);
|
|
269
|
-
}
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
return {
|
|
273
|
-
nodes: Array.from(nodes),
|
|
274
|
-
edges,
|
|
275
|
-
};
|
|
276
|
-
}
|
|
277
|
-
async getRelationshipTypes(consistencyToken, signal) {
|
|
278
|
-
if (consistencyToken) {
|
|
279
|
-
await this.waitForConsistency(consistencyToken, undefined, signal);
|
|
280
|
-
}
|
|
281
|
-
if (signal?.aborted) {
|
|
282
|
-
throw new Error("Operation aborted");
|
|
283
|
-
}
|
|
284
|
-
const rows = await this.db
|
|
285
|
-
.selectFrom("DocumentRelationship")
|
|
286
|
-
.select("relationshipType")
|
|
287
|
-
.distinct()
|
|
288
|
-
.execute();
|
|
289
|
-
return rows.map((row) => row.relationshipType);
|
|
290
|
-
}
|
|
291
|
-
async handleAddRelationship(trx, operation) {
|
|
292
|
-
const input = operation.action.input;
|
|
293
|
-
const existingDoc = await trx
|
|
294
|
-
.selectFrom("Document")
|
|
295
|
-
.select("id")
|
|
296
|
-
.where("id", "=", input.sourceId)
|
|
297
|
-
.executeTakeFirst();
|
|
298
|
-
if (!existingDoc) {
|
|
299
|
-
await trx
|
|
300
|
-
.insertInto("Document")
|
|
301
|
-
.values({
|
|
302
|
-
id: input.sourceId,
|
|
303
|
-
})
|
|
304
|
-
.execute();
|
|
305
|
-
}
|
|
306
|
-
const existingTargetDoc = await trx
|
|
307
|
-
.selectFrom("Document")
|
|
308
|
-
.select("id")
|
|
309
|
-
.where("id", "=", input.targetId)
|
|
310
|
-
.executeTakeFirst();
|
|
311
|
-
if (!existingTargetDoc) {
|
|
312
|
-
await trx
|
|
313
|
-
.insertInto("Document")
|
|
314
|
-
.values({
|
|
315
|
-
id: input.targetId,
|
|
316
|
-
})
|
|
317
|
-
.execute();
|
|
318
|
-
}
|
|
319
|
-
const existingRel = await trx
|
|
320
|
-
.selectFrom("DocumentRelationship")
|
|
321
|
-
.select("id")
|
|
322
|
-
.where("sourceId", "=", input.sourceId)
|
|
323
|
-
.where("targetId", "=", input.targetId)
|
|
324
|
-
.where("relationshipType", "=", input.relationshipType)
|
|
325
|
-
.executeTakeFirst();
|
|
326
|
-
if (!existingRel) {
|
|
327
|
-
const relationship = {
|
|
328
|
-
id: uuidv4(),
|
|
329
|
-
sourceId: input.sourceId,
|
|
330
|
-
targetId: input.targetId,
|
|
331
|
-
relationshipType: input.relationshipType,
|
|
332
|
-
metadata: input.metadata || null,
|
|
333
|
-
};
|
|
334
|
-
await trx
|
|
335
|
-
.insertInto("DocumentRelationship")
|
|
336
|
-
.values(relationship)
|
|
337
|
-
.execute();
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
async handleRemoveRelationship(trx, operation) {
|
|
341
|
-
const input = operation.action.input;
|
|
342
|
-
await trx
|
|
343
|
-
.deleteFrom("DocumentRelationship")
|
|
344
|
-
.where("sourceId", "=", input.sourceId)
|
|
345
|
-
.where("targetId", "=", input.targetId)
|
|
346
|
-
.where("relationshipType", "=", input.relationshipType)
|
|
347
|
-
.execute();
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
//# sourceMappingURL=document-indexer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"document-indexer.js","sourceRoot":"","sources":["../../../../src/storage/kysely/document-indexer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAsBpC,MAAM,OAAO,qBAAqB;IAItB;IACA;IACA;IALF,eAAe,GAAW,CAAC,CAAC;IAEpC,YACU,EAAoB,EACpB,cAA+B,EAC/B,kBAAuC;QAFvC,OAAE,GAAF,EAAE,CAAkB;QACpB,mBAAc,GAAd,cAAc,CAAiB;QAC/B,uBAAkB,GAAlB,kBAAkB,CAAqB;IAC9C,CAAC;IAEJ,KAAK,CAAC,IAAI;QACR,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,EAAE;aAC/B,UAAU,CAAC,cAAc,CAAC;aAC1B,SAAS,EAAE;aACX,gBAAgB,EAAE,CAAC;QAEtB,IAAI,YAAY,EAAE,CAAC;YACjB,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,eAAe,CAAC;YAEpD,MAAM,gBAAgB,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,UAAU,CAC3D,IAAI,CAAC,eAAe,CACrB,CAAC;YAEF,IAAI,gBAAgB,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YACrD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,CAAC,EAAE;iBACV,UAAU,CAAC,cAAc,CAAC;iBAC1B,MAAM,CAAC;gBACN,eAAe,EAAE,CAAC;aACnB,CAAC;iBACD,OAAO,EAAE,CAAC;YAEb,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAC9D,IAAI,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACnC,MAAM,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAA6B;QACjD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAE/B,MAAM,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YAChD,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC;gBAC3B,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;gBAEzC,IAAI,UAAU,KAAK,kBAAkB,EAAE,CAAC;oBACtC,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;gBACnD,CAAC;qBAAM,IAAI,UAAU,KAAK,qBAAqB,EAAE,CAAC;oBAChD,MAAM,IAAI,CAAC,wBAAwB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;gBACtD,CAAC;YACH,CAAC;YAED,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC;YACtD,IAAI,QAAQ,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE,CAAC;gBAC7C,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC;gBAChC,MAAM,GAAG;qBACN,WAAW,CAAC,cAAc,CAAC;qBAC3B,GAAG,CAAC;oBACH,eAAe,EAAE,QAAQ;oBACzB,sBAAsB,EAAE,IAAI,IAAI,EAAE;iBACnC,CAAC;qBACD,OAAO,EAAE,CAAC;YACf,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,WAAW,GAA4B,EAAE,CAAC;QAChD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAE,CAAC;YACvB,WAAW,CAAC,IAAI,CAAC;gBACf,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU;gBACnC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK;gBACzB,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;gBAC3B,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK;aACrC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC;IAED,KAAK,CAAC,kBAAkB,CACtB,KAAuB,EACvB,SAAkB,EAClB,MAAoB;QAEpB,IAAI,KAAK,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QACD,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;IAC9E,CAAC;IAED,KAAK,CAAC,WAAW,CACf,UAAkB,EAClB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QACD,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,sBAAsB,CAAC;aAClC,SAAS,EAAE;aACX,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;QAEtC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;QAEnC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;YACtC,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACpB,CAAC,CAAE,GAAG,CAAC,QAAoC;gBAC3C,CAAC,CAAC,SAAS;YACb,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,KAAK,CAAC,WAAW,CACf,UAAkB,EAClB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,sBAAsB,CAAC;aAClC,SAAS,EAAE;aACX,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;QAEtC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;QAEnC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;YACtC,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACpB,CAAC,CAAE,GAAG,CAAC,QAAoC;gBAC3C,CAAC,CAAC,SAAS;YACb,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,QAAgB,EAChB,QAAgB,EAChB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,sBAAsB,CAAC;aAClC,MAAM,CAAC,IAAI,CAAC;aACZ,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,CAAC;aAChC,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;QAEpC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAE9C,OAAO,MAAM,KAAK,SAAS,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,0BAA0B,CAC9B,CAAS,EACT,CAAS,EACT,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,sBAAsB,CAAC;aAClC,SAAS,EAAE;aACX,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,CACZ,EAAE,CAAC,EAAE,CAAC;YACJ,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YACxD,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;SACzD,CAAC,CACH,CAAC;QAEJ,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;QAEnC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;YACtC,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACpB,CAAC,CAAE,GAAG,CAAC,QAAoC;gBAC3C,CAAC,CAAC,SAAS;YACb,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC5B,QAAgB,EAChB,QAAgB,EAChB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,sBAAsB,CAAC;aAClC,SAAS,EAAE;aACX,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,CAAC;aAChC,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;QAEpC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;QAEnC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACxB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,gBAAgB,EAAE,GAAG,CAAC,gBAAgB;YACtC,QAAQ,EAAE,GAAG,CAAC,QAAQ;gBACpB,CAAC,CAAE,GAAG,CAAC,QAAoC;gBAC3C,CAAC,CAAC,SAAS;YACb,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IAED,KAAK,CAAC,QAAQ,CACZ,QAAgB,EAChB,QAAgB,EAChB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,QAAQ,KAAK,QAAQ,EAAE,CAAC;YAC1B,OAAO,CAAC,QAAQ,CAAC,CAAC;QACpB,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;QAClC,MAAM,KAAK,GAA0C;YACnD,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,QAAQ,CAAC,EAAE;SACnC,CAAC;QAEF,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,EAAG,CAAC;YAE/B,IAAI,OAAO,CAAC,EAAE,KAAK,QAAQ,EAAE,CAAC;gBAC5B,OAAO,OAAO,CAAC,IAAI,CAAC;YACtB,CAAC;YAED,IAAI,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC5B,SAAS;YACX,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAExB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CACrC,OAAO,CAAC,EAAE,EACV,KAAK,EACL,SAAS,EACT,MAAM,CACP,CAAC;YAEF,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;gBAC3B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC/B,KAAK,CAAC,IAAI,CAAC;wBACT,EAAE,EAAE,GAAG,CAAC,QAAQ;wBAChB,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,QAAQ,CAAC;qBACtC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,aAAa,CACjB,UAAkB,EAClB,KAAgB,EAChB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,GAAG,CAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAwB,EAAE,CAAC;QACtC,MAAM,KAAK,GAAa,CAAC,UAAU,CAAC,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;QAElC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,EAAG,CAAC;YAEjC,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC3B,SAAS;YACX,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAEvB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CACrC,SAAS,EACT,KAAK,EACL,SAAS,EACT,MAAM,CACP,CAAC;YAEF,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;gBAC3B,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACxB,KAAK,CAAC,IAAI,CAAC;oBACT,IAAI,EAAE,GAAG,CAAC,QAAQ;oBAClB,EAAE,EAAE,GAAG,CAAC,QAAQ;oBAChB,IAAI,EAAE,GAAG,CAAC,gBAAgB;iBAC3B,CAAC,CAAC;gBAEH,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC/B,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO;YACL,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;YACxB,KAAK;SACN,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,oBAAoB,CACxB,gBAAmC,EACnC,MAAoB;QAEpB,IAAI,gBAAgB,EAAE,CAAC;YACrB,MAAM,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACrE,CAAC;QAED,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,EAAE;aACvB,UAAU,CAAC,sBAAsB,CAAC;aAClC,MAAM,CAAC,kBAAkB,CAAC;aAC1B,QAAQ,EAAE;aACV,OAAO,EAAE,CAAC;QAEb,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IACjD,CAAC;IAEO,KAAK,CAAC,qBAAqB,CACjC,GAAqB,EACrB,SAAoB;QAEpB,MAAM,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC,KAK9B,CAAC;QAEF,MAAM,WAAW,GAAG,MAAM,GAAG;aAC1B,UAAU,CAAC,UAAU,CAAC;aACtB,MAAM,CAAC,IAAI,CAAC;aACZ,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aAChC,gBAAgB,EAAE,CAAC;QAEtB,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,GAAG;iBACN,UAAU,CAAC,UAAU,CAAC;iBACtB,MAAM,CAAC;gBACN,EAAE,EAAE,KAAK,CAAC,QAAQ;aACnB,CAAC;iBACD,OAAO,EAAE,CAAC;QACf,CAAC;QAED,MAAM,iBAAiB,GAAG,MAAM,GAAG;aAChC,UAAU,CAAC,UAAU,CAAC;aACtB,MAAM,CAAC,IAAI,CAAC;aACZ,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aAChC,gBAAgB,EAAE,CAAC;QAEtB,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACvB,MAAM,GAAG;iBACN,UAAU,CAAC,UAAU,CAAC;iBACtB,MAAM,CAAC;gBACN,EAAE,EAAE,KAAK,CAAC,QAAQ;aACnB,CAAC;iBACD,OAAO,EAAE,CAAC;QACf,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,GAAG;aAC1B,UAAU,CAAC,sBAAsB,CAAC;aAClC,MAAM,CAAC,IAAI,CAAC;aACZ,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aACtC,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aACtC,KAAK,CAAC,kBAAkB,EAAE,GAAG,EAAE,KAAK,CAAC,gBAAgB,CAAC;aACtD,gBAAgB,EAAE,CAAC;QAEtB,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,YAAY,GAAmC;gBACnD,EAAE,EAAE,MAAM,EAAE;gBACZ,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,IAAI;aACjC,CAAC;YAEF,MAAM,GAAG;iBACN,UAAU,CAAC,sBAAsB,CAAC;iBAClC,MAAM,CAAC,YAAY,CAAC;iBACpB,OAAO,EAAE,CAAC;QACf,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,wBAAwB,CACpC,GAAqB,EACrB,SAAoB;QAEpB,MAAM,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC,KAI9B,CAAC;QAEF,MAAM,GAAG;aACN,UAAU,CAAC,sBAAsB,CAAC;aAClC,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aACtC,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,KAAK,CAAC,QAAQ,CAAC;aACtC,KAAK,CAAC,kBAAkB,EAAE,GAAG,EAAE,KAAK,CAAC,gBAAgB,CAAC;aACtD,OAAO,EAAE,CAAC;IACf,CAAC;CACF"}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
export class KyselyKeyframeStore {
|
|
2
|
-
db;
|
|
3
|
-
constructor(db) {
|
|
4
|
-
this.db = db;
|
|
5
|
-
}
|
|
6
|
-
async putKeyframe(documentId, scope, branch, revision, document, signal) {
|
|
7
|
-
if (signal?.aborted) {
|
|
8
|
-
throw new Error("Operation aborted");
|
|
9
|
-
}
|
|
10
|
-
await this.db
|
|
11
|
-
.insertInto("Keyframe")
|
|
12
|
-
.values({
|
|
13
|
-
documentId,
|
|
14
|
-
documentType: document.header.documentType,
|
|
15
|
-
scope,
|
|
16
|
-
branch,
|
|
17
|
-
revision,
|
|
18
|
-
document,
|
|
19
|
-
})
|
|
20
|
-
.onConflict((oc) => oc
|
|
21
|
-
.columns(["documentId", "scope", "branch", "revision"])
|
|
22
|
-
.doUpdateSet({ document }))
|
|
23
|
-
.execute();
|
|
24
|
-
}
|
|
25
|
-
async findNearestKeyframe(documentId, scope, branch, targetRevision, signal) {
|
|
26
|
-
if (signal?.aborted) {
|
|
27
|
-
throw new Error("Operation aborted");
|
|
28
|
-
}
|
|
29
|
-
const row = await this.db
|
|
30
|
-
.selectFrom("Keyframe")
|
|
31
|
-
.selectAll()
|
|
32
|
-
.where("documentId", "=", documentId)
|
|
33
|
-
.where("scope", "=", scope)
|
|
34
|
-
.where("branch", "=", branch)
|
|
35
|
-
.where("revision", "<=", targetRevision)
|
|
36
|
-
.orderBy("revision", "desc")
|
|
37
|
-
.limit(1)
|
|
38
|
-
.executeTakeFirst();
|
|
39
|
-
if (!row) {
|
|
40
|
-
return undefined;
|
|
41
|
-
}
|
|
42
|
-
return {
|
|
43
|
-
revision: row.revision,
|
|
44
|
-
document: row.document,
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
async deleteKeyframes(documentId, scope, branch, signal) {
|
|
48
|
-
if (signal?.aborted) {
|
|
49
|
-
throw new Error("Operation aborted");
|
|
50
|
-
}
|
|
51
|
-
let query = this.db
|
|
52
|
-
.deleteFrom("Keyframe")
|
|
53
|
-
.where("documentId", "=", documentId);
|
|
54
|
-
if (scope !== undefined && branch !== undefined) {
|
|
55
|
-
query = query.where("scope", "=", scope).where("branch", "=", branch);
|
|
56
|
-
}
|
|
57
|
-
else if (scope !== undefined) {
|
|
58
|
-
query = query.where("scope", "=", scope);
|
|
59
|
-
}
|
|
60
|
-
const result = await query.executeTakeFirst();
|
|
61
|
-
return Number(result.numDeletedRows || 0n);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
//# sourceMappingURL=keyframe-store.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"keyframe-store.js","sourceRoot":"","sources":["../../../../src/storage/kysely/keyframe-store.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,mBAAmB;IACV;IAApB,YAAoB,EAAoB;QAApB,OAAE,GAAF,EAAE,CAAkB;IAAG,CAAC;IAE5C,KAAK,CAAC,WAAW,CACf,UAAkB,EAClB,KAAa,EACb,MAAc,EACd,QAAgB,EAChB,QAAoB,EACpB,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,IAAI,CAAC,EAAE;aACV,UAAU,CAAC,UAAU,CAAC;aACtB,MAAM,CAAC;YACN,UAAU;YACV,YAAY,EAAE,QAAQ,CAAC,MAAM,CAAC,YAAY;YAC1C,KAAK;YACL,MAAM;YACN,QAAQ;YACR,QAAQ;SACT,CAAC;aACD,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,CACjB,EAAE;aACC,OAAO,CAAC,CAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;aACtD,WAAW,CAAC,EAAE,QAAQ,EAAE,CAAC,CAC7B;aACA,OAAO,EAAE,CAAC;IACf,CAAC;IAED,KAAK,CAAC,mBAAmB,CACvB,UAAkB,EAClB,KAAa,EACb,MAAc,EACd,cAAsB,EACtB,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,EAAE;aACtB,UAAU,CAAC,UAAU,CAAC;aACtB,SAAS,EAAE;aACX,KAAK,CAAC,YAAY,EAAE,GAAG,EAAE,UAAU,CAAC;aACpC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC;aAC1B,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC;aAC5B,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,CAAC;aACvC,OAAO,CAAC,UAAU,EAAE,MAAM,CAAC;aAC3B,KAAK,CAAC,CAAC,CAAC;aACR,gBAAgB,EAAE,CAAC;QAEtB,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,OAAO;YACL,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAsB;SACrC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,KAAc,EACd,MAAe,EACf,MAAoB;QAEpB,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE;aAChB,UAAU,CAAC,UAAU,CAAC;aACtB,KAAK,CAAC,YAAY,EAAE,GAAG,EAAE,UAAU,CAAC,CAAC;QAExC,IAAI,KAAK,KAAK,SAAS,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;YAChD,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;QACxE,CAAC;aAAM,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAE9C,OAAO,MAAM,CAAC,MAAM,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF"}
|
|
@@ -1,233 +0,0 @@
|
|
|
1
|
-
import {} from "document-model";
|
|
2
|
-
import { DuplicateOperationError, RevisionMismatchError, } from "../interfaces.js";
|
|
3
|
-
import { AtomicTransaction } from "../txn.js";
|
|
4
|
-
export class KyselyOperationStore {
|
|
5
|
-
db;
|
|
6
|
-
constructor(db) {
|
|
7
|
-
this.db = db;
|
|
8
|
-
}
|
|
9
|
-
async apply(documentId, documentType, scope, branch, revision, fn, signal) {
|
|
10
|
-
await this.db.transaction().execute(async (trx) => {
|
|
11
|
-
// Check for abort signal
|
|
12
|
-
if (signal?.aborted) {
|
|
13
|
-
throw new Error("Operation aborted");
|
|
14
|
-
}
|
|
15
|
-
// Get the latest operation for this stream to verify revision
|
|
16
|
-
const latestOp = await trx
|
|
17
|
-
.selectFrom("Operation")
|
|
18
|
-
.selectAll()
|
|
19
|
-
.where("documentId", "=", documentId)
|
|
20
|
-
.where("scope", "=", scope)
|
|
21
|
-
.where("branch", "=", branch)
|
|
22
|
-
.orderBy("index", "desc")
|
|
23
|
-
.limit(1)
|
|
24
|
-
.executeTakeFirst();
|
|
25
|
-
// Check revision matches
|
|
26
|
-
const currentRevision = latestOp ? latestOp.index : -1;
|
|
27
|
-
if (currentRevision !== revision - 1) {
|
|
28
|
-
throw new RevisionMismatchError(currentRevision + 1, revision);
|
|
29
|
-
}
|
|
30
|
-
// Create atomic transaction
|
|
31
|
-
const atomicTxn = new AtomicTransaction(documentId, documentType, scope, branch, revision);
|
|
32
|
-
await fn(atomicTxn);
|
|
33
|
-
// Get operations and header updates
|
|
34
|
-
const operations = atomicTxn.getOperations();
|
|
35
|
-
// Insert operations
|
|
36
|
-
if (operations.length > 0) {
|
|
37
|
-
// Set prevOpId for each operation
|
|
38
|
-
let prevOpId = latestOp?.opId || "";
|
|
39
|
-
for (const op of operations) {
|
|
40
|
-
op.prevOpId = prevOpId;
|
|
41
|
-
prevOpId = op.opId;
|
|
42
|
-
}
|
|
43
|
-
try {
|
|
44
|
-
await trx.insertInto("Operation").values(operations).execute();
|
|
45
|
-
}
|
|
46
|
-
catch (error) {
|
|
47
|
-
if (error instanceof Error) {
|
|
48
|
-
if (error.message.includes("unique constraint")) {
|
|
49
|
-
const op = operations[0];
|
|
50
|
-
throw new DuplicateOperationError(`${op.opId} at index ${op.index} with skip ${op.skip}`);
|
|
51
|
-
}
|
|
52
|
-
throw error;
|
|
53
|
-
}
|
|
54
|
-
throw error;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
async getSince(documentId, scope, branch, revision, paging, signal) {
|
|
60
|
-
if (signal?.aborted) {
|
|
61
|
-
throw new Error("Operation aborted");
|
|
62
|
-
}
|
|
63
|
-
let query = this.db
|
|
64
|
-
.selectFrom("Operation")
|
|
65
|
-
.selectAll()
|
|
66
|
-
.where("documentId", "=", documentId)
|
|
67
|
-
.where("scope", "=", scope)
|
|
68
|
-
.where("branch", "=", branch)
|
|
69
|
-
.where("index", ">", revision)
|
|
70
|
-
.orderBy("index", "asc");
|
|
71
|
-
// Handle cursor-based pagination
|
|
72
|
-
if (paging) {
|
|
73
|
-
// Cursor encodes the last seen index
|
|
74
|
-
if (paging.cursor) {
|
|
75
|
-
const lastIndex = Number.parseInt(paging.cursor, 10);
|
|
76
|
-
query = query.where("index", ">", lastIndex);
|
|
77
|
-
}
|
|
78
|
-
// Apply limit if specified (fetch one extra to determine hasMore)
|
|
79
|
-
if (paging.limit) {
|
|
80
|
-
query = query.limit(paging.limit + 1);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
const rows = await query.execute();
|
|
84
|
-
// Determine if there are more results
|
|
85
|
-
let hasMore = false;
|
|
86
|
-
let items = rows;
|
|
87
|
-
if (paging?.limit && rows.length > paging.limit) {
|
|
88
|
-
hasMore = true;
|
|
89
|
-
items = rows.slice(0, paging.limit);
|
|
90
|
-
}
|
|
91
|
-
// Generate next cursor from last item's index
|
|
92
|
-
const nextCursor = hasMore && items.length > 0
|
|
93
|
-
? items[items.length - 1].index.toString()
|
|
94
|
-
: undefined;
|
|
95
|
-
return {
|
|
96
|
-
items: items.map((row) => this.rowToOperation(row)),
|
|
97
|
-
nextCursor,
|
|
98
|
-
hasMore,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
async getSinceId(id, paging, signal) {
|
|
102
|
-
if (signal?.aborted) {
|
|
103
|
-
throw new Error("Operation aborted");
|
|
104
|
-
}
|
|
105
|
-
let query = this.db
|
|
106
|
-
.selectFrom("Operation")
|
|
107
|
-
.selectAll()
|
|
108
|
-
.where("id", ">", id)
|
|
109
|
-
.orderBy("id", "asc");
|
|
110
|
-
// Handle cursor-based pagination
|
|
111
|
-
if (paging) {
|
|
112
|
-
// Cursor encodes the last seen id
|
|
113
|
-
if (paging.cursor) {
|
|
114
|
-
const lastId = Number.parseInt(paging.cursor, 10);
|
|
115
|
-
query = query.where("id", ">", lastId);
|
|
116
|
-
}
|
|
117
|
-
// Apply limit if specified (fetch one extra to determine hasMore)
|
|
118
|
-
if (paging.limit) {
|
|
119
|
-
query = query.limit(paging.limit + 1);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
const rows = await query.execute();
|
|
123
|
-
// Determine if there are more results
|
|
124
|
-
let hasMore = false;
|
|
125
|
-
let items = rows;
|
|
126
|
-
if (paging?.limit && rows.length > paging.limit) {
|
|
127
|
-
hasMore = true;
|
|
128
|
-
items = rows.slice(0, paging.limit);
|
|
129
|
-
}
|
|
130
|
-
// Generate next cursor from last item's id
|
|
131
|
-
const nextCursor = hasMore && items.length > 0
|
|
132
|
-
? items[items.length - 1].id.toString()
|
|
133
|
-
: undefined;
|
|
134
|
-
return {
|
|
135
|
-
items: items.map((row) => this.rowToOperationWithContext(row)),
|
|
136
|
-
nextCursor,
|
|
137
|
-
hasMore,
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
async getConflicting(documentId, scope, branch, minTimestamp, paging, signal) {
|
|
141
|
-
if (signal?.aborted) {
|
|
142
|
-
throw new Error("Operation aborted");
|
|
143
|
-
}
|
|
144
|
-
let query = this.db
|
|
145
|
-
.selectFrom("Operation")
|
|
146
|
-
.selectAll()
|
|
147
|
-
.where("documentId", "=", documentId)
|
|
148
|
-
.where("scope", "=", scope)
|
|
149
|
-
.where("branch", "=", branch)
|
|
150
|
-
.where("timestampUtcMs", ">=", new Date(minTimestamp))
|
|
151
|
-
.orderBy("index", "asc");
|
|
152
|
-
if (paging) {
|
|
153
|
-
if (paging.cursor) {
|
|
154
|
-
const lastIndex = Number.parseInt(paging.cursor, 10);
|
|
155
|
-
query = query.where("index", ">", lastIndex);
|
|
156
|
-
}
|
|
157
|
-
if (paging.limit) {
|
|
158
|
-
query = query.limit(paging.limit + 1);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
const rows = await query.execute();
|
|
162
|
-
let hasMore = false;
|
|
163
|
-
let items = rows;
|
|
164
|
-
if (paging?.limit && rows.length > paging.limit) {
|
|
165
|
-
hasMore = true;
|
|
166
|
-
items = rows.slice(0, paging.limit);
|
|
167
|
-
}
|
|
168
|
-
const nextCursor = hasMore && items.length > 0
|
|
169
|
-
? items[items.length - 1].index.toString()
|
|
170
|
-
: undefined;
|
|
171
|
-
return {
|
|
172
|
-
items: items.map((row) => this.rowToOperation(row)),
|
|
173
|
-
nextCursor,
|
|
174
|
-
hasMore,
|
|
175
|
-
};
|
|
176
|
-
}
|
|
177
|
-
async getRevisions(documentId, branch, signal) {
|
|
178
|
-
if (signal?.aborted) {
|
|
179
|
-
throw new Error("Operation aborted");
|
|
180
|
-
}
|
|
181
|
-
// Get the latest operation for each scope in a single query
|
|
182
|
-
// Uses a subquery to find operations where the index equals the max index for that scope
|
|
183
|
-
const scopeRevisions = await this.db
|
|
184
|
-
.selectFrom("Operation as o1")
|
|
185
|
-
.select(["o1.scope", "o1.index", "o1.timestampUtcMs"])
|
|
186
|
-
.where("o1.documentId", "=", documentId)
|
|
187
|
-
.where("o1.branch", "=", branch)
|
|
188
|
-
.where((eb) => eb("o1.index", "=", eb
|
|
189
|
-
.selectFrom("Operation as o2")
|
|
190
|
-
.select((eb2) => eb2.fn.max("o2.index").as("maxIndex"))
|
|
191
|
-
.where("o2.documentId", "=", eb.ref("o1.documentId"))
|
|
192
|
-
.where("o2.branch", "=", eb.ref("o1.branch"))
|
|
193
|
-
.where("o2.scope", "=", eb.ref("o1.scope"))))
|
|
194
|
-
.execute();
|
|
195
|
-
const revision = {};
|
|
196
|
-
let latestTimestamp = new Date(0).toISOString();
|
|
197
|
-
for (const row of scopeRevisions) {
|
|
198
|
-
revision[row.scope] = row.index + 1;
|
|
199
|
-
const timestamp = row.timestampUtcMs.toISOString();
|
|
200
|
-
if (timestamp > latestTimestamp) {
|
|
201
|
-
latestTimestamp = timestamp;
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
return {
|
|
205
|
-
revision,
|
|
206
|
-
latestTimestamp,
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
rowToOperation(row) {
|
|
210
|
-
return {
|
|
211
|
-
index: row.index,
|
|
212
|
-
timestampUtcMs: row.timestampUtcMs.toISOString(),
|
|
213
|
-
hash: row.hash,
|
|
214
|
-
skip: row.skip,
|
|
215
|
-
error: row.error || undefined,
|
|
216
|
-
id: row.opId,
|
|
217
|
-
action: row.action,
|
|
218
|
-
};
|
|
219
|
-
}
|
|
220
|
-
rowToOperationWithContext(row) {
|
|
221
|
-
return {
|
|
222
|
-
operation: this.rowToOperation(row),
|
|
223
|
-
context: {
|
|
224
|
-
documentId: row.documentId,
|
|
225
|
-
documentType: row.documentType,
|
|
226
|
-
scope: row.scope,
|
|
227
|
-
branch: row.branch,
|
|
228
|
-
ordinal: row.id,
|
|
229
|
-
},
|
|
230
|
-
};
|
|
231
|
-
}
|
|
232
|
-
}
|
|
233
|
-
//# sourceMappingURL=store.js.map
|