@rocicorp/zero 0.0.2024100800 → 0.0.202410040736
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/package.json +6 -8
- package/out/btree/b+tree.d.ts +0 -471
- package/out/btree/b+tree.d.ts.map +0 -1
- package/out/btree/b+tree.js +0 -1708
- package/out/btree/b+tree.js.map +0 -1
- package/out/btree/interfaces.d.ts +0 -270
- package/out/btree/interfaces.d.ts.map +0 -1
- package/out/btree/interfaces.js +0 -3
- package/out/btree/interfaces.js.map +0 -1
- package/out/btree/src/mod.d.ts +0 -2
- package/out/btree/src/mod.d.ts.map +0 -1
- package/out/btree/src/mod.js +0 -2
- package/out/btree/src/mod.js.map +0 -1
- package/out/chunk-2RUT5EQV.js +0 -28
- package/out/chunk-2RUT5EQV.js.map +0 -7
- package/out/datadog/src/datadog-log-sink.d.ts +0 -20
- package/out/datadog/src/datadog-log-sink.d.ts.map +0 -1
- package/out/datadog/src/datadog-log-sink.js +0 -231
- package/out/datadog/src/datadog-log-sink.js.map +0 -1
- package/out/datadog/src/mod.d.ts +0 -2
- package/out/datadog/src/mod.d.ts.map +0 -1
- package/out/datadog/src/mod.js +0 -2
- package/out/datadog/src/mod.js.map +0 -1
- package/out/react.js +0 -114
- package/out/react.js.map +0 -7
- package/out/replicache/src/async-iterable-to-array.d.ts +0 -2
- package/out/replicache/src/async-iterable-to-array.d.ts.map +0 -1
- package/out/replicache/src/bg-interval.d.ts +0 -3
- package/out/replicache/src/bg-interval.d.ts.map +0 -1
- package/out/replicache/src/binary-search.d.ts +0 -15
- package/out/replicache/src/binary-search.d.ts.map +0 -1
- package/out/replicache/src/broadcast-channel.d.ts +0 -3
- package/out/replicache/src/broadcast-channel.d.ts.map +0 -1
- package/out/replicache/src/btree/diff.d.ts +0 -4
- package/out/replicache/src/btree/diff.d.ts.map +0 -1
- package/out/replicache/src/btree/node.d.ts +0 -125
- package/out/replicache/src/btree/node.d.ts.map +0 -1
- package/out/replicache/src/btree/read.d.ts +0 -32
- package/out/replicache/src/btree/read.d.ts.map +0 -1
- package/out/replicache/src/btree/splice.d.ts +0 -9
- package/out/replicache/src/btree/splice.d.ts.map +0 -1
- package/out/replicache/src/btree/write.d.ts +0 -24
- package/out/replicache/src/btree/write.d.ts.map +0 -1
- package/out/replicache/src/call-default-fetch.d.ts +0 -6
- package/out/replicache/src/call-default-fetch.d.ts.map +0 -1
- package/out/replicache/src/config.d.ts +0 -13
- package/out/replicache/src/config.d.ts.map +0 -1
- package/out/replicache/src/connection-loop-delegates.d.ts +0 -20
- package/out/replicache/src/connection-loop-delegates.d.ts.map +0 -1
- package/out/replicache/src/connection-loop.d.ts +0 -28
- package/out/replicache/src/connection-loop.d.ts.map +0 -1
- package/out/replicache/src/cookies.d.ts +0 -29
- package/out/replicache/src/cookies.d.ts.map +0 -1
- package/out/replicache/src/dag/chunk.d.ts +0 -35
- package/out/replicache/src/dag/chunk.d.ts.map +0 -1
- package/out/replicache/src/dag/gc.d.ts +0 -42
- package/out/replicache/src/dag/gc.d.ts.map +0 -1
- package/out/replicache/src/dag/key-type-enum.d.ts +0 -10
- package/out/replicache/src/dag/key-type-enum.d.ts.map +0 -1
- package/out/replicache/src/dag/key.d.ts +0 -21
- package/out/replicache/src/dag/key.d.ts.map +0 -1
- package/out/replicache/src/dag/lazy-store.d.ts +0 -181
- package/out/replicache/src/dag/lazy-store.d.ts.map +0 -1
- package/out/replicache/src/dag/store-impl.d.ts +0 -38
- package/out/replicache/src/dag/store-impl.d.ts.map +0 -1
- package/out/replicache/src/dag/store.d.ts +0 -36
- package/out/replicache/src/dag/store.d.ts.map +0 -1
- package/out/replicache/src/dag/visitor.d.ts +0 -13
- package/out/replicache/src/dag/visitor.d.ts.map +0 -1
- package/out/replicache/src/db/commit.d.ts +0 -127
- package/out/replicache/src/db/commit.d.ts.map +0 -1
- package/out/replicache/src/db/index-operation-enum.d.ts +0 -6
- package/out/replicache/src/db/index-operation-enum.d.ts.map +0 -1
- package/out/replicache/src/db/index.d.ts +0 -30
- package/out/replicache/src/db/index.d.ts.map +0 -1
- package/out/replicache/src/db/meta-type-enum.d.ts +0 -12
- package/out/replicache/src/db/meta-type-enum.d.ts.map +0 -1
- package/out/replicache/src/db/read.d.ts +0 -24
- package/out/replicache/src/db/read.d.ts.map +0 -1
- package/out/replicache/src/db/rebase.d.ts +0 -10
- package/out/replicache/src/db/rebase.d.ts.map +0 -1
- package/out/replicache/src/db/scan.d.ts +0 -15
- package/out/replicache/src/db/scan.d.ts.map +0 -1
- package/out/replicache/src/db/write.d.ts +0 -39
- package/out/replicache/src/db/write.d.ts.map +0 -1
- package/out/replicache/src/error-responses.d.ts +0 -26
- package/out/replicache/src/error-responses.d.ts.map +0 -1
- package/out/replicache/src/filter-async-iterable.d.ts +0 -10
- package/out/replicache/src/filter-async-iterable.d.ts.map +0 -1
- package/out/replicache/src/format-version-enum.d.ts +0 -13
- package/out/replicache/src/format-version-enum.d.ts.map +0 -1
- package/out/replicache/src/format-version.d.ts +0 -3
- package/out/replicache/src/format-version.d.ts.map +0 -1
- package/out/replicache/src/frozen-json.d.ts +0 -35
- package/out/replicache/src/frozen-json.d.ts.map +0 -1
- package/out/replicache/src/get-default-puller.d.ts +0 -14
- package/out/replicache/src/get-default-puller.d.ts.map +0 -1
- package/out/replicache/src/get-default-pusher.d.ts +0 -10
- package/out/replicache/src/get-default-pusher.d.ts.map +0 -1
- package/out/replicache/src/hash.d.ts +0 -29
- package/out/replicache/src/hash.d.ts.map +0 -1
- package/out/replicache/src/http-request-info.d.ts +0 -6
- package/out/replicache/src/http-request-info.d.ts.map +0 -1
- package/out/replicache/src/impl.d.ts +0 -4
- package/out/replicache/src/impl.d.ts.map +0 -1
- package/out/replicache/src/index-defs.d.ts +0 -36
- package/out/replicache/src/index-defs.d.ts.map +0 -1
- package/out/replicache/src/invoke-kind-enum.d.ts +0 -6
- package/out/replicache/src/invoke-kind-enum.d.ts.map +0 -1
- package/out/replicache/src/iterable-union.d.ts +0 -5
- package/out/replicache/src/iterable-union.d.ts.map +0 -1
- package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts +0 -25
- package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts.map +0 -1
- package/out/replicache/src/kv/idb-store.d.ts +0 -18
- package/out/replicache/src/kv/idb-store.d.ts.map +0 -1
- package/out/replicache/src/kv/mem-store.d.ts +0 -23
- package/out/replicache/src/kv/mem-store.d.ts.map +0 -1
- package/out/replicache/src/kv/read-impl.d.ts +0 -11
- package/out/replicache/src/kv/read-impl.d.ts.map +0 -1
- package/out/replicache/src/kv/store.d.ts +0 -76
- package/out/replicache/src/kv/store.d.ts.map +0 -1
- package/out/replicache/src/kv/write-impl-base.d.ts +0 -18
- package/out/replicache/src/kv/write-impl-base.d.ts.map +0 -1
- package/out/replicache/src/kv/write-impl.d.ts +0 -9
- package/out/replicache/src/kv/write-impl.d.ts.map +0 -1
- package/out/replicache/src/lazy.d.ts +0 -2
- package/out/replicache/src/lazy.d.ts.map +0 -1
- package/out/replicache/src/log-options.d.ts +0 -10
- package/out/replicache/src/log-options.d.ts.map +0 -1
- package/out/replicache/src/merge-async-iterables.d.ts +0 -16
- package/out/replicache/src/merge-async-iterables.d.ts.map +0 -1
- package/out/replicache/src/mod.d.ts +0 -38
- package/out/replicache/src/mod.d.ts.map +0 -1
- package/out/replicache/src/mutation-recovery.d.ts +0 -43
- package/out/replicache/src/mutation-recovery.d.ts.map +0 -1
- package/out/replicache/src/new-client-channel.d.ts +0 -6
- package/out/replicache/src/new-client-channel.d.ts.map +0 -1
- package/out/replicache/src/on-persist-channel.d.ts +0 -10
- package/out/replicache/src/on-persist-channel.d.ts.map +0 -1
- package/out/replicache/src/patch-operation.d.ts +0 -32
- package/out/replicache/src/patch-operation.d.ts.map +0 -1
- package/out/replicache/src/pending-mutations.d.ts +0 -14
- package/out/replicache/src/pending-mutations.d.ts.map +0 -1
- package/out/replicache/src/persist/client-gc.d.ts +0 -17
- package/out/replicache/src/persist/client-gc.d.ts.map +0 -1
- package/out/replicache/src/persist/client-group-gc.d.ts +0 -10
- package/out/replicache/src/persist/client-group-gc.d.ts.map +0 -1
- package/out/replicache/src/persist/client-groups.d.ts +0 -72
- package/out/replicache/src/persist/client-groups.d.ts.map +0 -1
- package/out/replicache/src/persist/clients.d.ts +0 -155
- package/out/replicache/src/persist/clients.d.ts.map +0 -1
- package/out/replicache/src/persist/collect-idb-databases.d.ts +0 -91
- package/out/replicache/src/persist/collect-idb-databases.d.ts.map +0 -1
- package/out/replicache/src/persist/gather-mem-only-visitor.d.ts +0 -12
- package/out/replicache/src/persist/gather-mem-only-visitor.d.ts.map +0 -1
- package/out/replicache/src/persist/gather-not-cached-visitor.d.ts +0 -17
- package/out/replicache/src/persist/gather-not-cached-visitor.d.ts.map +0 -1
- package/out/replicache/src/persist/heartbeat.d.ts +0 -9
- package/out/replicache/src/persist/heartbeat.d.ts.map +0 -1
- package/out/replicache/src/persist/idb-databases-store-db-name.d.ts +0 -5
- package/out/replicache/src/persist/idb-databases-store-db-name.d.ts.map +0 -1
- package/out/replicache/src/persist/idb-databases-store.d.ts +0 -24
- package/out/replicache/src/persist/idb-databases-store.d.ts.map +0 -1
- package/out/replicache/src/persist/make-client-id.d.ts +0 -6
- package/out/replicache/src/persist/make-client-id.d.ts.map +0 -1
- package/out/replicache/src/persist/persist.d.ts +0 -26
- package/out/replicache/src/persist/persist.d.ts.map +0 -1
- package/out/replicache/src/persist/refresh.d.ts +0 -13
- package/out/replicache/src/persist/refresh.d.ts.map +0 -1
- package/out/replicache/src/process-scheduler.d.ts +0 -20
- package/out/replicache/src/process-scheduler.d.ts.map +0 -1
- package/out/replicache/src/puller.d.ts +0 -61
- package/out/replicache/src/puller.d.ts.map +0 -1
- package/out/replicache/src/pusher.d.ts +0 -33
- package/out/replicache/src/pusher.d.ts.map +0 -1
- package/out/replicache/src/replicache-impl.d.ts +0 -321
- package/out/replicache/src/replicache-impl.d.ts.map +0 -1
- package/out/replicache/src/replicache-options.d.ts +0 -209
- package/out/replicache/src/replicache-options.d.ts.map +0 -1
- package/out/replicache/src/replicache.d.ts +0 -298
- package/out/replicache/src/replicache.d.ts.map +0 -1
- package/out/replicache/src/request-idle.d.ts +0 -6
- package/out/replicache/src/request-idle.d.ts.map +0 -1
- package/out/replicache/src/scan-iterator.d.ts +0 -127
- package/out/replicache/src/scan-iterator.d.ts.map +0 -1
- package/out/replicache/src/scan-options.d.ts +0 -67
- package/out/replicache/src/scan-options.d.ts.map +0 -1
- package/out/replicache/src/set-interval-with-signal.d.ts +0 -2
- package/out/replicache/src/set-interval-with-signal.d.ts.map +0 -1
- package/out/replicache/src/size-of-value.d.ts +0 -19
- package/out/replicache/src/size-of-value.d.ts.map +0 -1
- package/out/replicache/src/subscriptions.d.ts +0 -137
- package/out/replicache/src/subscriptions.d.ts.map +0 -1
- package/out/replicache/src/sync/diff.d.ts +0 -31
- package/out/replicache/src/sync/diff.d.ts.map +0 -1
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.d.ts +0 -8
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.d.ts.map +0 -1
- package/out/replicache/src/sync/ids.d.ts +0 -13
- package/out/replicache/src/sync/ids.d.ts.map +0 -1
- package/out/replicache/src/sync/patch.d.ts +0 -5
- package/out/replicache/src/sync/patch.d.ts.map +0 -1
- package/out/replicache/src/sync/pull-error.d.ts +0 -9
- package/out/replicache/src/sync/pull-error.d.ts.map +0 -1
- package/out/replicache/src/sync/pull.d.ts +0 -78
- package/out/replicache/src/sync/pull.d.ts.map +0 -1
- package/out/replicache/src/sync/push.d.ts +0 -65
- package/out/replicache/src/sync/push.d.ts.map +0 -1
- package/out/replicache/src/sync/request-id.d.ts +0 -10
- package/out/replicache/src/sync/request-id.d.ts.map +0 -1
- package/out/replicache/src/sync/sync-head-name.d.ts +0 -2
- package/out/replicache/src/sync/sync-head-name.d.ts.map +0 -1
- package/out/replicache/src/test-license-key.d.ts +0 -3
- package/out/replicache/src/test-license-key.d.ts.map +0 -1
- package/out/replicache/src/to-error.d.ts +0 -2
- package/out/replicache/src/to-error.d.ts.map +0 -1
- package/out/replicache/src/transaction-closed-error.d.ts +0 -12
- package/out/replicache/src/transaction-closed-error.d.ts.map +0 -1
- package/out/replicache/src/transactions.d.ts +0 -156
- package/out/replicache/src/transactions.d.ts.map +0 -1
- package/out/replicache/src/types.d.ts +0 -57
- package/out/replicache/src/types.d.ts.map +0 -1
- package/out/replicache/src/version.d.ts +0 -5
- package/out/replicache/src/version.d.ts.map +0 -1
- package/out/replicache/src/with-transactions.d.ts +0 -23
- package/out/replicache/src/with-transactions.d.ts.map +0 -1
- package/out/shared/src/abort-error.d.ts +0 -4
- package/out/shared/src/abort-error.d.ts.map +0 -1
- package/out/shared/src/abort-error.js +0 -4
- package/out/shared/src/abort-error.js.map +0 -1
- package/out/shared/src/asserts.d.ts +0 -17
- package/out/shared/src/asserts.d.ts.map +0 -1
- package/out/shared/src/asserts.js +0 -73
- package/out/shared/src/asserts.js.map +0 -1
- package/out/shared/src/browser-env.d.ts +0 -3
- package/out/shared/src/browser-env.d.ts.map +0 -1
- package/out/shared/src/config.d.ts +0 -3
- package/out/shared/src/config.d.ts.map +0 -1
- package/out/shared/src/config.js +0 -3
- package/out/shared/src/config.js.map +0 -1
- package/out/shared/src/custom-key-map.d.ts +0 -26
- package/out/shared/src/custom-key-map.d.ts.map +0 -1
- package/out/shared/src/custom-key-map.js +0 -65
- package/out/shared/src/custom-key-map.js.map +0 -1
- package/out/shared/src/deep-clone.d.ts +0 -4
- package/out/shared/src/deep-clone.d.ts.map +0 -1
- package/out/shared/src/document-visible.d.ts +0 -9
- package/out/shared/src/document-visible.d.ts.map +0 -1
- package/out/shared/src/has-own.d.ts +0 -5
- package/out/shared/src/has-own.d.ts.map +0 -1
- package/out/shared/src/has-own.js +0 -8
- package/out/shared/src/has-own.js.map +0 -1
- package/out/shared/src/immutable.d.ts +0 -11
- package/out/shared/src/immutable.d.ts.map +0 -1
- package/out/shared/src/iterables.d.ts +0 -11
- package/out/shared/src/iterables.d.ts.map +0 -1
- package/out/shared/src/json-schema.d.ts +0 -5
- package/out/shared/src/json-schema.d.ts.map +0 -1
- package/out/shared/src/json-schema.js +0 -36
- package/out/shared/src/json-schema.js.map +0 -1
- package/out/shared/src/json.d.ts +0 -55
- package/out/shared/src/json.d.ts.map +0 -1
- package/out/shared/src/json.js +0 -164
- package/out/shared/src/json.js.map +0 -1
- package/out/shared/src/must.d.ts +0 -2
- package/out/shared/src/must.d.ts.map +0 -1
- package/out/shared/src/must.js +0 -8
- package/out/shared/src/must.js.map +0 -1
- package/out/shared/src/navigator.d.ts +0 -7
- package/out/shared/src/navigator.d.ts.map +0 -1
- package/out/shared/src/parse-big-int.d.ts +0 -2
- package/out/shared/src/parse-big-int.d.ts.map +0 -1
- package/out/shared/src/parse-big-int.js +0 -11
- package/out/shared/src/parse-big-int.js.map +0 -1
- package/out/shared/src/queue.d.ts +0 -40
- package/out/shared/src/queue.d.ts.map +0 -1
- package/out/shared/src/queue.js +0 -118
- package/out/shared/src/queue.js.map +0 -1
- package/out/shared/src/rand.d.ts +0 -7
- package/out/shared/src/rand.d.ts.map +0 -1
- package/out/shared/src/rand.js +0 -11
- package/out/shared/src/rand.js.map +0 -1
- package/out/shared/src/random-uint64.d.ts +0 -2
- package/out/shared/src/random-uint64.d.ts.map +0 -1
- package/out/shared/src/random-values.d.ts +0 -2
- package/out/shared/src/random-values.d.ts.map +0 -1
- package/out/shared/src/resolved-promises.d.ts +0 -5
- package/out/shared/src/resolved-promises.d.ts.map +0 -1
- package/out/shared/src/resolved-promises.js +0 -5
- package/out/shared/src/resolved-promises.js.map +0 -1
- package/out/shared/src/set-utils.d.ts +0 -9
- package/out/shared/src/set-utils.d.ts.map +0 -1
- package/out/shared/src/set-utils.js +0 -60
- package/out/shared/src/set-utils.js.map +0 -1
- package/out/shared/src/sleep.d.ts +0 -15
- package/out/shared/src/sleep.d.ts.map +0 -1
- package/out/shared/src/sleep.js +0 -54
- package/out/shared/src/sleep.js.map +0 -1
- package/out/shared/src/string-compare.d.ts +0 -2
- package/out/shared/src/string-compare.d.ts.map +0 -1
- package/out/shared/src/string-compare.js +0 -10
- package/out/shared/src/string-compare.js.map +0 -1
- package/out/shared/src/types.d.ts +0 -2
- package/out/shared/src/types.d.ts.map +0 -1
- package/out/shared/src/valita.d.ts +0 -27
- package/out/shared/src/valita.d.ts.map +0 -1
- package/out/shared/src/valita.js +0 -118
- package/out/shared/src/valita.js.map +0 -1
- package/out/shared/src/xxhash.d.ts +0 -3
- package/out/shared/src/xxhash.d.ts.map +0 -1
- package/out/shared/src/xxhash.js +0 -4
- package/out/shared/src/xxhash.js.map +0 -1
- package/out/zero/src/cli.d.ts +0 -3
- package/out/zero/src/cli.d.ts.map +0 -1
- package/out/zero/src/cli.js +0 -3
- package/out/zero/src/cli.js.map +0 -1
- package/out/zero/src/react.d.ts +0 -2
- package/out/zero/src/react.d.ts.map +0 -1
- package/out/zero/src/server/change-streamer.d.ts +0 -2
- package/out/zero/src/server/change-streamer.d.ts.map +0 -1
- package/out/zero/src/server/change-streamer.js +0 -2
- package/out/zero/src/server/change-streamer.js.map +0 -1
- package/out/zero/src/server/main.d.ts +0 -2
- package/out/zero/src/server/main.d.ts.map +0 -1
- package/out/zero/src/server/main.js +0 -2
- package/out/zero/src/server/main.js.map +0 -1
- package/out/zero/src/server/replicator.d.ts +0 -2
- package/out/zero/src/server/replicator.d.ts.map +0 -1
- package/out/zero/src/server/replicator.js +0 -2
- package/out/zero/src/server/replicator.js.map +0 -1
- package/out/zero/src/server/syncer.d.ts +0 -2
- package/out/zero/src/server/syncer.d.ts.map +0 -1
- package/out/zero/src/server/syncer.js +0 -2
- package/out/zero/src/server/syncer.js.map +0 -1
- package/out/zero/src/zero.d.ts +0 -2
- package/out/zero/src/zero.d.ts.map +0 -1
- package/out/zero-cache/src/config/zero-config.d.ts +0 -1509
- package/out/zero-cache/src/config/zero-config.d.ts.map +0 -1
- package/out/zero-cache/src/config/zero-config.js +0 -237
- package/out/zero-cache/src/config/zero-config.js.map +0 -1
- package/out/zero-cache/src/db/lite-tables.d.ts +0 -5
- package/out/zero-cache/src/db/lite-tables.d.ts.map +0 -1
- package/out/zero-cache/src/db/lite-tables.js +0 -75
- package/out/zero-cache/src/db/lite-tables.js.map +0 -1
- package/out/zero-cache/src/db/migration-lite.d.ts +0 -38
- package/out/zero-cache/src/db/migration-lite.d.ts.map +0 -1
- package/out/zero-cache/src/db/migration-lite.js +0 -161
- package/out/zero-cache/src/db/migration-lite.js.map +0 -1
- package/out/zero-cache/src/db/migration.d.ts +0 -38
- package/out/zero-cache/src/db/migration.d.ts.map +0 -1
- package/out/zero-cache/src/db/migration.js +0 -139
- package/out/zero-cache/src/db/migration.js.map +0 -1
- package/out/zero-cache/src/db/statements.d.ts +0 -32
- package/out/zero-cache/src/db/statements.d.ts.map +0 -1
- package/out/zero-cache/src/db/statements.js +0 -51
- package/out/zero-cache/src/db/statements.js.map +0 -1
- package/out/zero-cache/src/db/transaction-pool.d.ts +0 -187
- package/out/zero-cache/src/db/transaction-pool.d.ts.map +0 -1
- package/out/zero-cache/src/db/transaction-pool.js +0 -445
- package/out/zero-cache/src/db/transaction-pool.js.map +0 -1
- package/out/zero-cache/src/server/change-streamer.d.ts +0 -3
- package/out/zero-cache/src/server/change-streamer.d.ts.map +0 -1
- package/out/zero-cache/src/server/change-streamer.js +0 -30
- package/out/zero-cache/src/server/change-streamer.js.map +0 -1
- package/out/zero-cache/src/server/life-cycle.d.ts +0 -38
- package/out/zero-cache/src/server/life-cycle.d.ts.map +0 -1
- package/out/zero-cache/src/server/life-cycle.js +0 -110
- package/out/zero-cache/src/server/life-cycle.js.map +0 -1
- package/out/zero-cache/src/server/logging.d.ts +0 -6
- package/out/zero-cache/src/server/logging.d.ts.map +0 -1
- package/out/zero-cache/src/server/logging.js +0 -23
- package/out/zero-cache/src/server/logging.js.map +0 -1
- package/out/zero-cache/src/server/main.d.ts +0 -2
- package/out/zero-cache/src/server/main.d.ts.map +0 -1
- package/out/zero-cache/src/server/main.js +0 -94
- package/out/zero-cache/src/server/main.js.map +0 -1
- package/out/zero-cache/src/server/replicator.d.ts +0 -3
- package/out/zero-cache/src/server/replicator.d.ts.map +0 -1
- package/out/zero-cache/src/server/replicator.js +0 -36
- package/out/zero-cache/src/server/replicator.js.map +0 -1
- package/out/zero-cache/src/server/syncer.d.ts +0 -3
- package/out/zero-cache/src/server/syncer.d.ts.map +0 -1
- package/out/zero-cache/src/server/syncer.js +0 -46
- package/out/zero-cache/src/server/syncer.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +0 -23
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +0 -98
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +0 -39
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +0 -212
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +0 -110
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.js +0 -7
- package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +0 -19
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/forwarder.js +0 -56
- package/out/zero-cache/src/services/change-streamer/forwarder.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts +0 -14
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js +0 -211
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts +0 -6
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +0 -192
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts +0 -17
- package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/lsn.js +0 -17
- package/out/zero-cache/src/services/change-streamer/pg/lsn.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts +0 -6
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js +0 -29
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +0 -79
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js +0 -237
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts +0 -5
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js +0 -111
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +0 -26
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js +0 -185
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts +0 -11
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js +0 -86
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts +0 -19
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.js +0 -2
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts +0 -4
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +0 -12
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +0 -31
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.js +0 -2
- package/out/zero-cache/src/services/change-streamer/schema/change.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts +0 -4
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.js +0 -10
- package/out/zero-cache/src/services/change-streamer/schema/init.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +0 -22
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.js +0 -49
- package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/storer.d.ts +0 -22
- package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/storer.js +0 -157
- package/out/zero-cache/src/services/change-streamer/storer.js.map +0 -1
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +0 -27
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +0 -1
- package/out/zero-cache/src/services/change-streamer/subscriber.js +0 -70
- package/out/zero-cache/src/services/change-streamer/subscriber.js.map +0 -1
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +0 -21
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +0 -1
- package/out/zero-cache/src/services/dispatcher/connect-params.js +0 -38
- package/out/zero-cache/src/services/dispatcher/connect-params.js.map +0 -1
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts +0 -19
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts.map +0 -1
- package/out/zero-cache/src/services/dispatcher/dispatcher.js +0 -54
- package/out/zero-cache/src/services/dispatcher/dispatcher.js.map +0 -1
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts +0 -11
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts.map +0 -1
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.js +0 -33
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.js.map +0 -1
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts +0 -57
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts.map +0 -1
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +0 -137
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +0 -1
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts +0 -28
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +0 -1
- package/out/zero-cache/src/services/mutagen/mutagen.js +0 -256
- package/out/zero-cache/src/services/mutagen/mutagen.js.map +0 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts +0 -20
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +0 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.js +0 -187
- package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +0 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +0 -40
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +0 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.js +0 -348
- package/out/zero-cache/src/services/replicator/incremental-sync.js.map +0 -1
- package/out/zero-cache/src/services/replicator/notifier.d.ts +0 -30
- package/out/zero-cache/src/services/replicator/notifier.d.ts.map +0 -1
- package/out/zero-cache/src/services/replicator/notifier.js +0 -54
- package/out/zero-cache/src/services/replicator/notifier.js.map +0 -1
- package/out/zero-cache/src/services/replicator/replicator.d.ts +0 -56
- package/out/zero-cache/src/services/replicator/replicator.d.ts.map +0 -1
- package/out/zero-cache/src/services/replicator/replicator.js +0 -27
- package/out/zero-cache/src/services/replicator/replicator.js.map +0 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +0 -35
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +0 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.js +0 -78
- package/out/zero-cache/src/services/replicator/schema/change-log.js.map +0 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +0 -25
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +0 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.js +0 -90
- package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +0 -1
- package/out/zero-cache/src/services/runner.d.ts +0 -18
- package/out/zero-cache/src/services/runner.d.ts.map +0 -1
- package/out/zero-cache/src/services/runner.js +0 -45
- package/out/zero-cache/src/services/runner.js.map +0 -1
- package/out/zero-cache/src/services/running-state.d.ts +0 -56
- package/out/zero-cache/src/services/running-state.d.ts.map +0 -1
- package/out/zero-cache/src/services/running-state.js +0 -106
- package/out/zero-cache/src/services/running-state.js.map +0 -1
- package/out/zero-cache/src/services/service.d.ts +0 -37
- package/out/zero-cache/src/services/service.d.ts.map +0 -1
- package/out/zero-cache/src/services/service.js +0 -2
- package/out/zero-cache/src/services/service.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +0 -54
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.js +0 -195
- package/out/zero-cache/src/services/view-syncer/client-handler.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +0 -44
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.js +0 -386
- package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts +0 -146
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/cvr.js +0 -446
- package/out/zero-cache/src/services/view-syncer/cvr.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts +0 -22
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.js +0 -129
- package/out/zero-cache/src/services/view-syncer/database-storage.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +0 -108
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +0 -300
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts +0 -54
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js +0 -181
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts +0 -4
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js +0 -12
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +0 -783
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/schema/types.js +0 -213
- package/out/zero-cache/src/services/view-syncer/schema/types.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +0 -177
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.js +0 -363
- package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +0 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +0 -40
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +0 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.js +0 -506
- package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +0 -1
- package/out/zero-cache/src/types/bigint-json.d.ts +0 -26
- package/out/zero-cache/src/types/bigint-json.d.ts.map +0 -1
- package/out/zero-cache/src/types/bigint-json.js +0 -49
- package/out/zero-cache/src/types/bigint-json.js.map +0 -1
- package/out/zero-cache/src/types/error-for-client.d.ts +0 -7
- package/out/zero-cache/src/types/error-for-client.d.ts.map +0 -1
- package/out/zero-cache/src/types/error-for-client.js +0 -17
- package/out/zero-cache/src/types/error-for-client.js.map +0 -1
- package/out/zero-cache/src/types/lexi-version.d.ts +0 -29
- package/out/zero-cache/src/types/lexi-version.d.ts.map +0 -1
- package/out/zero-cache/src/types/lexi-version.js +0 -36
- package/out/zero-cache/src/types/lexi-version.js.map +0 -1
- package/out/zero-cache/src/types/lite.d.ts +0 -11
- package/out/zero-cache/src/types/lite.d.ts.map +0 -1
- package/out/zero-cache/src/types/lite.js +0 -26
- package/out/zero-cache/src/types/lite.js.map +0 -1
- package/out/zero-cache/src/types/names.d.ts +0 -5
- package/out/zero-cache/src/types/names.d.ts.map +0 -1
- package/out/zero-cache/src/types/names.js +0 -4
- package/out/zero-cache/src/types/names.js.map +0 -1
- package/out/zero-cache/src/types/pg.d.ts +0 -31
- package/out/zero-cache/src/types/pg.d.ts.map +0 -1
- package/out/zero-cache/src/types/pg.js +0 -60
- package/out/zero-cache/src/types/pg.js.map +0 -1
- package/out/zero-cache/src/types/processes.d.ts +0 -57
- package/out/zero-cache/src/types/processes.d.ts.map +0 -1
- package/out/zero-cache/src/types/processes.js +0 -115
- package/out/zero-cache/src/types/processes.js.map +0 -1
- package/out/zero-cache/src/types/row-key.d.ts +0 -37
- package/out/zero-cache/src/types/row-key.d.ts.map +0 -1
- package/out/zero-cache/src/types/row-key.js +0 -64
- package/out/zero-cache/src/types/row-key.js.map +0 -1
- package/out/zero-cache/src/types/satisfies.d.ts +0 -14
- package/out/zero-cache/src/types/satisfies.d.ts.map +0 -1
- package/out/zero-cache/src/types/satisfies.js +0 -2
- package/out/zero-cache/src/types/satisfies.js.map +0 -1
- package/out/zero-cache/src/types/schema-versions.d.ts +0 -8
- package/out/zero-cache/src/types/schema-versions.d.ts.map +0 -1
- package/out/zero-cache/src/types/schema-versions.js +0 -21
- package/out/zero-cache/src/types/schema-versions.js.map +0 -1
- package/out/zero-cache/src/types/specs.d.ts +0 -29
- package/out/zero-cache/src/types/specs.d.ts.map +0 -1
- package/out/zero-cache/src/types/specs.js +0 -2
- package/out/zero-cache/src/types/specs.js.map +0 -1
- package/out/zero-cache/src/types/sql.d.ts +0 -11
- package/out/zero-cache/src/types/sql.d.ts.map +0 -1
- package/out/zero-cache/src/types/sql.js +0 -15
- package/out/zero-cache/src/types/sql.js.map +0 -1
- package/out/zero-cache/src/types/streams.d.ts +0 -33
- package/out/zero-cache/src/types/streams.d.ts.map +0 -1
- package/out/zero-cache/src/types/streams.js +0 -141
- package/out/zero-cache/src/types/streams.js.map +0 -1
- package/out/zero-cache/src/types/subscription.d.ts +0 -158
- package/out/zero-cache/src/types/subscription.d.ts.map +0 -1
- package/out/zero-cache/src/types/subscription.js +0 -233
- package/out/zero-cache/src/types/subscription.js.map +0 -1
- package/out/zero-cache/src/types/timeout.d.ts +0 -11
- package/out/zero-cache/src/types/timeout.d.ts.map +0 -1
- package/out/zero-cache/src/types/timeout.js +0 -23
- package/out/zero-cache/src/types/timeout.js.map +0 -1
- package/out/zero-cache/src/types/url-params.d.ts +0 -10
- package/out/zero-cache/src/types/url-params.d.ts.map +0 -1
- package/out/zero-cache/src/types/url-params.js +0 -35
- package/out/zero-cache/src/types/url-params.js.map +0 -1
- package/out/zero-cache/src/workers/connection.d.ts +0 -25
- package/out/zero-cache/src/workers/connection.d.ts.map +0 -1
- package/out/zero-cache/src/workers/connection.js +0 -189
- package/out/zero-cache/src/workers/connection.js.map +0 -1
- package/out/zero-cache/src/workers/replicator.d.ts +0 -17
- package/out/zero-cache/src/workers/replicator.d.ts.map +0 -1
- package/out/zero-cache/src/workers/replicator.js +0 -77
- package/out/zero-cache/src/workers/replicator.js.map +0 -1
- package/out/zero-cache/src/workers/syncer.d.ts +0 -36
- package/out/zero-cache/src/workers/syncer.d.ts.map +0 -1
- package/out/zero-cache/src/workers/syncer.js +0 -104
- package/out/zero-cache/src/workers/syncer.js.map +0 -1
- package/out/zero-client/src/client/context.d.ts +0 -23
- package/out/zero-client/src/client/context.d.ts.map +0 -1
- package/out/zero-client/src/client/crud.d.ts +0 -52
- package/out/zero-client/src/client/crud.d.ts.map +0 -1
- package/out/zero-client/src/client/enable-analytics.d.ts +0 -3
- package/out/zero-client/src/client/enable-analytics.d.ts.map +0 -1
- package/out/zero-client/src/client/http-string.d.ts +0 -7
- package/out/zero-client/src/client/http-string.d.ts.map +0 -1
- package/out/zero-client/src/client/keys.d.ts +0 -11
- package/out/zero-client/src/client/keys.d.ts.map +0 -1
- package/out/zero-client/src/client/log-options.d.ts +0 -12
- package/out/zero-client/src/client/log-options.d.ts.map +0 -1
- package/out/zero-client/src/client/metrics.d.ts +0 -115
- package/out/zero-client/src/client/metrics.d.ts.map +0 -1
- package/out/zero-client/src/client/options.d.ts +0 -94
- package/out/zero-client/src/client/options.d.ts.map +0 -1
- package/out/zero-client/src/client/query-manager.d.ts +0 -18
- package/out/zero-client/src/client/query-manager.d.ts.map +0 -1
- package/out/zero-client/src/client/reload-error-handler.d.ts +0 -5
- package/out/zero-client/src/client/reload-error-handler.d.ts.map +0 -1
- package/out/zero-client/src/client/replicache-types.d.ts +0 -48
- package/out/zero-client/src/client/replicache-types.d.ts.map +0 -1
- package/out/zero-client/src/client/server-error.d.ts +0 -12
- package/out/zero-client/src/client/server-error.d.ts.map +0 -1
- package/out/zero-client/src/client/server-option.d.ts +0 -3
- package/out/zero-client/src/client/server-option.d.ts.map +0 -1
- package/out/zero-client/src/client/version.d.ts +0 -5
- package/out/zero-client/src/client/version.d.ts.map +0 -1
- package/out/zero-client/src/client/zero-poke-handler.d.ts +0 -28
- package/out/zero-client/src/client/zero-poke-handler.d.ts.map +0 -1
- package/out/zero-client/src/client/zero.d.ts +0 -182
- package/out/zero-client/src/client/zero.d.ts.map +0 -1
- package/out/zero-client/src/mod.d.ts +0 -9
- package/out/zero-client/src/mod.d.ts.map +0 -1
- package/out/zero-client/src/util/nanoid.d.ts +0 -2
- package/out/zero-client/src/util/nanoid.d.ts.map +0 -1
- package/out/zero-client/src/util/socket.d.ts +0 -3
- package/out/zero-client/src/util/socket.d.ts.map +0 -1
- package/out/zero-protocol/src/ast.d.ts +0 -69
- package/out/zero-protocol/src/ast.d.ts.map +0 -1
- package/out/zero-protocol/src/ast.js +0 -64
- package/out/zero-protocol/src/ast.js.map +0 -1
- package/out/zero-protocol/src/change-desired-queries.d.ts +0 -71
- package/out/zero-protocol/src/change-desired-queries.d.ts.map +0 -1
- package/out/zero-protocol/src/change-desired-queries.js +0 -10
- package/out/zero-protocol/src/change-desired-queries.js.map +0 -1
- package/out/zero-protocol/src/clients-patch.d.ts +0 -37
- package/out/zero-protocol/src/clients-patch.d.ts.map +0 -1
- package/out/zero-protocol/src/clients-patch.js +0 -15
- package/out/zero-protocol/src/clients-patch.js.map +0 -1
- package/out/zero-protocol/src/connect.d.ts +0 -88
- package/out/zero-protocol/src/connect.d.ts.map +0 -1
- package/out/zero-protocol/src/connect.js +0 -25
- package/out/zero-protocol/src/connect.js.map +0 -1
- package/out/zero-protocol/src/delete-clients.d.ts +0 -11
- package/out/zero-protocol/src/delete-clients.d.ts.map +0 -1
- package/out/zero-protocol/src/delete-clients.js +0 -9
- package/out/zero-protocol/src/delete-clients.js.map +0 -1
- package/out/zero-protocol/src/down.d.ts +0 -114
- package/out/zero-protocol/src/down.d.ts.map +0 -1
- package/out/zero-protocol/src/down.js +0 -8
- package/out/zero-protocol/src/down.js.map +0 -1
- package/out/zero-protocol/src/entities-patch.d.ts +0 -66
- package/out/zero-protocol/src/entities-patch.d.ts.map +0 -1
- package/out/zero-protocol/src/entities-patch.js +0 -27
- package/out/zero-protocol/src/entities-patch.js.map +0 -1
- package/out/zero-protocol/src/entity.d.ts +0 -9
- package/out/zero-protocol/src/entity.d.ts.map +0 -1
- package/out/zero-protocol/src/entity.js +0 -8
- package/out/zero-protocol/src/entity.js.map +0 -1
- package/out/zero-protocol/src/error.d.ts +0 -21
- package/out/zero-protocol/src/error.d.ts.map +0 -1
- package/out/zero-protocol/src/error.js +0 -28
- package/out/zero-protocol/src/error.js.map +0 -1
- package/out/zero-protocol/src/mod.d.ts +0 -16
- package/out/zero-protocol/src/mod.d.ts.map +0 -1
- package/out/zero-protocol/src/mod.js +0 -16
- package/out/zero-protocol/src/mod.js.map +0 -1
- package/out/zero-protocol/src/ping.d.ts +0 -6
- package/out/zero-protocol/src/ping.d.ts.map +0 -1
- package/out/zero-protocol/src/ping.js +0 -4
- package/out/zero-protocol/src/ping.js.map +0 -1
- package/out/zero-protocol/src/poke.d.ts +0 -244
- package/out/zero-protocol/src/poke.d.ts.map +0 -1
- package/out/zero-protocol/src/poke.js +0 -73
- package/out/zero-protocol/src/poke.js.map +0 -1
- package/out/zero-protocol/src/pong.d.ts +0 -6
- package/out/zero-protocol/src/pong.d.ts.map +0 -1
- package/out/zero-protocol/src/pong.js +0 -4
- package/out/zero-protocol/src/pong.js.map +0 -1
- package/out/zero-protocol/src/pull.d.ts +0 -26
- package/out/zero-protocol/src/pull.d.ts.map +0 -1
- package/out/zero-protocol/src/pull.js +0 -24
- package/out/zero-protocol/src/pull.js.map +0 -1
- package/out/zero-protocol/src/push.d.ts +0 -257
- package/out/zero-protocol/src/push.d.ts.map +0 -1
- package/out/zero-protocol/src/push.js +0 -77
- package/out/zero-protocol/src/push.js.map +0 -1
- package/out/zero-protocol/src/queries-patch.d.ts +0 -103
- package/out/zero-protocol/src/queries-patch.d.ts.map +0 -1
- package/out/zero-protocol/src/queries-patch.js +0 -17
- package/out/zero-protocol/src/queries-patch.js.map +0 -1
- package/out/zero-protocol/src/up.d.ts +0 -116
- package/out/zero-protocol/src/up.d.ts.map +0 -1
- package/out/zero-protocol/src/up.js +0 -9
- package/out/zero-protocol/src/up.js.map +0 -1
- package/out/zero-protocol/src/version.d.ts +0 -6
- package/out/zero-protocol/src/version.d.ts.map +0 -1
- package/out/zero-protocol/src/version.js +0 -4
- package/out/zero-protocol/src/version.js.map +0 -1
- package/out/zero-react/src/mod.d.ts +0 -3
- package/out/zero-react/src/mod.d.ts.map +0 -1
- package/out/zero-react/src/use-query.d.ts +0 -3
- package/out/zero-react/src/use-query.d.ts.map +0 -1
- package/out/zero-react/src/use-zero.d.ts +0 -8
- package/out/zero-react/src/use-zero.d.ts.map +0 -1
- package/out/zero.js +0 -15868
- package/out/zero.js.map +0 -7
- package/out/zql/src/zql/ast/ast.d.ts +0 -84
- package/out/zql/src/zql/ast/ast.d.ts.map +0 -1
- package/out/zql/src/zql/ast/ast.js +0 -54
- package/out/zql/src/zql/ast/ast.js.map +0 -1
- package/out/zql/src/zql/builder/builder.d.ts +0 -56
- package/out/zql/src/zql/builder/builder.d.ts.map +0 -1
- package/out/zql/src/zql/builder/builder.js +0 -115
- package/out/zql/src/zql/builder/builder.js.map +0 -1
- package/out/zql/src/zql/builder/error.d.ts +0 -3
- package/out/zql/src/zql/builder/error.d.ts.map +0 -1
- package/out/zql/src/zql/builder/error.js +0 -3
- package/out/zql/src/zql/builder/error.js.map +0 -1
- package/out/zql/src/zql/builder/filter.d.ts +0 -6
- package/out/zql/src/zql/builder/filter.d.ts.map +0 -1
- package/out/zql/src/zql/builder/filter.js +0 -53
- package/out/zql/src/zql/builder/filter.js.map +0 -1
- package/out/zql/src/zql/builder/like.d.ts +0 -3
- package/out/zql/src/zql/builder/like.d.ts.map +0 -1
- package/out/zql/src/zql/builder/like.js +0 -60
- package/out/zql/src/zql/builder/like.js.map +0 -1
- package/out/zql/src/zql/ivm/array-view.d.ts +0 -42
- package/out/zql/src/zql/ivm/array-view.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/change.d.ts +0 -44
- package/out/zql/src/zql/ivm/change.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/change.js +0 -2
- package/out/zql/src/zql/ivm/change.js.map +0 -1
- package/out/zql/src/zql/ivm/data.d.ts +0 -72
- package/out/zql/src/zql/ivm/data.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/data.js +0 -84
- package/out/zql/src/zql/ivm/data.js.map +0 -1
- package/out/zql/src/zql/ivm/filter.d.ts +0 -27
- package/out/zql/src/zql/ivm/filter.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/filter.js +0 -60
- package/out/zql/src/zql/ivm/filter.js.map +0 -1
- package/out/zql/src/zql/ivm/join.d.ts +0 -37
- package/out/zql/src/zql/ivm/join.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/join.js +0 -228
- package/out/zql/src/zql/ivm/join.js.map +0 -1
- package/out/zql/src/zql/ivm/lookahead-iterator.d.ts +0 -13
- package/out/zql/src/zql/ivm/lookahead-iterator.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/lookahead-iterator.js +0 -45
- package/out/zql/src/zql/ivm/lookahead-iterator.js.map +0 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts +0 -10
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js +0 -34
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js.map +0 -1
- package/out/zql/src/zql/ivm/memory-source.d.ts +0 -65
- package/out/zql/src/zql/ivm/memory-source.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/memory-source.js +0 -508
- package/out/zql/src/zql/ivm/memory-source.js.map +0 -1
- package/out/zql/src/zql/ivm/memory-storage.d.ts +0 -18
- package/out/zql/src/zql/ivm/memory-storage.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/operator.d.ts +0 -89
- package/out/zql/src/zql/ivm/operator.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/operator.js +0 -2
- package/out/zql/src/zql/ivm/operator.js.map +0 -1
- package/out/zql/src/zql/ivm/schema.d.ts +0 -29
- package/out/zql/src/zql/ivm/schema.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/schema.js +0 -3
- package/out/zql/src/zql/ivm/schema.js.map +0 -1
- package/out/zql/src/zql/ivm/skip.d.ts +0 -24
- package/out/zql/src/zql/ivm/skip.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/skip.js +0 -113
- package/out/zql/src/zql/ivm/skip.js.map +0 -1
- package/out/zql/src/zql/ivm/source.d.ts +0 -57
- package/out/zql/src/zql/ivm/source.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/source.js +0 -2
- package/out/zql/src/zql/ivm/source.js.map +0 -1
- package/out/zql/src/zql/ivm/stream.d.ts +0 -11
- package/out/zql/src/zql/ivm/stream.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/stream.js +0 -19
- package/out/zql/src/zql/ivm/stream.js.map +0 -1
- package/out/zql/src/zql/ivm/take.d.ts +0 -24
- package/out/zql/src/zql/ivm/take.d.ts.map +0 -1
- package/out/zql/src/zql/ivm/take.js +0 -453
- package/out/zql/src/zql/ivm/take.js.map +0 -1
- package/out/zql/src/zql/query/query-impl.d.ts +0 -48
- package/out/zql/src/zql/query/query-impl.d.ts.map +0 -1
- package/out/zql/src/zql/query/query.d.ts +0 -131
- package/out/zql/src/zql/query/query.d.ts.map +0 -1
- package/out/zql/src/zql/query/schema.d.ts +0 -53
- package/out/zql/src/zql/query/schema.d.ts.map +0 -1
- package/out/zql/src/zql/query/typed-view.d.ts +0 -10
- package/out/zql/src/zql/query/typed-view.d.ts.map +0 -1
- package/out/zqlite/src/db.d.ts +0 -23
- package/out/zqlite/src/db.d.ts.map +0 -1
- package/out/zqlite/src/db.js +0 -117
- package/out/zqlite/src/db.js.map +0 -1
- package/out/zqlite/src/internal/sql.d.ts +0 -9
- package/out/zqlite/src/internal/sql.d.ts.map +0 -1
- package/out/zqlite/src/internal/sql.js +0 -14
- package/out/zqlite/src/internal/sql.js.map +0 -1
- package/out/zqlite/src/internal/statement-cache.d.ts +0 -67
- package/out/zqlite/src/internal/statement-cache.d.ts.map +0 -1
- package/out/zqlite/src/internal/statement-cache.js +0 -119
- package/out/zqlite/src/internal/statement-cache.js.map +0 -1
- package/out/zqlite/src/table-source.d.ts +0 -43
- package/out/zqlite/src/table-source.d.ts.map +0 -1
- package/out/zqlite/src/table-source.js +0 -393
- package/out/zqlite/src/table-source.js.map +0 -1
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { LogContext } from '@rocicorp/logger';
|
|
2
|
-
import postgres from 'postgres';
|
|
3
|
-
import { equals } from '../../../../../shared/src/set-utils.js';
|
|
4
|
-
export const PG_SCHEMA = 'cdc';
|
|
5
|
-
const CREATE_CDC_SCHEMA = `CREATE SCHEMA IF NOT EXISTS cdc;`;
|
|
6
|
-
const CREATE_CHANGE_LOG_TABLE = `
|
|
7
|
-
CREATE TABLE cdc."ChangeLog" (
|
|
8
|
-
watermark TEXT,
|
|
9
|
-
pos INT8,
|
|
10
|
-
change JSONB NOT NULL,
|
|
11
|
-
precommit TEXT, -- Only exists on commit entries. Purely for debugging.
|
|
12
|
-
PRIMARY KEY (watermark, pos)
|
|
13
|
-
);
|
|
14
|
-
`;
|
|
15
|
-
const CREATE_REPLICATION_CONFIG_TABLE = `
|
|
16
|
-
CREATE TABLE cdc."ReplicationConfig" (
|
|
17
|
-
"replicaVersion" TEXT NOT NULL,
|
|
18
|
-
"publications" TEXT[] NOT NULL,
|
|
19
|
-
"lock" INTEGER PRIMARY KEY DEFAULT 1 CHECK (lock=1)
|
|
20
|
-
);
|
|
21
|
-
`;
|
|
22
|
-
const CREATE_CDC_TABLES = CREATE_CDC_SCHEMA + CREATE_CHANGE_LOG_TABLE + CREATE_REPLICATION_CONFIG_TABLE;
|
|
23
|
-
export async function setupCDCTables(lc, db) {
|
|
24
|
-
lc.info?.(`Setting up CDC tables`);
|
|
25
|
-
await db.unsafe(CREATE_CDC_TABLES);
|
|
26
|
-
}
|
|
27
|
-
export async function ensureReplicationConfig(lc, db, config) {
|
|
28
|
-
// Restrict the fields of the supplied `config`.
|
|
29
|
-
const { publications, replicaVersion } = config;
|
|
30
|
-
const replicaConfig = { publications, replicaVersion };
|
|
31
|
-
await db.begin(async (tx) => {
|
|
32
|
-
const results = await tx `SELECT "replicaVersion", "publications" FROM cdc."ReplicationConfig"`;
|
|
33
|
-
if (results.length === 0) {
|
|
34
|
-
return tx `INSERT INTO cdc."ReplicationConfig" ${tx(replicaConfig)}`;
|
|
35
|
-
}
|
|
36
|
-
const { replicaVersion, publications } = results[0];
|
|
37
|
-
if (replicaVersion !== replicaConfig.replicaVersion ||
|
|
38
|
-
!equals(new Set(publications), new Set(replicaConfig.publications))) {
|
|
39
|
-
lc.info?.(`Data in cdc tables @${replicaVersion} is incompatible ` +
|
|
40
|
-
`with replica @${replicaConfig.replicaVersion}. Clearing tables.`);
|
|
41
|
-
return [
|
|
42
|
-
tx `TRUNCATE TABLE cdc."ChangeLog"`,
|
|
43
|
-
tx `UPDATE cdc."ReplicationConfig" SET ${tx(replicaConfig)}`,
|
|
44
|
-
].map(stmt => stmt.execute());
|
|
45
|
-
}
|
|
46
|
-
return [];
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
//# sourceMappingURL=tables.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tables.js","sourceRoot":"","sources":["../../../../../../../zero-cache/src/services/change-streamer/schema/tables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,EAAC,MAAM,EAAC,MAAM,wCAAwC,CAAC;AAI9D,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,CAAC;AAE/B,MAAM,iBAAiB,GAAG,kCAAkC,CAAC;AAS7D,MAAM,uBAAuB,GAAG;;;;;;;;CAQ/B,CAAC;AAaF,MAAM,+BAA+B,GAAG;;;;;;CAMvC,CAAC;AAEF,MAAM,iBAAiB,GACrB,iBAAiB,GAAG,uBAAuB,GAAG,+BAA+B,CAAC;AAEhF,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,EAAc,EACd,EAA2B;IAE3B,EAAE,CAAC,IAAI,EAAE,CAAC,uBAAuB,CAAC,CAAC;IACnC,MAAM,EAAE,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,EAAc,EACd,EAAc,EACd,MAAyB;IAEzB,gDAAgD;IAChD,MAAM,EAAC,YAAY,EAAE,cAAc,EAAC,GAAG,MAAM,CAAC;IAC9C,MAAM,aAAa,GAAG,EAAC,YAAY,EAAE,cAAc,EAAC,CAAC;IAErD,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAC,EAAE,EAAC,EAAE;QACxB,MAAM,OAAO,GAAG,MAAM,EAAE,CAKvB,sEAAsE,CAAC;QAExE,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,EAAE,CAAA,uCAAuC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC;QACtE,CAAC;QAED,MAAM,EAAC,cAAc,EAAE,YAAY,EAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QAClD,IACE,cAAc,KAAK,aAAa,CAAC,cAAc;YAC/C,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,EACnE,CAAC;YACD,EAAE,CAAC,IAAI,EAAE,CACP,uBAAuB,cAAc,mBAAmB;gBACtD,iBAAiB,aAAa,CAAC,cAAc,oBAAoB,CACpE,CAAC;YACF,OAAO;gBACL,EAAE,CAAA,gCAAgC;gBAClC,EAAE,CAAA,sCAAsC,EAAE,CAAC,aAAa,CAAC,EAAE;aAC5D,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAChC,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { LogContext } from '@rocicorp/logger';
|
|
2
|
-
import type { PostgresDB } from '../../types/pg.js';
|
|
3
|
-
import type { Service } from '../service.js';
|
|
4
|
-
import type { WatermarkedChange } from './change-streamer-service.js';
|
|
5
|
-
import type { Commit } from './change-streamer.js';
|
|
6
|
-
import { Subscriber } from './subscriber.js';
|
|
7
|
-
/**
|
|
8
|
-
* Handles the storage of changes and the catchup of subscribers
|
|
9
|
-
* that are behind.
|
|
10
|
-
*/
|
|
11
|
-
export declare class Storer implements Service {
|
|
12
|
-
#private;
|
|
13
|
-
readonly id = "storer";
|
|
14
|
-
readonly stopped: import("@rocicorp/resolver").Resolver<false, unknown>;
|
|
15
|
-
constructor(lc: LogContext, db: PostgresDB, onCommit: (c: Commit) => void);
|
|
16
|
-
getLastStoredWatermark(): Promise<string | null>;
|
|
17
|
-
store(entry: WatermarkedChange): void;
|
|
18
|
-
catchup(sub: Subscriber): void;
|
|
19
|
-
run(): Promise<void>;
|
|
20
|
-
stop(): Promise<void>;
|
|
21
|
-
}
|
|
22
|
-
//# sourceMappingURL=storer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storer.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/storer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAO5C,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AAC3C,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AACpE,OAAO,KAAK,EAAc,MAAM,EAAC,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;AAU3C;;;GAGG;AACH,qBAAa,MAAO,YAAW,OAAO;;IACpC,QAAQ,CAAC,EAAE,YAAY;IAKvB,QAAQ,CAAC,OAAO,wDAAqB;gBAEzB,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI;IAMnE,sBAAsB,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAOtD,KAAK,CAAC,KAAK,EAAE,iBAAiB;IAI9B,OAAO,CAAC,GAAG,EAAE,UAAU;IAIjB,GAAG;IAsIT,IAAI;CAIL"}
|
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
import { LogContext } from '@rocicorp/logger';
|
|
2
|
-
import { resolver } from '@rocicorp/resolver';
|
|
3
|
-
import { assert } from '../../../../shared/src/asserts.js';
|
|
4
|
-
import { Queue } from '../../../../shared/src/queue.js';
|
|
5
|
-
import { promiseVoid } from '../../../../shared/src/resolved-promises.js';
|
|
6
|
-
import { Mode, TransactionPool } from '../../db/transaction-pool.js';
|
|
7
|
-
import { Subscriber } from './subscriber.js';
|
|
8
|
-
/**
|
|
9
|
-
* Handles the storage of changes and the catchup of subscribers
|
|
10
|
-
* that are behind.
|
|
11
|
-
*/
|
|
12
|
-
export class Storer {
|
|
13
|
-
id = 'storer';
|
|
14
|
-
#lc;
|
|
15
|
-
#db;
|
|
16
|
-
#onCommit;
|
|
17
|
-
#queue = new Queue();
|
|
18
|
-
stopped = resolver();
|
|
19
|
-
constructor(lc, db, onCommit) {
|
|
20
|
-
this.#lc = lc;
|
|
21
|
-
this.#db = db;
|
|
22
|
-
this.#onCommit = onCommit;
|
|
23
|
-
}
|
|
24
|
-
async getLastStoredWatermark() {
|
|
25
|
-
const result = await this.#db `SELECT MAX(watermark) as max FROM cdc."ChangeLog"`;
|
|
26
|
-
return result[0].max;
|
|
27
|
-
}
|
|
28
|
-
store(entry) {
|
|
29
|
-
void this.#queue.enqueue(['change', entry]);
|
|
30
|
-
}
|
|
31
|
-
catchup(sub) {
|
|
32
|
-
void this.#queue.enqueue(['subscriber', sub]);
|
|
33
|
-
}
|
|
34
|
-
async run() {
|
|
35
|
-
let tx = null;
|
|
36
|
-
let next;
|
|
37
|
-
const catchupQueue = [];
|
|
38
|
-
while ((next = await Promise.race([this.#queue.dequeue(), this.stopped.promise]))) {
|
|
39
|
-
if (next[0] === 'subscriber') {
|
|
40
|
-
const subscriber = next[1];
|
|
41
|
-
if (tx) {
|
|
42
|
-
catchupQueue.push(subscriber); // Wait for the current tx to complete.
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this.#processCatchup([subscriber]); // Catch up immediately.
|
|
46
|
-
}
|
|
47
|
-
continue;
|
|
48
|
-
}
|
|
49
|
-
// next[0] === 'change'
|
|
50
|
-
const [watermark, downstream] = next[1];
|
|
51
|
-
const [tag, change] = downstream;
|
|
52
|
-
if (tag === 'begin') {
|
|
53
|
-
assert(!tx, 'received BEGIN in the middle of a transaction');
|
|
54
|
-
tx = {
|
|
55
|
-
pool: new TransactionPool(this.#lc.withContext('watermark', watermark), Mode.SERIALIZABLE),
|
|
56
|
-
preCommitWatermark: watermark,
|
|
57
|
-
pos: 0,
|
|
58
|
-
};
|
|
59
|
-
tx.pool.run(this.#db);
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
assert(tx, `received ${tag} outside of transaction`);
|
|
63
|
-
tx.pos++;
|
|
64
|
-
}
|
|
65
|
-
const entry = {
|
|
66
|
-
watermark: tag === 'commit' ? watermark : tx.preCommitWatermark,
|
|
67
|
-
precommit: tag === 'commit' ? tx.preCommitWatermark : null,
|
|
68
|
-
pos: tx.pos,
|
|
69
|
-
change: change,
|
|
70
|
-
};
|
|
71
|
-
tx.pool.process(tx => [
|
|
72
|
-
// Ignore conflicts to take into account transaction replay when an
|
|
73
|
-
// acknowledgement doesn't reach upstream.
|
|
74
|
-
tx `INSERT INTO cdc."ChangeLog" ${tx(entry)} ON CONFLICT DO NOTHING`,
|
|
75
|
-
]);
|
|
76
|
-
if (tag === 'commit') {
|
|
77
|
-
// Sanity check that there are no records between the preCommitWatermark
|
|
78
|
-
// and the commit watermark.
|
|
79
|
-
const { count } = await tx.pool.processReadTask(async (db) => {
|
|
80
|
-
assert(tx);
|
|
81
|
-
const results = await db `
|
|
82
|
-
SELECT COUNT(*) as count FROM cdc."ChangeLog"
|
|
83
|
-
WHERE watermark > ${tx.preCommitWatermark} AND
|
|
84
|
-
watermark < ${entry.watermark}
|
|
85
|
-
`;
|
|
86
|
-
return results[0];
|
|
87
|
-
});
|
|
88
|
-
if (count > 0) {
|
|
89
|
-
const err = new Error(`Unexpected entries between precommit ${tx.preCommitWatermark} and commit ${watermark}`);
|
|
90
|
-
tx.pool.fail(err);
|
|
91
|
-
await tx.pool.done();
|
|
92
|
-
throw err; // tx.pool.done() throws, but this makes it clearer.
|
|
93
|
-
}
|
|
94
|
-
tx.pool.setDone();
|
|
95
|
-
await tx.pool.done();
|
|
96
|
-
tx = null;
|
|
97
|
-
// ACK the LSN to the upstream Postgres.
|
|
98
|
-
this.#onCommit(downstream);
|
|
99
|
-
// Before beginning the next transaction, open a READONLY snapshot to
|
|
100
|
-
// concurrently catchup any queued subscribers.
|
|
101
|
-
this.#processCatchup(catchupQueue.splice(0));
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
this.#lc.info?.('storer stopped');
|
|
105
|
-
}
|
|
106
|
-
#processCatchup(subs) {
|
|
107
|
-
if (subs.length === 0) {
|
|
108
|
-
return;
|
|
109
|
-
}
|
|
110
|
-
const reader = new TransactionPool(this.#lc.withContext('pool', 'catchup'), Mode.READONLY);
|
|
111
|
-
reader.run(this.#db);
|
|
112
|
-
// Run in the background. Errors are handled in #catchup() by disconnecting
|
|
113
|
-
// the associated subscriber.
|
|
114
|
-
void Promise.all(subs.map(sub => this.#catchup(sub, reader))).finally(() => reader.setDone());
|
|
115
|
-
}
|
|
116
|
-
async #catchup(sub, reader) {
|
|
117
|
-
try {
|
|
118
|
-
await reader.processReadTask(async (tx) => {
|
|
119
|
-
const start = Date.now();
|
|
120
|
-
let count = 0;
|
|
121
|
-
for await (const entries of tx `
|
|
122
|
-
SELECT watermark, change FROM cdc."ChangeLog"
|
|
123
|
-
WHERE watermark > ${sub.watermark}
|
|
124
|
-
ORDER BY watermark, pos`.cursor(10000)) {
|
|
125
|
-
for (const entry of entries) {
|
|
126
|
-
sub.catchup(toDownstream(entry));
|
|
127
|
-
count++;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
// Flushes the backlog of messages buffered during catchup and
|
|
131
|
-
// allows the subscription to forward subsequent messages immediately.
|
|
132
|
-
sub.setCaughtUp();
|
|
133
|
-
this.#lc.info?.(`caught up ${sub.id} with ${count} changes (${Date.now() - start} ms)`);
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
catch (err) {
|
|
137
|
-
sub.fail(err);
|
|
138
|
-
this.#lc.error?.(`error while catching up subscriber ${sub.id}`, err);
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
stop() {
|
|
142
|
-
this.stopped.resolve(false);
|
|
143
|
-
return promiseVoid;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
function toDownstream(entry) {
|
|
147
|
-
const { watermark, change } = entry;
|
|
148
|
-
switch (change.tag) {
|
|
149
|
-
case 'begin':
|
|
150
|
-
return [watermark, ['begin', change]];
|
|
151
|
-
case 'commit':
|
|
152
|
-
return [watermark, ['commit', change, { watermark }]];
|
|
153
|
-
default:
|
|
154
|
-
return [watermark, ['data', change]];
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
//# sourceMappingURL=storer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"storer.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/storer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { Subscription } from '../../types/subscription.js';
|
|
2
|
-
import type { WatermarkedChange } from './change-streamer-service.js';
|
|
3
|
-
import { type Downstream, ErrorType } from './change-streamer.js';
|
|
4
|
-
/**
|
|
5
|
-
* Encapsulates a subscriber to changes. All subscribers start in a
|
|
6
|
-
* "catchup" phase in which changes are buffered in a backlog while the
|
|
7
|
-
* storer is queried to send any changes that were committed since the
|
|
8
|
-
* subscriber's watermark. Once the catchup is complete, calls to
|
|
9
|
-
* {@link send()} result in immediately sending the change.
|
|
10
|
-
*/
|
|
11
|
-
export declare class Subscriber {
|
|
12
|
-
#private;
|
|
13
|
-
readonly id: string;
|
|
14
|
-
constructor(id: string, watermark: string, downstream: Subscription<Downstream>);
|
|
15
|
-
get watermark(): string;
|
|
16
|
-
send(change: WatermarkedChange): void;
|
|
17
|
-
/** catchup() is called on ChangeEntries loaded from the store. */
|
|
18
|
-
catchup(change: WatermarkedChange): void;
|
|
19
|
-
/**
|
|
20
|
-
* Marks the Subscribe as "caught up" and flushes any backlog of
|
|
21
|
-
* entries that were received during the catchup.
|
|
22
|
-
*/
|
|
23
|
-
setCaughtUp(): void;
|
|
24
|
-
fail(err?: unknown): void;
|
|
25
|
-
close(error?: ErrorType, message?: string): void;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=subscriber.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"subscriber.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/subscriber.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,YAAY,EAAC,MAAM,6BAA6B,CAAC;AACzD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAC,KAAK,UAAU,EAAE,SAAS,EAAC,MAAM,sBAAsB,CAAC;AAEhE;;;;;;GAMG;AACH,qBAAa,UAAU;;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;gBAMlB,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,YAAY,CAAC,UAAU,CAAC;IAQtC,IAAI,SAAS,WAEZ;IAED,IAAI,CAAC,MAAM,EAAE,iBAAiB;IAW9B,kEAAkE;IAClE,OAAO,CAAC,MAAM,EAAE,iBAAiB;IAIjC;;;OAGG;IACH,WAAW;IAkBX,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO;IAIlB,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,MAAM;CAM1C"}
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { assert } from '../../../../shared/src/asserts.js';
|
|
2
|
-
import { Subscription } from '../../types/subscription.js';
|
|
3
|
-
import { ErrorType } from './change-streamer.js';
|
|
4
|
-
/**
|
|
5
|
-
* Encapsulates a subscriber to changes. All subscribers start in a
|
|
6
|
-
* "catchup" phase in which changes are buffered in a backlog while the
|
|
7
|
-
* storer is queried to send any changes that were committed since the
|
|
8
|
-
* subscriber's watermark. Once the catchup is complete, calls to
|
|
9
|
-
* {@link send()} result in immediately sending the change.
|
|
10
|
-
*/
|
|
11
|
-
export class Subscriber {
|
|
12
|
-
id;
|
|
13
|
-
#downstream;
|
|
14
|
-
#watermark;
|
|
15
|
-
#backlog;
|
|
16
|
-
constructor(id, watermark, downstream) {
|
|
17
|
-
this.id = id;
|
|
18
|
-
this.#downstream = downstream;
|
|
19
|
-
this.#watermark = watermark;
|
|
20
|
-
this.#backlog = [];
|
|
21
|
-
}
|
|
22
|
-
get watermark() {
|
|
23
|
-
return this.#watermark;
|
|
24
|
-
}
|
|
25
|
-
send(change) {
|
|
26
|
-
const [watermark] = change;
|
|
27
|
-
if (watermark > this.#watermark) {
|
|
28
|
-
if (this.#backlog) {
|
|
29
|
-
this.#backlog.push(change);
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
this.#send(change);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
/** catchup() is called on ChangeEntries loaded from the store. */
|
|
37
|
-
catchup(change) {
|
|
38
|
-
this.#send(change);
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Marks the Subscribe as "caught up" and flushes any backlog of
|
|
42
|
-
* entries that were received during the catchup.
|
|
43
|
-
*/
|
|
44
|
-
setCaughtUp() {
|
|
45
|
-
assert(this.#backlog);
|
|
46
|
-
for (const change of this.#backlog) {
|
|
47
|
-
this.#send(change);
|
|
48
|
-
}
|
|
49
|
-
this.#backlog = null;
|
|
50
|
-
}
|
|
51
|
-
#send(change) {
|
|
52
|
-
const [watermark, downstream] = change;
|
|
53
|
-
if (watermark > this.watermark) {
|
|
54
|
-
this.#downstream.push(downstream);
|
|
55
|
-
if (downstream[0] === 'commit') {
|
|
56
|
-
this.#watermark = watermark;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
fail(err) {
|
|
61
|
-
this.close(ErrorType.Unknown, String(err));
|
|
62
|
-
}
|
|
63
|
-
close(error, message) {
|
|
64
|
-
if (error) {
|
|
65
|
-
this.#downstream.push(['error', { type: error, message }]);
|
|
66
|
-
}
|
|
67
|
-
this.#downstream.cancel();
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
//# sourceMappingURL=subscriber.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"subscriber.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/subscriber.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,mCAAmC,CAAC;AACzD,OAAO,EAAC,YAAY,EAAC,MAAM,6BAA6B,CAAC;AAEzD,OAAO,EAAkB,SAAS,EAAC,MAAM,sBAAsB,CAAC;AAEhE;;;;;;GAMG;AACH,MAAM,OAAO,UAAU;IACZ,EAAE,CAAS;IACX,WAAW,CAA2B;IAC/C,UAAU,CAAS;IACnB,QAAQ,CAA6B;IAErC,YACE,EAAU,EACV,SAAiB,EACjB,UAAoC;QAEpC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,MAAyB;QAC5B,MAAM,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC;QAC3B,IAAI,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAChC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACrB,CAAC;QACH,CAAC;IACH,CAAC;IAED,kEAAkE;IAClE,OAAO,CAAC,MAAyB;QAC/B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtB,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACrB,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,MAAyB;QAC7B,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,GAAG,MAAM,CAAC;QACvC,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClC,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE,CAAC;gBAC/B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,CAAC,GAAa;QAChB,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,KAAiB,EAAE,OAAgB;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,IAAI,EAAE,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC,CAAC;QAC3D,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;IAC5B,CAAC;CACF"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import type { IncomingHttpHeaders } from 'node:http2';
|
|
2
|
-
export type ConnectParams = {
|
|
3
|
-
readonly clientID: string;
|
|
4
|
-
readonly clientGroupID: string;
|
|
5
|
-
readonly schemaVersion: number;
|
|
6
|
-
readonly baseCookie: string | null;
|
|
7
|
-
readonly timestamp: number;
|
|
8
|
-
readonly lmID: number;
|
|
9
|
-
readonly wsID: string;
|
|
10
|
-
readonly debugPerf: boolean;
|
|
11
|
-
readonly auth: string | undefined;
|
|
12
|
-
readonly userID: string;
|
|
13
|
-
};
|
|
14
|
-
export declare function getConnectParams(url: URL, headers: IncomingHttpHeaders): {
|
|
15
|
-
params: ConnectParams;
|
|
16
|
-
error: null;
|
|
17
|
-
} | {
|
|
18
|
-
params: null;
|
|
19
|
-
error: string;
|
|
20
|
-
};
|
|
21
|
-
//# sourceMappingURL=connect-params.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connect-params.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/connect-params.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,mBAAmB,EAAC,MAAM,YAAY,CAAC;AAGpD,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,mBAAmB,GAE1B;IACE,MAAM,EAAE,aAAa,CAAC;IACtB,KAAK,EAAE,IAAI,CAAC;CACb,GACD;IACE,MAAM,EAAE,IAAI,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;CACf,CAoCJ"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import { URLParams } from '../../types/url-params.js';
|
|
2
|
-
export function getConnectParams(url, headers) {
|
|
3
|
-
const params = new URLParams(url);
|
|
4
|
-
try {
|
|
5
|
-
const clientID = params.get('clientID', true);
|
|
6
|
-
const clientGroupID = params.get('clientGroupID', true);
|
|
7
|
-
const schemaVersion = params.getInteger('schemaVersion', true);
|
|
8
|
-
const baseCookie = params.get('baseCookie', false);
|
|
9
|
-
const timestamp = params.getInteger('ts', true);
|
|
10
|
-
const lmID = params.getInteger('lmid', true);
|
|
11
|
-
const wsID = params.get('wsid', false) ?? '';
|
|
12
|
-
const userID = params.get('userID', false) ?? '';
|
|
13
|
-
const debugPerf = params.getBoolean('debugPerf');
|
|
14
|
-
const maybeAuthToken = headers['sec-websocket-protocol'];
|
|
15
|
-
return {
|
|
16
|
-
params: {
|
|
17
|
-
clientID,
|
|
18
|
-
clientGroupID,
|
|
19
|
-
schemaVersion,
|
|
20
|
-
baseCookie,
|
|
21
|
-
timestamp,
|
|
22
|
-
lmID,
|
|
23
|
-
wsID,
|
|
24
|
-
debugPerf,
|
|
25
|
-
auth: maybeAuthToken ? decodeURIComponent(maybeAuthToken) : undefined,
|
|
26
|
-
userID,
|
|
27
|
-
},
|
|
28
|
-
error: null,
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
catch (e) {
|
|
32
|
-
return {
|
|
33
|
-
params: null,
|
|
34
|
-
error: e instanceof Error ? e.message : String(e),
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
//# sourceMappingURL=connect-params.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connect-params.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/connect-params.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAepD,MAAM,UAAU,gBAAgB,CAC9B,GAAQ,EACR,OAA4B;IAU5B,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;IAElC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC9C,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QACxD,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAC/D,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QACnD,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC7C,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAEjD,MAAM,cAAc,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC;QACzD,OAAO;YACL,MAAM,EAAE;gBACN,QAAQ;gBACR,aAAa;gBACb,aAAa;gBACb,UAAU;gBACV,SAAS;gBACT,IAAI;gBACJ,IAAI;gBACJ,SAAS;gBACT,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,SAAS;gBACrE,MAAM;aACP;YACD,KAAK,EAAE,IAAI;SACZ,CAAC;IACJ,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO;YACL,MAAM,EAAE,IAAI;YACZ,KAAK,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;SAClD,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { LogContext } from '@rocicorp/logger';
|
|
2
|
-
import type { Worker } from '../../types/processes.js';
|
|
3
|
-
import type { Service } from '../service.js';
|
|
4
|
-
export declare const CONNECT_URL_PATTERN = "/api/sync/:version/connect";
|
|
5
|
-
export type Workers = {
|
|
6
|
-
syncers: Worker[];
|
|
7
|
-
};
|
|
8
|
-
export declare const DEFAULT_PORT = 4848;
|
|
9
|
-
export type Options = {
|
|
10
|
-
port: number;
|
|
11
|
-
};
|
|
12
|
-
export declare class Dispatcher implements Service {
|
|
13
|
-
#private;
|
|
14
|
-
readonly id = "dispatcher";
|
|
15
|
-
constructor(lc: LogContext, workersByHostname: (hostname: string) => Workers, opts?: Partial<Options>);
|
|
16
|
-
run(): Promise<void>;
|
|
17
|
-
stop(): Promise<void>;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=dispatcher.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dispatcher.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/dispatcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAI5C,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,0BAA0B,CAAC;AACrD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AAI3C,eAAO,MAAM,mBAAmB,+BAA+B,CAAC;AAEhE,MAAM,MAAM,OAAO,GAAG;IACpB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,YAAY,OAAO,CAAC;AAEjC,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,qBAAa,UAAW,YAAW,OAAO;;IACxC,QAAQ,CAAC,EAAE,gBAAgB;gBAOzB,EAAE,EAAE,UAAU,EACd,iBAAiB,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,EAChD,IAAI,GAAE,OAAO,CAAC,OAAO,CAAM;IAsCvB,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;IAOpB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAG5B"}
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { LogContext } from '@rocicorp/logger';
|
|
2
|
-
import Fastify, {} from 'fastify';
|
|
3
|
-
import { IncomingMessage } from 'http';
|
|
4
|
-
import { h32 } from '../../../../shared/src/xxhash.js';
|
|
5
|
-
import { getConnectParams } from './connect-params.js';
|
|
6
|
-
import { installWebSocketHandoff } from './websocket-handoff.js';
|
|
7
|
-
export const CONNECT_URL_PATTERN = '/api/sync/:version/connect';
|
|
8
|
-
export const DEFAULT_PORT = 4848;
|
|
9
|
-
export class Dispatcher {
|
|
10
|
-
id = 'dispatcher';
|
|
11
|
-
#lc;
|
|
12
|
-
#workersByHostname;
|
|
13
|
-
#fastify;
|
|
14
|
-
#port;
|
|
15
|
-
constructor(lc, workersByHostname, opts = {}) {
|
|
16
|
-
const { port = DEFAULT_PORT } = opts;
|
|
17
|
-
this.#lc = lc;
|
|
18
|
-
this.#workersByHostname = workersByHostname;
|
|
19
|
-
this.#fastify = Fastify();
|
|
20
|
-
this.#fastify.get('/', (_req, res) => res.send('OK'));
|
|
21
|
-
this.#fastify.addHook('onRequest', (req, _, done) => {
|
|
22
|
-
this.#lc?.debug?.(`received request`, req.hostname, req.url);
|
|
23
|
-
done();
|
|
24
|
-
});
|
|
25
|
-
this.#port = port;
|
|
26
|
-
installWebSocketHandoff(this.#fastify.server, req => this.#handoff(req));
|
|
27
|
-
}
|
|
28
|
-
#handoff(req) {
|
|
29
|
-
const { headers, url } = req;
|
|
30
|
-
const { params, error } = getConnectParams(new URL(url ?? '', 'http://unused/'), headers);
|
|
31
|
-
if (error !== null) {
|
|
32
|
-
throw new Error(error);
|
|
33
|
-
}
|
|
34
|
-
const { host } = headers;
|
|
35
|
-
if (!host) {
|
|
36
|
-
throw new Error('Missing Host field');
|
|
37
|
-
}
|
|
38
|
-
const { clientGroupID } = params;
|
|
39
|
-
const { syncers } = this.#workersByHostname(host);
|
|
40
|
-
const syncer = h32(clientGroupID) % syncers.length;
|
|
41
|
-
this.#lc.debug?.(`connecting ${clientGroupID} to syncer ${syncer}`);
|
|
42
|
-
return { payload: params, receiver: syncers[syncer] };
|
|
43
|
-
}
|
|
44
|
-
async run() {
|
|
45
|
-
const address = await this.#fastify.listen({
|
|
46
|
-
port: this.#port,
|
|
47
|
-
});
|
|
48
|
-
this.#lc.info?.(`Server listening at ${address}`);
|
|
49
|
-
}
|
|
50
|
-
async stop() {
|
|
51
|
-
await this.#fastify.close();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
//# sourceMappingURL=dispatcher.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dispatcher.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/dispatcher.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { IncomingMessage, Server } from 'node:http';
|
|
2
|
-
import type { WebSocket, WebSocketServer } from 'ws';
|
|
3
|
-
import { type Receiver, type Sender } from '../../types/processes.js';
|
|
4
|
-
export type WebSocketHandoff<P> = (message: IncomingMessage) => {
|
|
5
|
-
payload: P;
|
|
6
|
-
receiver: Receiver;
|
|
7
|
-
};
|
|
8
|
-
export type WebSocketReceiver<P> = (ws: WebSocket, payload: P) => void;
|
|
9
|
-
export declare function installWebSocketHandoff<P>(server: Server, handoff: WebSocketHandoff<P>): void;
|
|
10
|
-
export declare function installWebSocketReceiver<P>(server: WebSocketServer, receive: WebSocketReceiver<P>, sender: Sender): void;
|
|
11
|
-
//# sourceMappingURL=websocket-handoff.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"websocket-handoff.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/websocket-handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,MAAM,EAAC,MAAM,WAAW,CAAC;AAElD,OAAO,KAAK,EAAC,SAAS,EAAE,eAAe,EAAC,MAAM,IAAI,CAAC;AACnD,OAAO,EAEL,KAAK,QAAQ,EACb,KAAK,MAAM,EACZ,MAAM,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,KAAK;IAC9D,OAAO,EAAE,CAAC,CAAC;IACX,QAAQ,EAAE,QAAQ,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,KAAK,IAAI,CAAC;AAEvE,wBAAgB,uBAAuB,CAAC,CAAC,EACvC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,QAwB7B;AAED,wBAAgB,wBAAwB,CAAC,CAAC,EACxC,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAC7B,MAAM,EAAE,MAAM,QAWf"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import { IncomingMessage, Server } from 'node:http';
|
|
2
|
-
import { Socket } from 'node:net';
|
|
3
|
-
import { MESSAGE_TYPES, } from '../../types/processes.js';
|
|
4
|
-
export function installWebSocketHandoff(server, handoff) {
|
|
5
|
-
server.on('upgrade', (req, socket, head) => {
|
|
6
|
-
try {
|
|
7
|
-
const { payload, receiver } = handoff(req);
|
|
8
|
-
const { headers, method = 'GET' } = req;
|
|
9
|
-
const data = [
|
|
10
|
-
'handoff',
|
|
11
|
-
{
|
|
12
|
-
message: { headers, method },
|
|
13
|
-
head,
|
|
14
|
-
payload,
|
|
15
|
-
},
|
|
16
|
-
];
|
|
17
|
-
// "This event is guaranteed to be passed an instance of the <net.Socket> class"
|
|
18
|
-
// https://nodejs.org/api/http.html#event-upgrade
|
|
19
|
-
receiver.send(data, socket);
|
|
20
|
-
}
|
|
21
|
-
catch (error) {
|
|
22
|
-
socket.write(`HTTP/1.1 400 Bad Request\r\n${String(error)}`);
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
export function installWebSocketReceiver(server, receive, sender) {
|
|
28
|
-
sender.onMessageType('handoff', (msg, socket) => {
|
|
29
|
-
const { message, head, payload } = msg;
|
|
30
|
-
server.handleUpgrade(message, socket, Buffer.from(head), ws => receive(ws, payload));
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
//# sourceMappingURL=websocket-handoff.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"websocket-handoff.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/websocket-handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,MAAM,EAAC,MAAM,WAAW,CAAC;AAClD,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAC;AAEhC,OAAO,EACL,aAAa,GAGd,MAAM,0BAA0B,CAAC;AASlC,MAAM,UAAU,uBAAuB,CACrC,MAAc,EACd,OAA4B;IAE5B,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;QACzC,IAAI,CAAC;YACH,MAAM,EAAC,OAAO,EAAE,QAAQ,EAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;YACzC,MAAM,EAAC,OAAO,EAAE,MAAM,GAAG,KAAK,EAAC,GAAG,GAAG,CAAC;YAEtC,MAAM,IAAI,GAAG;gBACX,SAAS;gBACT;oBACE,OAAO,EAAE,EAAC,OAAO,EAAE,MAAM,EAAC;oBAC1B,IAAI;oBACJ,OAAO;iBACR;aACmB,CAAC;YAEvB,gFAAgF;YAChF,iDAAiD;YACjD,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,MAAgB,CAAC,CAAC;QACxC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,+BAA+B,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7D,OAAO;QACT,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,MAAuB,EACvB,OAA6B,EAC7B,MAAc;IAEd,MAAM,CAAC,aAAa,CAAa,SAAS,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;QAC1D,MAAM,EAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,GAAG,GAAG,CAAC;QACrC,MAAM,CAAC,aAAa,CAClB,OAA0B,EAC1B,MAAgB,EAChB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EACjB,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
type Window = {
|
|
2
|
-
start: number;
|
|
3
|
-
count: number;
|
|
4
|
-
};
|
|
5
|
-
/**
|
|
6
|
-
* The limiter is a sliding window rate limiter that allows a maximum
|
|
7
|
-
* number of mutations per window.
|
|
8
|
-
*
|
|
9
|
-
* The window is divided into two parts: the prev window and the next window.
|
|
10
|
-
* The prev window is the part of the window that has already passed, and the
|
|
11
|
-
* next window is the part of the window that is still in the future.
|
|
12
|
-
*
|
|
13
|
-
* The limiter keeps track of the number of mutations in each window. When the
|
|
14
|
-
* current time moves completely past the next window, the limiter creates new
|
|
15
|
-
* windows (this only happens if the limiter is not called for a long time).
|
|
16
|
-
* When the current time moves completely into the next window, the
|
|
17
|
-
* limiter rotates the windows.
|
|
18
|
-
*
|
|
19
|
-
* Case 1: need new windows
|
|
20
|
-
* |----|----|
|
|
21
|
-
* |----| (sliding window)
|
|
22
|
-
*
|
|
23
|
-
* Case 2: rotate windows
|
|
24
|
-
* |----|----|
|
|
25
|
-
* |----| (sliding window)
|
|
26
|
-
*
|
|
27
|
-
* or
|
|
28
|
-
*
|
|
29
|
-
* |----|----|
|
|
30
|
-
* |----| (sliding window)
|
|
31
|
-
*
|
|
32
|
-
* The leading edge of the sliding window is current time.
|
|
33
|
-
*
|
|
34
|
-
* The limiter increments the count for the prev window if the current time is
|
|
35
|
-
* in the prior window. Otherwise, it increments the count for the next
|
|
36
|
-
* window.
|
|
37
|
-
*
|
|
38
|
-
* The limiter computes the total mutations by: taking the number of mutation in the next window and
|
|
39
|
-
* adding the number of mutation from the prev window, weighted by
|
|
40
|
-
* the fraction of the window that has passed. The total mutations must be less
|
|
41
|
-
* than the maximum number of mutations allowed per window.
|
|
42
|
-
*
|
|
43
|
-
* |----|----|
|
|
44
|
-
* |----| (sliding window)
|
|
45
|
-
* ^-- the sliding window covers 25% of the prior window. Only 25% of that window's count counts.
|
|
46
|
-
* The entirety of the next window's count counts.
|
|
47
|
-
*/
|
|
48
|
-
export declare class SlidingWindowLimiter {
|
|
49
|
-
#private;
|
|
50
|
-
constructor(windowSizeMs: number, maxMutations: number);
|
|
51
|
-
canDo(): boolean;
|
|
52
|
-
totalCallsForTime(now: number): number;
|
|
53
|
-
get priorWindow(): Window;
|
|
54
|
-
get nextWindow(): Window;
|
|
55
|
-
}
|
|
56
|
-
export {};
|
|
57
|
-
//# sourceMappingURL=sliding-window-limiter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sliding-window-limiter.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/limiter/sliding-window-limiter.ts"],"names":[],"mappings":"AAEA,KAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,qBAAa,oBAAoB;;gBAOnB,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM;IAOtD,KAAK,IAAI,OAAO;IAsChB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM;IAuBtC,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,IAAI,UAAU,IAAI,MAAM,CAEvB;CA4BF"}
|