@rocicorp/zero 0.0.0-202410031711
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/deps/sqlite3/sqlite3.c +260574 -0
- package/deps/sqlite3/sqlite3.h +13572 -0
- package/deps/sqlite3/sqlite3ext.h +719 -0
- package/out/btree/b+tree.d.ts +471 -0
- package/out/btree/b+tree.d.ts.map +1 -0
- package/out/btree/b+tree.js +1708 -0
- package/out/btree/b+tree.js.map +1 -0
- package/out/btree/interfaces.d.ts +270 -0
- package/out/btree/interfaces.d.ts.map +1 -0
- package/out/btree/interfaces.js +3 -0
- package/out/btree/interfaces.js.map +1 -0
- package/out/chunk-2RUT5EQV.js +28 -0
- package/out/chunk-2RUT5EQV.js.map +7 -0
- package/out/datadog/src/datadog-log-sink.d.ts +20 -0
- package/out/datadog/src/datadog-log-sink.d.ts.map +1 -0
- package/out/datadog/src/datadog-log-sink.js +231 -0
- package/out/datadog/src/datadog-log-sink.js.map +1 -0
- package/out/datadog/src/mod.d.ts +2 -0
- package/out/datadog/src/mod.d.ts.map +1 -0
- package/out/react.js +108 -0
- package/out/react.js.map +7 -0
- package/out/replicache/src/async-iterable-to-array.d.ts +2 -0
- package/out/replicache/src/async-iterable-to-array.d.ts.map +1 -0
- package/out/replicache/src/bg-interval.d.ts +3 -0
- package/out/replicache/src/bg-interval.d.ts.map +1 -0
- package/out/replicache/src/binary-search.d.ts +15 -0
- package/out/replicache/src/binary-search.d.ts.map +1 -0
- package/out/replicache/src/broadcast-channel.d.ts +3 -0
- package/out/replicache/src/broadcast-channel.d.ts.map +1 -0
- package/out/replicache/src/btree/diff.d.ts +4 -0
- package/out/replicache/src/btree/diff.d.ts.map +1 -0
- package/out/replicache/src/btree/node.d.ts +125 -0
- package/out/replicache/src/btree/node.d.ts.map +1 -0
- package/out/replicache/src/btree/read.d.ts +32 -0
- package/out/replicache/src/btree/read.d.ts.map +1 -0
- package/out/replicache/src/btree/splice.d.ts +9 -0
- package/out/replicache/src/btree/splice.d.ts.map +1 -0
- package/out/replicache/src/btree/write.d.ts +24 -0
- package/out/replicache/src/btree/write.d.ts.map +1 -0
- package/out/replicache/src/call-default-fetch.d.ts +6 -0
- package/out/replicache/src/call-default-fetch.d.ts.map +1 -0
- package/out/replicache/src/config.d.ts +13 -0
- package/out/replicache/src/config.d.ts.map +1 -0
- package/out/replicache/src/connection-loop-delegates.d.ts +20 -0
- package/out/replicache/src/connection-loop-delegates.d.ts.map +1 -0
- package/out/replicache/src/connection-loop.d.ts +28 -0
- package/out/replicache/src/connection-loop.d.ts.map +1 -0
- package/out/replicache/src/cookies.d.ts +29 -0
- package/out/replicache/src/cookies.d.ts.map +1 -0
- package/out/replicache/src/dag/chunk.d.ts +35 -0
- package/out/replicache/src/dag/chunk.d.ts.map +1 -0
- package/out/replicache/src/dag/gc.d.ts +42 -0
- package/out/replicache/src/dag/gc.d.ts.map +1 -0
- package/out/replicache/src/dag/key.d.ts +26 -0
- package/out/replicache/src/dag/key.d.ts.map +1 -0
- package/out/replicache/src/dag/lazy-store.d.ts +181 -0
- package/out/replicache/src/dag/lazy-store.d.ts.map +1 -0
- package/out/replicache/src/dag/store-impl.d.ts +38 -0
- package/out/replicache/src/dag/store-impl.d.ts.map +1 -0
- package/out/replicache/src/dag/store.d.ts +36 -0
- package/out/replicache/src/dag/store.d.ts.map +1 -0
- package/out/replicache/src/dag/visitor.d.ts +13 -0
- package/out/replicache/src/dag/visitor.d.ts.map +1 -0
- package/out/replicache/src/db/commit.d.ts +133 -0
- package/out/replicache/src/db/commit.d.ts.map +1 -0
- package/out/replicache/src/db/index.d.ts +33 -0
- package/out/replicache/src/db/index.d.ts.map +1 -0
- package/out/replicache/src/db/read.d.ts +24 -0
- package/out/replicache/src/db/read.d.ts.map +1 -0
- package/out/replicache/src/db/rebase.d.ts +10 -0
- package/out/replicache/src/db/rebase.d.ts.map +1 -0
- package/out/replicache/src/db/scan.d.ts +15 -0
- package/out/replicache/src/db/scan.d.ts.map +1 -0
- package/out/replicache/src/db/write.d.ts +39 -0
- package/out/replicache/src/db/write.d.ts.map +1 -0
- package/out/replicache/src/error-responses.d.ts +26 -0
- package/out/replicache/src/error-responses.d.ts.map +1 -0
- package/out/replicache/src/filter-async-iterable.d.ts +10 -0
- package/out/replicache/src/filter-async-iterable.d.ts.map +1 -0
- package/out/replicache/src/format-version.d.ts +9 -0
- package/out/replicache/src/format-version.d.ts.map +1 -0
- package/out/replicache/src/frozen-json.d.ts +35 -0
- package/out/replicache/src/frozen-json.d.ts.map +1 -0
- package/out/replicache/src/get-default-puller.d.ts +14 -0
- package/out/replicache/src/get-default-puller.d.ts.map +1 -0
- package/out/replicache/src/get-default-pusher.d.ts +10 -0
- package/out/replicache/src/get-default-pusher.d.ts.map +1 -0
- package/out/replicache/src/hash.d.ts +29 -0
- package/out/replicache/src/hash.d.ts.map +1 -0
- package/out/replicache/src/http-request-info.d.ts +6 -0
- package/out/replicache/src/http-request-info.d.ts.map +1 -0
- package/out/replicache/src/impl.d.ts +4 -0
- package/out/replicache/src/impl.d.ts.map +1 -0
- package/out/replicache/src/index-defs.d.ts +36 -0
- package/out/replicache/src/index-defs.d.ts.map +1 -0
- package/out/replicache/src/iterable-union.d.ts +5 -0
- package/out/replicache/src/iterable-union.d.ts.map +1 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts +25 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts.map +1 -0
- package/out/replicache/src/kv/idb-store.d.ts +18 -0
- package/out/replicache/src/kv/idb-store.d.ts.map +1 -0
- package/out/replicache/src/kv/mem-store.d.ts +23 -0
- package/out/replicache/src/kv/mem-store.d.ts.map +1 -0
- package/out/replicache/src/kv/read-impl.d.ts +11 -0
- package/out/replicache/src/kv/read-impl.d.ts.map +1 -0
- package/out/replicache/src/kv/store.d.ts +76 -0
- package/out/replicache/src/kv/store.d.ts.map +1 -0
- package/out/replicache/src/kv/write-impl-base.d.ts +18 -0
- package/out/replicache/src/kv/write-impl-base.d.ts.map +1 -0
- package/out/replicache/src/kv/write-impl.d.ts +9 -0
- package/out/replicache/src/kv/write-impl.d.ts.map +1 -0
- package/out/replicache/src/lazy.d.ts +2 -0
- package/out/replicache/src/lazy.d.ts.map +1 -0
- package/out/replicache/src/log-options.d.ts +10 -0
- package/out/replicache/src/log-options.d.ts.map +1 -0
- package/out/replicache/src/merge-async-iterables.d.ts +16 -0
- package/out/replicache/src/merge-async-iterables.d.ts.map +1 -0
- package/out/replicache/src/mod.d.ts +38 -0
- package/out/replicache/src/mod.d.ts.map +1 -0
- package/out/replicache/src/mutation-recovery.d.ts +43 -0
- package/out/replicache/src/mutation-recovery.d.ts.map +1 -0
- package/out/replicache/src/new-client-channel.d.ts +6 -0
- package/out/replicache/src/new-client-channel.d.ts.map +1 -0
- package/out/replicache/src/on-persist-channel.d.ts +10 -0
- package/out/replicache/src/on-persist-channel.d.ts.map +1 -0
- package/out/replicache/src/patch-operation.d.ts +32 -0
- package/out/replicache/src/patch-operation.d.ts.map +1 -0
- package/out/replicache/src/pending-mutations.d.ts +14 -0
- package/out/replicache/src/pending-mutations.d.ts.map +1 -0
- package/out/replicache/src/persist/client-gc.d.ts +17 -0
- package/out/replicache/src/persist/client-gc.d.ts.map +1 -0
- package/out/replicache/src/persist/client-group-gc.d.ts +10 -0
- package/out/replicache/src/persist/client-group-gc.d.ts.map +1 -0
- package/out/replicache/src/persist/client-groups.d.ts +72 -0
- package/out/replicache/src/persist/client-groups.d.ts.map +1 -0
- package/out/replicache/src/persist/clients.d.ts +155 -0
- package/out/replicache/src/persist/clients.d.ts.map +1 -0
- package/out/replicache/src/persist/collect-idb-databases.d.ts +91 -0
- package/out/replicache/src/persist/collect-idb-databases.d.ts.map +1 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.d.ts +12 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.d.ts.map +1 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.d.ts +17 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.d.ts.map +1 -0
- package/out/replicache/src/persist/heartbeat.d.ts +9 -0
- package/out/replicache/src/persist/heartbeat.d.ts.map +1 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.d.ts +5 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.d.ts.map +1 -0
- package/out/replicache/src/persist/idb-databases-store.d.ts +24 -0
- package/out/replicache/src/persist/idb-databases-store.d.ts.map +1 -0
- package/out/replicache/src/persist/make-client-id.d.ts +6 -0
- package/out/replicache/src/persist/make-client-id.d.ts.map +1 -0
- package/out/replicache/src/persist/persist.d.ts +26 -0
- package/out/replicache/src/persist/persist.d.ts.map +1 -0
- package/out/replicache/src/persist/refresh.d.ts +13 -0
- package/out/replicache/src/persist/refresh.d.ts.map +1 -0
- package/out/replicache/src/process-scheduler.d.ts +20 -0
- package/out/replicache/src/process-scheduler.d.ts.map +1 -0
- package/out/replicache/src/puller.d.ts +61 -0
- package/out/replicache/src/puller.d.ts.map +1 -0
- package/out/replicache/src/pusher.d.ts +33 -0
- package/out/replicache/src/pusher.d.ts.map +1 -0
- package/out/replicache/src/replicache-impl.d.ts +321 -0
- package/out/replicache/src/replicache-impl.d.ts.map +1 -0
- package/out/replicache/src/replicache-options.d.ts +209 -0
- package/out/replicache/src/replicache-options.d.ts.map +1 -0
- package/out/replicache/src/replicache.d.ts +298 -0
- package/out/replicache/src/replicache.d.ts.map +1 -0
- package/out/replicache/src/request-idle.d.ts +6 -0
- package/out/replicache/src/request-idle.d.ts.map +1 -0
- package/out/replicache/src/scan-iterator.d.ts +127 -0
- package/out/replicache/src/scan-iterator.d.ts.map +1 -0
- package/out/replicache/src/scan-options.d.ts +67 -0
- package/out/replicache/src/scan-options.d.ts.map +1 -0
- package/out/replicache/src/set-interval-with-signal.d.ts +2 -0
- package/out/replicache/src/set-interval-with-signal.d.ts.map +1 -0
- package/out/replicache/src/size-of-value.d.ts +19 -0
- package/out/replicache/src/size-of-value.d.ts.map +1 -0
- package/out/replicache/src/subscriptions.d.ts +140 -0
- package/out/replicache/src/subscriptions.d.ts.map +1 -0
- package/out/replicache/src/sync/diff.d.ts +31 -0
- package/out/replicache/src/sync/diff.d.ts.map +1 -0
- package/out/replicache/src/sync/ids.d.ts +13 -0
- package/out/replicache/src/sync/ids.d.ts.map +1 -0
- package/out/replicache/src/sync/patch.d.ts +5 -0
- package/out/replicache/src/sync/patch.d.ts.map +1 -0
- package/out/replicache/src/sync/pull-error.d.ts +9 -0
- package/out/replicache/src/sync/pull-error.d.ts.map +1 -0
- package/out/replicache/src/sync/pull.d.ts +82 -0
- package/out/replicache/src/sync/pull.d.ts.map +1 -0
- package/out/replicache/src/sync/push.d.ts +65 -0
- package/out/replicache/src/sync/push.d.ts.map +1 -0
- package/out/replicache/src/sync/request-id.d.ts +10 -0
- package/out/replicache/src/sync/request-id.d.ts.map +1 -0
- package/out/replicache/src/sync/sync-head-name.d.ts +2 -0
- package/out/replicache/src/sync/sync-head-name.d.ts.map +1 -0
- package/out/replicache/src/test-license-key.d.ts +3 -0
- package/out/replicache/src/test-license-key.d.ts.map +1 -0
- package/out/replicache/src/to-error.d.ts +2 -0
- package/out/replicache/src/to-error.d.ts.map +1 -0
- package/out/replicache/src/transaction-closed-error.d.ts +12 -0
- package/out/replicache/src/transaction-closed-error.d.ts.map +1 -0
- package/out/replicache/src/transactions.d.ts +156 -0
- package/out/replicache/src/transactions.d.ts.map +1 -0
- package/out/replicache/src/types.d.ts +57 -0
- package/out/replicache/src/types.d.ts.map +1 -0
- package/out/replicache/src/version.d.ts +5 -0
- package/out/replicache/src/version.d.ts.map +1 -0
- package/out/replicache/src/with-transactions.d.ts +23 -0
- package/out/replicache/src/with-transactions.d.ts.map +1 -0
- package/out/shared/src/abort-error.d.ts +4 -0
- package/out/shared/src/abort-error.d.ts.map +1 -0
- package/out/shared/src/abort-error.js +4 -0
- package/out/shared/src/abort-error.js.map +1 -0
- package/out/shared/src/asserts.d.ts +17 -0
- package/out/shared/src/asserts.d.ts.map +1 -0
- package/out/shared/src/asserts.js +73 -0
- package/out/shared/src/asserts.js.map +1 -0
- package/out/shared/src/browser-env.d.ts +3 -0
- package/out/shared/src/browser-env.d.ts.map +1 -0
- package/out/shared/src/config.d.ts +3 -0
- package/out/shared/src/config.d.ts.map +1 -0
- package/out/shared/src/config.js +3 -0
- package/out/shared/src/config.js.map +1 -0
- package/out/shared/src/custom-key-map.d.ts +26 -0
- package/out/shared/src/custom-key-map.d.ts.map +1 -0
- package/out/shared/src/custom-key-map.js +65 -0
- package/out/shared/src/custom-key-map.js.map +1 -0
- package/out/shared/src/deep-clone.d.ts +4 -0
- package/out/shared/src/deep-clone.d.ts.map +1 -0
- package/out/shared/src/document-visible.d.ts +9 -0
- package/out/shared/src/document-visible.d.ts.map +1 -0
- package/out/shared/src/has-own.d.ts +5 -0
- package/out/shared/src/has-own.d.ts.map +1 -0
- package/out/shared/src/has-own.js +8 -0
- package/out/shared/src/has-own.js.map +1 -0
- package/out/shared/src/immutable.d.ts +11 -0
- package/out/shared/src/immutable.d.ts.map +1 -0
- package/out/shared/src/iterables.d.ts +11 -0
- package/out/shared/src/iterables.d.ts.map +1 -0
- package/out/shared/src/json-schema.d.ts +5 -0
- package/out/shared/src/json-schema.d.ts.map +1 -0
- package/out/shared/src/json-schema.js +36 -0
- package/out/shared/src/json-schema.js.map +1 -0
- package/out/shared/src/json.d.ts +55 -0
- package/out/shared/src/json.d.ts.map +1 -0
- package/out/shared/src/json.js +164 -0
- package/out/shared/src/json.js.map +1 -0
- package/out/shared/src/must.d.ts +2 -0
- package/out/shared/src/must.d.ts.map +1 -0
- package/out/shared/src/must.js +8 -0
- package/out/shared/src/must.js.map +1 -0
- package/out/shared/src/navigator.d.ts +7 -0
- package/out/shared/src/navigator.d.ts.map +1 -0
- package/out/shared/src/parse-big-int.d.ts +2 -0
- package/out/shared/src/parse-big-int.d.ts.map +1 -0
- package/out/shared/src/parse-big-int.js +11 -0
- package/out/shared/src/parse-big-int.js.map +1 -0
- package/out/shared/src/queue.d.ts +40 -0
- package/out/shared/src/queue.d.ts.map +1 -0
- package/out/shared/src/queue.js +118 -0
- package/out/shared/src/queue.js.map +1 -0
- package/out/shared/src/rand.d.ts +7 -0
- package/out/shared/src/rand.d.ts.map +1 -0
- package/out/shared/src/rand.js +11 -0
- package/out/shared/src/rand.js.map +1 -0
- package/out/shared/src/random-uint64.d.ts +2 -0
- package/out/shared/src/random-uint64.d.ts.map +1 -0
- package/out/shared/src/random-values.d.ts +2 -0
- package/out/shared/src/random-values.d.ts.map +1 -0
- package/out/shared/src/resolved-promises.d.ts +5 -0
- package/out/shared/src/resolved-promises.d.ts.map +1 -0
- package/out/shared/src/resolved-promises.js +5 -0
- package/out/shared/src/resolved-promises.js.map +1 -0
- package/out/shared/src/set-utils.d.ts +9 -0
- package/out/shared/src/set-utils.d.ts.map +1 -0
- package/out/shared/src/set-utils.js +60 -0
- package/out/shared/src/set-utils.js.map +1 -0
- package/out/shared/src/sleep.d.ts +15 -0
- package/out/shared/src/sleep.d.ts.map +1 -0
- package/out/shared/src/sleep.js +54 -0
- package/out/shared/src/sleep.js.map +1 -0
- package/out/shared/src/string-compare.d.ts +2 -0
- package/out/shared/src/string-compare.d.ts.map +1 -0
- package/out/shared/src/string-compare.js +10 -0
- package/out/shared/src/string-compare.js.map +1 -0
- package/out/shared/src/types.d.ts +2 -0
- package/out/shared/src/types.d.ts.map +1 -0
- package/out/shared/src/valita.d.ts +27 -0
- package/out/shared/src/valita.d.ts.map +1 -0
- package/out/shared/src/valita.js +118 -0
- package/out/shared/src/valita.js.map +1 -0
- package/out/shared/src/xxhash.d.ts +3 -0
- package/out/shared/src/xxhash.d.ts.map +1 -0
- package/out/shared/src/xxhash.js +4 -0
- package/out/shared/src/xxhash.js.map +1 -0
- package/out/zero/src/cli.d.ts +3 -0
- package/out/zero/src/cli.d.ts.map +1 -0
- package/out/zero/src/cli.js +3 -0
- package/out/zero/src/cli.js.map +1 -0
- package/out/zero/src/react.d.ts +2 -0
- package/out/zero/src/react.d.ts.map +1 -0
- package/out/zero/src/server/change-streamer.d.ts +2 -0
- package/out/zero/src/server/change-streamer.d.ts.map +1 -0
- package/out/zero/src/server/change-streamer.js +2 -0
- package/out/zero/src/server/change-streamer.js.map +1 -0
- package/out/zero/src/server/main.d.ts +2 -0
- package/out/zero/src/server/main.d.ts.map +1 -0
- package/out/zero/src/server/main.js +2 -0
- package/out/zero/src/server/main.js.map +1 -0
- package/out/zero/src/server/replicator.d.ts +2 -0
- package/out/zero/src/server/replicator.d.ts.map +1 -0
- package/out/zero/src/server/replicator.js +2 -0
- package/out/zero/src/server/replicator.js.map +1 -0
- package/out/zero/src/server/syncer.d.ts +2 -0
- package/out/zero/src/server/syncer.d.ts.map +1 -0
- package/out/zero/src/server/syncer.js +2 -0
- package/out/zero/src/server/syncer.js.map +1 -0
- package/out/zero/src/zero.d.ts +2 -0
- package/out/zero/src/zero.d.ts.map +1 -0
- package/out/zero-cache/src/config/zero-config.d.ts +1509 -0
- package/out/zero-cache/src/config/zero-config.d.ts.map +1 -0
- package/out/zero-cache/src/config/zero-config.js +227 -0
- package/out/zero-cache/src/config/zero-config.js.map +1 -0
- package/out/zero-cache/src/db/lite-tables.d.ts +5 -0
- package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -0
- package/out/zero-cache/src/db/lite-tables.js +75 -0
- package/out/zero-cache/src/db/lite-tables.js.map +1 -0
- package/out/zero-cache/src/db/migration-lite.d.ts +38 -0
- package/out/zero-cache/src/db/migration-lite.d.ts.map +1 -0
- package/out/zero-cache/src/db/migration-lite.js +161 -0
- package/out/zero-cache/src/db/migration-lite.js.map +1 -0
- package/out/zero-cache/src/db/migration.d.ts +38 -0
- package/out/zero-cache/src/db/migration.d.ts.map +1 -0
- package/out/zero-cache/src/db/migration.js +139 -0
- package/out/zero-cache/src/db/migration.js.map +1 -0
- package/out/zero-cache/src/db/statements.d.ts +31 -0
- package/out/zero-cache/src/db/statements.d.ts.map +1 -0
- package/out/zero-cache/src/db/statements.js +48 -0
- package/out/zero-cache/src/db/statements.js.map +1 -0
- package/out/zero-cache/src/db/transaction-pool.d.ts +187 -0
- package/out/zero-cache/src/db/transaction-pool.d.ts.map +1 -0
- package/out/zero-cache/src/db/transaction-pool.js +445 -0
- package/out/zero-cache/src/db/transaction-pool.js.map +1 -0
- package/out/zero-cache/src/server/change-streamer.d.ts +3 -0
- package/out/zero-cache/src/server/change-streamer.d.ts.map +1 -0
- package/out/zero-cache/src/server/change-streamer.js +30 -0
- package/out/zero-cache/src/server/change-streamer.js.map +1 -0
- package/out/zero-cache/src/server/logging.d.ts +6 -0
- package/out/zero-cache/src/server/logging.d.ts.map +1 -0
- package/out/zero-cache/src/server/logging.js +23 -0
- package/out/zero-cache/src/server/logging.js.map +1 -0
- package/out/zero-cache/src/server/main.d.ts +2 -0
- package/out/zero-cache/src/server/main.d.ts.map +1 -0
- package/out/zero-cache/src/server/main.js +92 -0
- package/out/zero-cache/src/server/main.js.map +1 -0
- package/out/zero-cache/src/server/replicator.d.ts +3 -0
- package/out/zero-cache/src/server/replicator.d.ts.map +1 -0
- package/out/zero-cache/src/server/replicator.js +35 -0
- package/out/zero-cache/src/server/replicator.js.map +1 -0
- package/out/zero-cache/src/server/syncer.d.ts +3 -0
- package/out/zero-cache/src/server/syncer.d.ts.map +1 -0
- package/out/zero-cache/src/server/syncer.js +45 -0
- package/out/zero-cache/src/server/syncer.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +23 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +98 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +39 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +212 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +110 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.js +7 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +19 -0
- package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/forwarder.js +56 -0
- package/out/zero-cache/src/services/change-streamer/forwarder.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts +14 -0
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js +206 -0
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts +6 -0
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +192 -0
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts +17 -0
- package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/lsn.js +17 -0
- package/out/zero-cache/src/services/change-streamer/pg/lsn.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts +6 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js +29 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/create.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +79 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js +237 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts +5 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js +111 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +26 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js +185 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts +11 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js +86 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts +19 -0
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.js +2 -0
- package/out/zero-cache/src/services/change-streamer/pg/shard-config.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts +4 -0
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +12 -0
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +31 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.js +2 -0
- package/out/zero-cache/src/services/change-streamer/schema/change.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts +4 -0
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/init.js +10 -0
- package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +22 -0
- package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/schema/tables.js +49 -0
- package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/storer.d.ts +22 -0
- package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/storer.js +157 -0
- package/out/zero-cache/src/services/change-streamer/storer.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +27 -0
- package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/subscriber.js +70 -0
- package/out/zero-cache/src/services/change-streamer/subscriber.js.map +1 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +20 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +1 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.js +36 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.js.map +1 -0
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts +19 -0
- package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts.map +1 -0
- package/out/zero-cache/src/services/dispatcher/dispatcher.js +55 -0
- package/out/zero-cache/src/services/dispatcher/dispatcher.js.map +1 -0
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts +11 -0
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts.map +1 -0
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.js +33 -0
- package/out/zero-cache/src/services/dispatcher/websocket-handoff.js.map +1 -0
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts +57 -0
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts.map +1 -0
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +130 -0
- package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +1 -0
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts +24 -0
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -0
- package/out/zero-cache/src/services/mutagen/mutagen.js +247 -0
- package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -0
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts +20 -0
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +1 -0
- package/out/zero-cache/src/services/mutagen/write-authorizer.js +187 -0
- package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +1 -0
- package/out/zero-cache/src/services/replicator/checkpointer.d.ts +79 -0
- package/out/zero-cache/src/services/replicator/checkpointer.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/checkpointer.js +124 -0
- package/out/zero-cache/src/services/replicator/checkpointer.js.map +1 -0
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +39 -0
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/incremental-sync.js +342 -0
- package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -0
- package/out/zero-cache/src/services/replicator/notifier.d.ts +30 -0
- package/out/zero-cache/src/services/replicator/notifier.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/notifier.js +54 -0
- package/out/zero-cache/src/services/replicator/notifier.js.map +1 -0
- package/out/zero-cache/src/services/replicator/replicator.d.ts +65 -0
- package/out/zero-cache/src/services/replicator/replicator.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/replicator.js +27 -0
- package/out/zero-cache/src/services/replicator/replicator.js.map +1 -0
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +35 -0
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/schema/change-log.js +78 -0
- package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -0
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +25 -0
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -0
- package/out/zero-cache/src/services/replicator/schema/replication-state.js +90 -0
- package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -0
- package/out/zero-cache/src/services/runner.d.ts +21 -0
- package/out/zero-cache/src/services/runner.d.ts.map +1 -0
- package/out/zero-cache/src/services/runner.js +63 -0
- package/out/zero-cache/src/services/runner.js.map +1 -0
- package/out/zero-cache/src/services/running-state.d.ts +56 -0
- package/out/zero-cache/src/services/running-state.d.ts.map +1 -0
- package/out/zero-cache/src/services/running-state.js +106 -0
- package/out/zero-cache/src/services/running-state.js.map +1 -0
- package/out/zero-cache/src/services/service.d.ts +29 -0
- package/out/zero-cache/src/services/service.d.ts.map +1 -0
- package/out/zero-cache/src/services/service.js +2 -0
- package/out/zero-cache/src/services/service.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +53 -0
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/client-handler.js +184 -0
- package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +44 -0
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/cvr-store.js +386 -0
- package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts +146 -0
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/cvr.js +446 -0
- package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts +22 -0
- package/out/zero-cache/src/services/view-syncer/database-storage.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/database-storage.js +129 -0
- package/out/zero-cache/src/services/view-syncer/database-storage.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +103 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +290 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts +54 -0
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js +181 -0
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts +4 -0
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js +12 -0
- package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +783 -0
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/types.js +213 -0
- package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +166 -0
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/snapshotter.js +374 -0
- package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +37 -0
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/view-syncer.js +522 -0
- package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -0
- package/out/zero-cache/src/types/bigint-json.d.ts +26 -0
- package/out/zero-cache/src/types/bigint-json.d.ts.map +1 -0
- package/out/zero-cache/src/types/bigint-json.js +49 -0
- package/out/zero-cache/src/types/bigint-json.js.map +1 -0
- package/out/zero-cache/src/types/error-for-client.d.ts +7 -0
- package/out/zero-cache/src/types/error-for-client.d.ts.map +1 -0
- package/out/zero-cache/src/types/error-for-client.js +17 -0
- package/out/zero-cache/src/types/error-for-client.js.map +1 -0
- package/out/zero-cache/src/types/lexi-version.d.ts +29 -0
- package/out/zero-cache/src/types/lexi-version.d.ts.map +1 -0
- package/out/zero-cache/src/types/lexi-version.js +36 -0
- package/out/zero-cache/src/types/lexi-version.js.map +1 -0
- package/out/zero-cache/src/types/lite.d.ts +11 -0
- package/out/zero-cache/src/types/lite.d.ts.map +1 -0
- package/out/zero-cache/src/types/lite.js +26 -0
- package/out/zero-cache/src/types/lite.js.map +1 -0
- package/out/zero-cache/src/types/names.d.ts +5 -0
- package/out/zero-cache/src/types/names.d.ts.map +1 -0
- package/out/zero-cache/src/types/names.js +4 -0
- package/out/zero-cache/src/types/names.js.map +1 -0
- package/out/zero-cache/src/types/pg.d.ts +31 -0
- package/out/zero-cache/src/types/pg.d.ts.map +1 -0
- package/out/zero-cache/src/types/pg.js +60 -0
- package/out/zero-cache/src/types/pg.js.map +1 -0
- package/out/zero-cache/src/types/processes.d.ts +57 -0
- package/out/zero-cache/src/types/processes.d.ts.map +1 -0
- package/out/zero-cache/src/types/processes.js +121 -0
- package/out/zero-cache/src/types/processes.js.map +1 -0
- package/out/zero-cache/src/types/row-key.d.ts +37 -0
- package/out/zero-cache/src/types/row-key.d.ts.map +1 -0
- package/out/zero-cache/src/types/row-key.js +64 -0
- package/out/zero-cache/src/types/row-key.js.map +1 -0
- package/out/zero-cache/src/types/satisfies.d.ts +14 -0
- package/out/zero-cache/src/types/satisfies.d.ts.map +1 -0
- package/out/zero-cache/src/types/satisfies.js +2 -0
- package/out/zero-cache/src/types/satisfies.js.map +1 -0
- package/out/zero-cache/src/types/specs.d.ts +29 -0
- package/out/zero-cache/src/types/specs.d.ts.map +1 -0
- package/out/zero-cache/src/types/specs.js +2 -0
- package/out/zero-cache/src/types/specs.js.map +1 -0
- package/out/zero-cache/src/types/sql.d.ts +11 -0
- package/out/zero-cache/src/types/sql.d.ts.map +1 -0
- package/out/zero-cache/src/types/sql.js +15 -0
- package/out/zero-cache/src/types/sql.js.map +1 -0
- package/out/zero-cache/src/types/streams.d.ts +33 -0
- package/out/zero-cache/src/types/streams.d.ts.map +1 -0
- package/out/zero-cache/src/types/streams.js +141 -0
- package/out/zero-cache/src/types/streams.js.map +1 -0
- package/out/zero-cache/src/types/subscription.d.ts +158 -0
- package/out/zero-cache/src/types/subscription.d.ts.map +1 -0
- package/out/zero-cache/src/types/subscription.js +233 -0
- package/out/zero-cache/src/types/subscription.js.map +1 -0
- package/out/zero-cache/src/types/timeout.d.ts +11 -0
- package/out/zero-cache/src/types/timeout.d.ts.map +1 -0
- package/out/zero-cache/src/types/timeout.js +23 -0
- package/out/zero-cache/src/types/timeout.js.map +1 -0
- package/out/zero-cache/src/types/url-params.d.ts +10 -0
- package/out/zero-cache/src/types/url-params.d.ts.map +1 -0
- package/out/zero-cache/src/types/url-params.js +35 -0
- package/out/zero-cache/src/types/url-params.js.map +1 -0
- package/out/zero-cache/src/workers/connection.d.ts +25 -0
- package/out/zero-cache/src/workers/connection.d.ts.map +1 -0
- package/out/zero-cache/src/workers/connection.js +189 -0
- package/out/zero-cache/src/workers/connection.js.map +1 -0
- package/out/zero-cache/src/workers/replicator.d.ts +17 -0
- package/out/zero-cache/src/workers/replicator.d.ts.map +1 -0
- package/out/zero-cache/src/workers/replicator.js +105 -0
- package/out/zero-cache/src/workers/replicator.js.map +1 -0
- package/out/zero-cache/src/workers/syncer.d.ts +28 -0
- package/out/zero-cache/src/workers/syncer.d.ts.map +1 -0
- package/out/zero-cache/src/workers/syncer.js +72 -0
- package/out/zero-cache/src/workers/syncer.js.map +1 -0
- package/out/zero-client/src/client/context.d.ts +23 -0
- package/out/zero-client/src/client/context.d.ts.map +1 -0
- package/out/zero-client/src/client/crud.d.ts +52 -0
- package/out/zero-client/src/client/crud.d.ts.map +1 -0
- package/out/zero-client/src/client/enable-analytics.d.ts +3 -0
- package/out/zero-client/src/client/enable-analytics.d.ts.map +1 -0
- package/out/zero-client/src/client/http-string.d.ts +7 -0
- package/out/zero-client/src/client/http-string.d.ts.map +1 -0
- package/out/zero-client/src/client/keys.d.ts +11 -0
- package/out/zero-client/src/client/keys.d.ts.map +1 -0
- package/out/zero-client/src/client/log-options.d.ts +12 -0
- package/out/zero-client/src/client/log-options.d.ts.map +1 -0
- package/out/zero-client/src/client/metrics.d.ts +115 -0
- package/out/zero-client/src/client/metrics.d.ts.map +1 -0
- package/out/zero-client/src/client/options.d.ts +94 -0
- package/out/zero-client/src/client/options.d.ts.map +1 -0
- package/out/zero-client/src/client/query-manager.d.ts +16 -0
- package/out/zero-client/src/client/query-manager.d.ts.map +1 -0
- package/out/zero-client/src/client/reload-error-handler.d.ts +5 -0
- package/out/zero-client/src/client/reload-error-handler.d.ts.map +1 -0
- package/out/zero-client/src/client/replicache-types.d.ts +48 -0
- package/out/zero-client/src/client/replicache-types.d.ts.map +1 -0
- package/out/zero-client/src/client/server-error.d.ts +12 -0
- package/out/zero-client/src/client/server-error.d.ts.map +1 -0
- package/out/zero-client/src/client/server-option.d.ts +3 -0
- package/out/zero-client/src/client/server-option.d.ts.map +1 -0
- package/out/zero-client/src/client/version.d.ts +5 -0
- package/out/zero-client/src/client/version.d.ts.map +1 -0
- package/out/zero-client/src/client/zero-poke-handler.d.ts +28 -0
- package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -0
- package/out/zero-client/src/client/zero.d.ts +183 -0
- package/out/zero-client/src/client/zero.d.ts.map +1 -0
- package/out/zero-client/src/mod.d.ts +9 -0
- package/out/zero-client/src/mod.d.ts.map +1 -0
- package/out/zero-client/src/util/nanoid.d.ts +2 -0
- package/out/zero-client/src/util/nanoid.d.ts.map +1 -0
- package/out/zero-client/src/util/socket.d.ts +3 -0
- package/out/zero-client/src/util/socket.d.ts.map +1 -0
- package/out/zero-protocol/src/ast.d.ts +69 -0
- package/out/zero-protocol/src/ast.d.ts.map +1 -0
- package/out/zero-protocol/src/ast.js +64 -0
- package/out/zero-protocol/src/ast.js.map +1 -0
- package/out/zero-protocol/src/change-desired-queries.d.ts +71 -0
- package/out/zero-protocol/src/change-desired-queries.d.ts.map +1 -0
- package/out/zero-protocol/src/change-desired-queries.js +10 -0
- package/out/zero-protocol/src/change-desired-queries.js.map +1 -0
- package/out/zero-protocol/src/clients-patch.d.ts +37 -0
- package/out/zero-protocol/src/clients-patch.d.ts.map +1 -0
- package/out/zero-protocol/src/clients-patch.js +15 -0
- package/out/zero-protocol/src/clients-patch.js.map +1 -0
- package/out/zero-protocol/src/connect.d.ts +88 -0
- package/out/zero-protocol/src/connect.d.ts.map +1 -0
- package/out/zero-protocol/src/connect.js +25 -0
- package/out/zero-protocol/src/connect.js.map +1 -0
- package/out/zero-protocol/src/delete-clients.d.ts +11 -0
- package/out/zero-protocol/src/delete-clients.d.ts.map +1 -0
- package/out/zero-protocol/src/delete-clients.js +9 -0
- package/out/zero-protocol/src/delete-clients.js.map +1 -0
- package/out/zero-protocol/src/down.d.ts +110 -0
- package/out/zero-protocol/src/down.d.ts.map +1 -0
- package/out/zero-protocol/src/down.js +8 -0
- package/out/zero-protocol/src/down.js.map +1 -0
- package/out/zero-protocol/src/entities-patch.d.ts +66 -0
- package/out/zero-protocol/src/entities-patch.d.ts.map +1 -0
- package/out/zero-protocol/src/entities-patch.js +27 -0
- package/out/zero-protocol/src/entities-patch.js.map +1 -0
- package/out/zero-protocol/src/entity.d.ts +9 -0
- package/out/zero-protocol/src/entity.d.ts.map +1 -0
- package/out/zero-protocol/src/entity.js +8 -0
- package/out/zero-protocol/src/entity.js.map +1 -0
- package/out/zero-protocol/src/error.d.ts +19 -0
- package/out/zero-protocol/src/error.d.ts.map +1 -0
- package/out/zero-protocol/src/error.js +26 -0
- package/out/zero-protocol/src/error.js.map +1 -0
- package/out/zero-protocol/src/mod.d.ts +16 -0
- package/out/zero-protocol/src/mod.d.ts.map +1 -0
- package/out/zero-protocol/src/mod.js +16 -0
- package/out/zero-protocol/src/mod.js.map +1 -0
- package/out/zero-protocol/src/ping.d.ts +6 -0
- package/out/zero-protocol/src/ping.d.ts.map +1 -0
- package/out/zero-protocol/src/ping.js +4 -0
- package/out/zero-protocol/src/ping.js.map +1 -0
- package/out/zero-protocol/src/poke.d.ts +236 -0
- package/out/zero-protocol/src/poke.d.ts.map +1 -0
- package/out/zero-protocol/src/poke.js +69 -0
- package/out/zero-protocol/src/poke.js.map +1 -0
- package/out/zero-protocol/src/pong.d.ts +6 -0
- package/out/zero-protocol/src/pong.d.ts.map +1 -0
- package/out/zero-protocol/src/pong.js +4 -0
- package/out/zero-protocol/src/pong.js.map +1 -0
- package/out/zero-protocol/src/pull.d.ts +26 -0
- package/out/zero-protocol/src/pull.d.ts.map +1 -0
- package/out/zero-protocol/src/pull.js +24 -0
- package/out/zero-protocol/src/pull.js.map +1 -0
- package/out/zero-protocol/src/push.d.ts +257 -0
- package/out/zero-protocol/src/push.d.ts.map +1 -0
- package/out/zero-protocol/src/push.js +77 -0
- package/out/zero-protocol/src/push.js.map +1 -0
- package/out/zero-protocol/src/queries-patch.d.ts +103 -0
- package/out/zero-protocol/src/queries-patch.d.ts.map +1 -0
- package/out/zero-protocol/src/queries-patch.js +17 -0
- package/out/zero-protocol/src/queries-patch.js.map +1 -0
- package/out/zero-protocol/src/up.d.ts +116 -0
- package/out/zero-protocol/src/up.d.ts.map +1 -0
- package/out/zero-protocol/src/up.js +9 -0
- package/out/zero-protocol/src/up.js.map +1 -0
- package/out/zero-protocol/src/version.d.ts +6 -0
- package/out/zero-protocol/src/version.d.ts.map +1 -0
- package/out/zero-protocol/src/version.js +4 -0
- package/out/zero-protocol/src/version.js.map +1 -0
- package/out/zero-react/src/mod.d.ts +3 -0
- package/out/zero-react/src/mod.d.ts.map +1 -0
- package/out/zero-react/src/use-query.d.ts +3 -0
- package/out/zero-react/src/use-query.d.ts.map +1 -0
- package/out/zero-react/src/use-zero.d.ts +8 -0
- package/out/zero-react/src/use-zero.d.ts.map +1 -0
- package/out/zero.js +7000 -0
- package/out/zero.js.map +7 -0
- package/out/zql/src/zql/ast/ast.d.ts +84 -0
- package/out/zql/src/zql/ast/ast.d.ts.map +1 -0
- package/out/zql/src/zql/ast/ast.js +54 -0
- package/out/zql/src/zql/ast/ast.js.map +1 -0
- package/out/zql/src/zql/builder/builder.d.ts +56 -0
- package/out/zql/src/zql/builder/builder.d.ts.map +1 -0
- package/out/zql/src/zql/builder/builder.js +112 -0
- package/out/zql/src/zql/builder/builder.js.map +1 -0
- package/out/zql/src/zql/builder/error.d.ts +3 -0
- package/out/zql/src/zql/builder/error.d.ts.map +1 -0
- package/out/zql/src/zql/builder/error.js +3 -0
- package/out/zql/src/zql/builder/error.js.map +1 -0
- package/out/zql/src/zql/builder/filter.d.ts +6 -0
- package/out/zql/src/zql/builder/filter.d.ts.map +1 -0
- package/out/zql/src/zql/builder/filter.js +53 -0
- package/out/zql/src/zql/builder/filter.js.map +1 -0
- package/out/zql/src/zql/builder/like.d.ts +3 -0
- package/out/zql/src/zql/builder/like.d.ts.map +1 -0
- package/out/zql/src/zql/builder/like.js +60 -0
- package/out/zql/src/zql/builder/like.js.map +1 -0
- package/out/zql/src/zql/ivm/array-view.d.ts +42 -0
- package/out/zql/src/zql/ivm/array-view.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/change.d.ts +44 -0
- package/out/zql/src/zql/ivm/change.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/change.js +2 -0
- package/out/zql/src/zql/ivm/change.js.map +1 -0
- package/out/zql/src/zql/ivm/data.d.ts +72 -0
- package/out/zql/src/zql/ivm/data.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/data.js +84 -0
- package/out/zql/src/zql/ivm/data.js.map +1 -0
- package/out/zql/src/zql/ivm/filter.d.ts +27 -0
- package/out/zql/src/zql/ivm/filter.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/filter.js +60 -0
- package/out/zql/src/zql/ivm/filter.js.map +1 -0
- package/out/zql/src/zql/ivm/join.d.ts +37 -0
- package/out/zql/src/zql/ivm/join.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/join.js +228 -0
- package/out/zql/src/zql/ivm/join.js.map +1 -0
- package/out/zql/src/zql/ivm/lookahead-iterator.d.ts +13 -0
- package/out/zql/src/zql/ivm/lookahead-iterator.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/lookahead-iterator.js +45 -0
- package/out/zql/src/zql/ivm/lookahead-iterator.js.map +1 -0
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts +10 -0
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js +34 -0
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js.map +1 -0
- package/out/zql/src/zql/ivm/memory-source.d.ts +65 -0
- package/out/zql/src/zql/ivm/memory-source.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/memory-source.js +508 -0
- package/out/zql/src/zql/ivm/memory-source.js.map +1 -0
- package/out/zql/src/zql/ivm/memory-storage.d.ts +18 -0
- package/out/zql/src/zql/ivm/memory-storage.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/operator.d.ts +89 -0
- package/out/zql/src/zql/ivm/operator.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/operator.js +2 -0
- package/out/zql/src/zql/ivm/operator.js.map +1 -0
- package/out/zql/src/zql/ivm/schema.d.ts +29 -0
- package/out/zql/src/zql/ivm/schema.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/schema.js +3 -0
- package/out/zql/src/zql/ivm/schema.js.map +1 -0
- package/out/zql/src/zql/ivm/skip.d.ts +24 -0
- package/out/zql/src/zql/ivm/skip.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/skip.js +113 -0
- package/out/zql/src/zql/ivm/skip.js.map +1 -0
- package/out/zql/src/zql/ivm/source.d.ts +57 -0
- package/out/zql/src/zql/ivm/source.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/source.js +2 -0
- package/out/zql/src/zql/ivm/source.js.map +1 -0
- package/out/zql/src/zql/ivm/stream.d.ts +11 -0
- package/out/zql/src/zql/ivm/stream.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/stream.js +19 -0
- package/out/zql/src/zql/ivm/stream.js.map +1 -0
- package/out/zql/src/zql/ivm/take.d.ts +24 -0
- package/out/zql/src/zql/ivm/take.d.ts.map +1 -0
- package/out/zql/src/zql/ivm/take.js +453 -0
- package/out/zql/src/zql/ivm/take.js.map +1 -0
- package/out/zql/src/zql/query/query-impl.d.ts +45 -0
- package/out/zql/src/zql/query/query-impl.d.ts.map +1 -0
- package/out/zql/src/zql/query/query.d.ts +130 -0
- package/out/zql/src/zql/query/query.d.ts.map +1 -0
- package/out/zql/src/zql/query/schema.d.ts +53 -0
- package/out/zql/src/zql/query/schema.d.ts.map +1 -0
- package/out/zql/src/zql/query/typed-view.d.ts +10 -0
- package/out/zql/src/zql/query/typed-view.d.ts.map +1 -0
- package/out/zqlite/src/db.d.ts +23 -0
- package/out/zqlite/src/db.d.ts.map +1 -0
- package/out/zqlite/src/db.js +117 -0
- package/out/zqlite/src/db.js.map +1 -0
- package/out/zqlite/src/internal/sql.d.ts +9 -0
- package/out/zqlite/src/internal/sql.d.ts.map +1 -0
- package/out/zqlite/src/internal/sql.js +14 -0
- package/out/zqlite/src/internal/sql.js.map +1 -0
- package/out/zqlite/src/internal/statement-cache.d.ts +67 -0
- package/out/zqlite/src/internal/statement-cache.d.ts.map +1 -0
- package/out/zqlite/src/internal/statement-cache.js +119 -0
- package/out/zqlite/src/internal/statement-cache.js.map +1 -0
- package/out/zqlite/src/table-source.d.ts +43 -0
- package/out/zqlite/src/table-source.d.ts.map +1 -0
- package/out/zqlite/src/table-source.js +393 -0
- package/out/zqlite/src/table-source.js.map +1 -0
- package/package.json +79 -0
- package/tool/install-sqlite3.js +37 -0
|
@@ -0,0 +1,522 @@
|
|
|
1
|
+
import { Lock } from '@rocicorp/lock';
|
|
2
|
+
import { assert, unreachable } from '../../../../shared/src/asserts.js';
|
|
3
|
+
import { CustomKeyMap } from '../../../../shared/src/custom-key-map.js';
|
|
4
|
+
import { must } from '../../../../shared/src/must.js';
|
|
5
|
+
import { difference } from '../../../../shared/src/set-utils.js';
|
|
6
|
+
import { stringify } from '../../../../zero-cache/src/types/bigint-json.js';
|
|
7
|
+
import { rowIDHash } from '../../../../zero-cache/src/types/row-key.js';
|
|
8
|
+
import { Subscription } from '../../types/subscription.js';
|
|
9
|
+
import { ZERO_VERSION_COLUMN_NAME } from '../replicator/schema/replication-state.js';
|
|
10
|
+
import { ClientHandler, } from './client-handler.js';
|
|
11
|
+
import { CVRStore } from './cvr-store.js';
|
|
12
|
+
import { CVRConfigDrivenUpdater, CVRQueryDrivenUpdater, } from './cvr.js';
|
|
13
|
+
import { PipelineDriver } from './pipeline-driver.js';
|
|
14
|
+
import { cmpVersions, versionFromString, versionString, versionToCookie, } from './schema/types.js';
|
|
15
|
+
const DEFAULT_KEEPALIVE_MS = 30_000;
|
|
16
|
+
export class ViewSyncerService {
|
|
17
|
+
id;
|
|
18
|
+
#lc;
|
|
19
|
+
#pipelines;
|
|
20
|
+
#stateChanges;
|
|
21
|
+
#keepaliveMs;
|
|
22
|
+
// Serialize on this lock for:
|
|
23
|
+
// (1) storage or database-dependent operations
|
|
24
|
+
// (2) updating member variables.
|
|
25
|
+
#lock = new Lock();
|
|
26
|
+
#clients = new Map();
|
|
27
|
+
#cvrStore;
|
|
28
|
+
#cvr;
|
|
29
|
+
#pipelinesSynced = false;
|
|
30
|
+
#pipelinesPaused = false;
|
|
31
|
+
constructor(lc, clientGroupID, db, pipelineDriver, versionChanges, keepaliveMs = DEFAULT_KEEPALIVE_MS) {
|
|
32
|
+
this.id = clientGroupID;
|
|
33
|
+
this.#lc = lc
|
|
34
|
+
.withContext('component', 'view-syncer')
|
|
35
|
+
.withContext('serviceID', this.id);
|
|
36
|
+
this.#pipelines = pipelineDriver;
|
|
37
|
+
this.#stateChanges = versionChanges;
|
|
38
|
+
this.#keepaliveMs = keepaliveMs;
|
|
39
|
+
this.#cvrStore = new CVRStore(lc, db, clientGroupID);
|
|
40
|
+
}
|
|
41
|
+
#runInLockWithCVR(fn) {
|
|
42
|
+
return this.#lock.withLock(async () => {
|
|
43
|
+
if (!this.#cvr) {
|
|
44
|
+
this.#cvr = await this.#cvrStore.load();
|
|
45
|
+
}
|
|
46
|
+
return fn(this.#cvr);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
#pipelinesReady() {
|
|
50
|
+
return this.#pipelinesSynced && !this.#pipelinesPaused;
|
|
51
|
+
}
|
|
52
|
+
async run() {
|
|
53
|
+
try {
|
|
54
|
+
for await (const { state } of this.#stateChanges) {
|
|
55
|
+
await this.#runInLockWithCVR(async (cvr) => {
|
|
56
|
+
if (state === 'maintenance') {
|
|
57
|
+
if (this.#pipelines.initialized()) {
|
|
58
|
+
this.#pipelines.release();
|
|
59
|
+
}
|
|
60
|
+
this.#pipelinesPaused = true; // Block access to pipelines until resume.
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
if (!this.#pipelines.initialized()) {
|
|
64
|
+
// On the first version-ready signal, connect to the replica.
|
|
65
|
+
this.#pipelines.init();
|
|
66
|
+
}
|
|
67
|
+
if (this.#pipelinesReady()) {
|
|
68
|
+
// Note: #pipelinesReady() means `paused === false`.
|
|
69
|
+
await this.#advancePipelines(cvr);
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
this.#pipelinesPaused = false;
|
|
73
|
+
// Advance the snapshot to the current version.
|
|
74
|
+
const version = this.#pipelines.advanceWithoutDiff();
|
|
75
|
+
const cvrVer = versionString(cvr.version);
|
|
76
|
+
if (version < cvr.version.stateVersion) {
|
|
77
|
+
this.#lc.debug?.(`replica@${version} is behind cvr@${cvrVer}`);
|
|
78
|
+
// Wait for the next advancement.
|
|
79
|
+
}
|
|
80
|
+
else if (version === cvr.version.stateVersion &&
|
|
81
|
+
this.#pipelinesSynced) {
|
|
82
|
+
// This happens when an advance-after-unpause lands on the same
|
|
83
|
+
// version, which is hopefully the common case. Nothing to do.
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.#lc.info?.(`init pipelines@${version} (cvr@${cvrVer})`);
|
|
87
|
+
// stateVersion matches the CVR for the first time,
|
|
88
|
+
// or it advanced beyond the CVR during a maintenance pause.
|
|
89
|
+
// (Clear and re-)initialize the pipelines.
|
|
90
|
+
this.#pipelines.clear();
|
|
91
|
+
this.#hydrateUnchangedQueries(cvr);
|
|
92
|
+
await this.#syncQueryPipelineSet(cvr);
|
|
93
|
+
this.#pipelinesSynced = true;
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
this.#cleanup();
|
|
98
|
+
}
|
|
99
|
+
catch (e) {
|
|
100
|
+
this.#lc.error?.(e);
|
|
101
|
+
this.#cleanup(e);
|
|
102
|
+
}
|
|
103
|
+
finally {
|
|
104
|
+
this.#lc.info?.('view-syncer stopped');
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
// The idleToken is an object associated with an idle timeout function,
|
|
108
|
+
// the latter of which checks the token with identity equality before
|
|
109
|
+
// executing. Setting the #idleToken to a new object or to `null`
|
|
110
|
+
// effectively cancels the previous timeout.
|
|
111
|
+
#idleToken = null;
|
|
112
|
+
#startIdleTimer(reason) {
|
|
113
|
+
if (this.#idleToken) {
|
|
114
|
+
// Previous timeout is canceled for efficiency
|
|
115
|
+
// (but not necessary for correctness).
|
|
116
|
+
clearTimeout(this.#idleToken?.timeoutID);
|
|
117
|
+
this.#lc.debug?.(`${reason}. resetting idle timer`);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
this.#lc.debug?.(`${reason}. starting idle timer`);
|
|
121
|
+
}
|
|
122
|
+
const idleToken = {};
|
|
123
|
+
this.#idleToken = idleToken;
|
|
124
|
+
idleToken.timeoutID = setTimeout(() => {
|
|
125
|
+
// If #idleToken has changed, this timeout is effectively canceled.
|
|
126
|
+
if (this.#idleToken === idleToken) {
|
|
127
|
+
this.#lc.info?.('shutting down after idle timeout');
|
|
128
|
+
this.#stateChanges.cancel(); // Note: #versionChanges.active becomes false.
|
|
129
|
+
}
|
|
130
|
+
}, this.#keepaliveMs);
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Guarantees that the ViewSyncer will remain running for at least
|
|
134
|
+
* its configured `keepaliveMs`. This is called when establishing a
|
|
135
|
+
* new connection to ensure that its associated ViewSyncer isn't
|
|
136
|
+
* shutdown before it receives the connection.
|
|
137
|
+
*
|
|
138
|
+
* @return `true` if the ViewSyncer will stay alive, `false` if the
|
|
139
|
+
* ViewSyncer is shutting down.
|
|
140
|
+
*/
|
|
141
|
+
keepalive() {
|
|
142
|
+
if (!this.#stateChanges.active) {
|
|
143
|
+
return false;
|
|
144
|
+
}
|
|
145
|
+
if (this.#idleToken) {
|
|
146
|
+
// Resets the idle timer for another `keepaliveMs`.
|
|
147
|
+
this.#startIdleTimer('received keepalive');
|
|
148
|
+
}
|
|
149
|
+
return true;
|
|
150
|
+
}
|
|
151
|
+
#deleteClient(clientID, client) {
|
|
152
|
+
// Note: The CVR is not needed here so there's no need to call runInLockWithCVR().
|
|
153
|
+
return this.#lock.withLock(() => {
|
|
154
|
+
const c = this.#clients.get(clientID);
|
|
155
|
+
if (c === client) {
|
|
156
|
+
this.#clients.delete(clientID);
|
|
157
|
+
if (this.#clients.size === 0) {
|
|
158
|
+
this.#startIdleTimer('no more clients');
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
async initConnection(ctx, initConnectionMessage) {
|
|
164
|
+
const { clientID, wsID, baseCookie } = ctx;
|
|
165
|
+
const lc = this.#lc
|
|
166
|
+
.withContext('clientID', clientID)
|
|
167
|
+
.withContext('wsID', wsID);
|
|
168
|
+
// Setup the downstream connection.
|
|
169
|
+
const downstream = Subscription.create({
|
|
170
|
+
cleanup: (_, err) => {
|
|
171
|
+
err
|
|
172
|
+
? lc.error?.(`client closed with error`, err)
|
|
173
|
+
: lc.info?.('client closed');
|
|
174
|
+
void this.#deleteClient(clientID, newClient);
|
|
175
|
+
},
|
|
176
|
+
});
|
|
177
|
+
const newClient = new ClientHandler(lc, this.id, clientID, wsID, baseCookie, downstream);
|
|
178
|
+
await this.#runInLockForClient(ctx, initConnectionMessage, this.#patchQueries, newClient);
|
|
179
|
+
return downstream;
|
|
180
|
+
}
|
|
181
|
+
async changeDesiredQueries(ctx, msg) {
|
|
182
|
+
await this.#runInLockForClient(ctx, msg, this.#patchQueries);
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Runs the given `fn` to process the `msg` from within the `#lock`,
|
|
186
|
+
* optionally adding the `newClient` if supplied.
|
|
187
|
+
*/
|
|
188
|
+
async #runInLockForClient(ctx, msg, fn, newClient) {
|
|
189
|
+
const { clientID, wsID } = ctx;
|
|
190
|
+
const [cmd, body] = msg;
|
|
191
|
+
const lc = this.#lc
|
|
192
|
+
.withContext('clientID', clientID)
|
|
193
|
+
.withContext('wsID', wsID)
|
|
194
|
+
.withContext('cmd', cmd);
|
|
195
|
+
let client;
|
|
196
|
+
try {
|
|
197
|
+
await this.#runInLockWithCVR(cvr => {
|
|
198
|
+
lc.debug?.(cmd, body);
|
|
199
|
+
if (newClient) {
|
|
200
|
+
assert(newClient.wsID === wsID);
|
|
201
|
+
this.#clients.get(clientID)?.close();
|
|
202
|
+
this.#clients.set(clientID, newClient);
|
|
203
|
+
client = newClient;
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
client = this.#clients.get(clientID);
|
|
207
|
+
if (client?.wsID !== wsID) {
|
|
208
|
+
// Only respond to messages of the currently connected client.
|
|
209
|
+
// Past connections may have been dropped due to an error, so consider them invalid.
|
|
210
|
+
lc.info?.(`client no longer connected. dropping ${cmd} message`);
|
|
211
|
+
return;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
return fn(lc, clientID, body, cvr);
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
catch (e) {
|
|
218
|
+
lc.error?.(`closing connection with error`, e);
|
|
219
|
+
client?.fail(e);
|
|
220
|
+
throw e;
|
|
221
|
+
}
|
|
222
|
+
// Clear and cancel any idle timeout.
|
|
223
|
+
if (this.#idleToken) {
|
|
224
|
+
clearTimeout(this.#idleToken.timeoutID);
|
|
225
|
+
this.#idleToken = null;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
// Must be called from within #lock.
|
|
229
|
+
#patchQueries = async (lc, clientID, { desiredQueriesPatch }, cvr) => {
|
|
230
|
+
// Apply requested patches.
|
|
231
|
+
if (desiredQueriesPatch.length) {
|
|
232
|
+
lc.debug?.(`applying ${desiredQueriesPatch.length} query patches`);
|
|
233
|
+
const updater = new CVRConfigDrivenUpdater(this.#cvrStore, cvr);
|
|
234
|
+
const added = [];
|
|
235
|
+
for (const patch of desiredQueriesPatch) {
|
|
236
|
+
switch (patch.op) {
|
|
237
|
+
case 'put':
|
|
238
|
+
added.push(...updater.putDesiredQueries(clientID, { [patch.hash]: patch.ast }));
|
|
239
|
+
break;
|
|
240
|
+
case 'del':
|
|
241
|
+
updater.deleteDesiredQueries(clientID, [patch.hash]);
|
|
242
|
+
break;
|
|
243
|
+
case 'clear':
|
|
244
|
+
updater.clearDesiredQueries(clientID);
|
|
245
|
+
break;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
this.#cvr = (await updater.flush(lc)).cvr;
|
|
249
|
+
cvr = this.#cvr; // For #syncQueryPipelineSet().
|
|
250
|
+
}
|
|
251
|
+
if (this.#pipelinesReady()) {
|
|
252
|
+
await this.#syncQueryPipelineSet(cvr);
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
/**
|
|
256
|
+
* Adds and hydrates pipelines for queries whose results are already
|
|
257
|
+
* recorded in the CVR. Namely:
|
|
258
|
+
*
|
|
259
|
+
* 1. The CVR state version and database version are the same.
|
|
260
|
+
* 2. The transformation hash of the queries equal those in the CVR.
|
|
261
|
+
*
|
|
262
|
+
* Note that by definition, only "got" queries can satisfy condition (2),
|
|
263
|
+
* as desired queries do not have a transformation hash.
|
|
264
|
+
*
|
|
265
|
+
* This is an initialization step that sets up pipeline state without
|
|
266
|
+
* the expensive of loading and diffing CVR row state.
|
|
267
|
+
*
|
|
268
|
+
* This must be called from within the #lock.
|
|
269
|
+
*/
|
|
270
|
+
#hydrateUnchangedQueries(cvr) {
|
|
271
|
+
assert(this.#pipelines.initialized());
|
|
272
|
+
const dbVersion = this.#pipelines.currentVersion();
|
|
273
|
+
const cvrVersion = cvr.version;
|
|
274
|
+
if (cvrVersion.stateVersion !== dbVersion) {
|
|
275
|
+
this.#lc.info?.(`CVR (${versionToCookie(cvrVersion)}) is behind db ${dbVersion}`);
|
|
276
|
+
return; // hydration needs to be run with the CVR updater.
|
|
277
|
+
}
|
|
278
|
+
const gotQueries = Object.entries(cvr.queries).filter(([_, state]) => state.transformationHash !== undefined);
|
|
279
|
+
for (const [hash, query] of gotQueries) {
|
|
280
|
+
const { ast, transformationHash } = query;
|
|
281
|
+
if (!query.internal && Object.keys(query.desiredBy).length === 0) {
|
|
282
|
+
continue; // No longer desired.
|
|
283
|
+
}
|
|
284
|
+
const newTransformationHash = hash; // Currently, no transformations are done.
|
|
285
|
+
if (newTransformationHash !== transformationHash) {
|
|
286
|
+
continue; // Query results may have changed.
|
|
287
|
+
}
|
|
288
|
+
const start = Date.now();
|
|
289
|
+
let count = 0;
|
|
290
|
+
for (const _ of this.#pipelines.addQuery(hash, ast)) {
|
|
291
|
+
count++;
|
|
292
|
+
}
|
|
293
|
+
const elapsed = Date.now() - start;
|
|
294
|
+
this.#lc.debug?.(`hydrated ${count} rows for ${hash} (${elapsed} ms)`);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Adds and/or removes queries to/from the PipelineDriver to bring it
|
|
299
|
+
* in sync with the set of queries in the CVR (both got and desired).
|
|
300
|
+
* If queries are added, removed, or queried due to a new state version,
|
|
301
|
+
* a new CVR version is created and pokes sent to connected clients.
|
|
302
|
+
*
|
|
303
|
+
* This must be called from within the #lock.
|
|
304
|
+
*/
|
|
305
|
+
async #syncQueryPipelineSet(cvr) {
|
|
306
|
+
assert(this.#pipelines.initialized());
|
|
307
|
+
const lc = this.#lc.withContext('cvrVersion', versionString(cvr.version));
|
|
308
|
+
const hydratedQueries = this.#pipelines.addedQueries();
|
|
309
|
+
const allClientQueries = new Set(Object.keys(cvr.queries));
|
|
310
|
+
const desiredClientQueries = new Set(Object.keys(cvr.queries).filter(id => {
|
|
311
|
+
const q = cvr.queries[id];
|
|
312
|
+
return q.internal || Object.keys(q.desiredBy).length > 0;
|
|
313
|
+
}));
|
|
314
|
+
const addQueries = [...difference(desiredClientQueries, hydratedQueries)];
|
|
315
|
+
const removeQueries = [
|
|
316
|
+
...difference(allClientQueries, desiredClientQueries),
|
|
317
|
+
];
|
|
318
|
+
if (addQueries.length > 0 || removeQueries.length > 0) {
|
|
319
|
+
// Note: clients are caught up as part of #addAndRemoveQueries().
|
|
320
|
+
await this.#addAndRemoveQueries(lc, cvr, addQueries, removeQueries);
|
|
321
|
+
}
|
|
322
|
+
else {
|
|
323
|
+
await this.#catchupClients(lc, cvr);
|
|
324
|
+
}
|
|
325
|
+
// If CVR was non-empty, then the CVR, database, and all clients
|
|
326
|
+
// should now be at the same version.
|
|
327
|
+
if (allClientQueries.size) {
|
|
328
|
+
const cvrVersion = must(this.#cvr).version;
|
|
329
|
+
const dbVersion = this.#pipelines.currentVersion();
|
|
330
|
+
assert(cvrVersion.stateVersion === dbVersion, `CVR@${versionString(cvrVersion)}" does not match DB@${dbVersion}`);
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
// This must be called from within the #lock.
|
|
334
|
+
async #addAndRemoveQueries(lc, cvr, addQueries, removeQueries) {
|
|
335
|
+
assert(addQueries.length > 0 || removeQueries.length > 0);
|
|
336
|
+
const start = Date.now();
|
|
337
|
+
const stateVersion = this.#pipelines.currentVersion();
|
|
338
|
+
lc = lc.withContext('stateVersion', stateVersion);
|
|
339
|
+
lc.info?.(`hydrating ${addQueries.length} queries`);
|
|
340
|
+
const updater = new CVRQueryDrivenUpdater(this.#cvrStore, cvr, stateVersion);
|
|
341
|
+
// Note: This kicks of background PG queries for CVR data associated with the
|
|
342
|
+
// executed and removed queries.
|
|
343
|
+
const { newVersion, queryPatches } = updater.trackQueries(lc, addQueries.map(hash => ({ id: hash, transformationHash: hash })), removeQueries);
|
|
344
|
+
const pokers = [...this.#clients.values()].map(c => c.startPoke(newVersion));
|
|
345
|
+
for (const patch of queryPatches) {
|
|
346
|
+
pokers.forEach(poker => poker.addPatch(patch));
|
|
347
|
+
}
|
|
348
|
+
// Removing queries is easy. The pipelines are dropped, and the CVR
|
|
349
|
+
// updater handles the updates and pokes.
|
|
350
|
+
for (const hash of removeQueries) {
|
|
351
|
+
this.#pipelines.removeQuery(hash);
|
|
352
|
+
}
|
|
353
|
+
for (const hash of addQueries) {
|
|
354
|
+
const { ast } = cvr.queries[hash];
|
|
355
|
+
lc.debug?.(`adding pipeline for query ${hash}`, ast);
|
|
356
|
+
await this.#processChanges(lc, this.#pipelines.addQuery(hash, ast), updater, pokers);
|
|
357
|
+
}
|
|
358
|
+
lc.debug?.(`generating delete patches`);
|
|
359
|
+
for (const patch of await updater.deleteUnreferencedRows()) {
|
|
360
|
+
pokers.forEach(poker => poker.addPatch(patch));
|
|
361
|
+
}
|
|
362
|
+
// Commit the changes and update the CVR snapshot.
|
|
363
|
+
this.#cvr = (await updater.flush(lc)).cvr;
|
|
364
|
+
// Before ending the poke, catch up clients that were behind the old CVR.
|
|
365
|
+
await this.#catchupClients(lc, cvr, addQueries, pokers);
|
|
366
|
+
// Signal clients to commit.
|
|
367
|
+
pokers.forEach(poker => poker.end());
|
|
368
|
+
lc.info?.(`finished processing queries (${Date.now() - start} ms)`);
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* @param cvr The CVR to which clients should be caught up to. This does
|
|
372
|
+
* not necessarily need to be the current CVR.
|
|
373
|
+
* @param excludeQueryHashes Exclude patches from rows associated with
|
|
374
|
+
* the specified queries.
|
|
375
|
+
* @param usePokers If specified, sends pokes on existing PokeHandlers,
|
|
376
|
+
* in which case the caller is responsible for sending the `pokeEnd`
|
|
377
|
+
* messages. If unspecified, the pokes will be started and ended
|
|
378
|
+
* using the version from the supplied `cvr`.
|
|
379
|
+
*/
|
|
380
|
+
// Must be called within #lock
|
|
381
|
+
async #catchupClients(lc, cvr, excludeQueryHashes = [], usePokers) {
|
|
382
|
+
const pokers = usePokers ??
|
|
383
|
+
[...this.#clients.values()].map(c => c.startPoke(cvr.version));
|
|
384
|
+
const catchupFrom = [...this.#clients.values()]
|
|
385
|
+
.map(c => c.version())
|
|
386
|
+
.reduce((a, b) => (cmpVersions(a, b) < 0 ? a : b), cvr.version);
|
|
387
|
+
const rowPatches = this.#cvrStore.catchupRowPatches(lc, catchupFrom, cvr, excludeQueryHashes);
|
|
388
|
+
const configPatches = this.#cvrStore.catchupConfigPatches(lc, catchupFrom, cvr);
|
|
389
|
+
for (const patch of await configPatches) {
|
|
390
|
+
pokers.forEach(poker => poker.addPatch(patch));
|
|
391
|
+
}
|
|
392
|
+
let rowPatchCount = 0;
|
|
393
|
+
for await (const rows of rowPatches) {
|
|
394
|
+
for (const row of rows) {
|
|
395
|
+
const { schema, table } = row;
|
|
396
|
+
const rowKey = row.rowKey;
|
|
397
|
+
const toVersion = versionFromString(row.patchVersion);
|
|
398
|
+
const id = { schema, table, rowKey };
|
|
399
|
+
let patch;
|
|
400
|
+
if (!row.refCounts) {
|
|
401
|
+
patch = { type: 'row', op: 'del', id };
|
|
402
|
+
}
|
|
403
|
+
else {
|
|
404
|
+
const row = must(this.#pipelines.getRow(table, rowKey), `Missing row ${table}:${stringify(rowKey)}`);
|
|
405
|
+
const { contents } = contentsAndVersion(row);
|
|
406
|
+
patch = { type: 'row', op: 'put', id, contents };
|
|
407
|
+
}
|
|
408
|
+
const patchToVersion = { patch, toVersion };
|
|
409
|
+
pokers.forEach(poker => poker.addPatch(patchToVersion));
|
|
410
|
+
rowPatchCount++;
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
lc.debug?.(`sent ${rowPatchCount} row patches`);
|
|
414
|
+
if (!usePokers) {
|
|
415
|
+
pokers.forEach(poker => poker.end());
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
async #processChanges(lc, changes, updater, pokers) {
|
|
419
|
+
const start = Date.now();
|
|
420
|
+
const rows = new CustomKeyMap(rowIDHash);
|
|
421
|
+
let total = 0;
|
|
422
|
+
// eslint-disable-next-line require-await
|
|
423
|
+
const processBatch = async () => {
|
|
424
|
+
const elapsed = Date.now() - start;
|
|
425
|
+
total += rows.size;
|
|
426
|
+
lc.debug?.(`processing ${rows.size} (of ${total}) rows (${elapsed} ms)`);
|
|
427
|
+
const patches = await updater.received(this.#lc, rows);
|
|
428
|
+
patches.forEach(patch => pokers.forEach(poker => poker.addPatch(patch)));
|
|
429
|
+
rows.clear();
|
|
430
|
+
};
|
|
431
|
+
for (const change of changes) {
|
|
432
|
+
const { type, queryHash, table, rowKey, row } = change;
|
|
433
|
+
const rowID = { schema: '', table, rowKey: rowKey };
|
|
434
|
+
let parsedRow = rows.get(rowID);
|
|
435
|
+
let rc;
|
|
436
|
+
if (!parsedRow) {
|
|
437
|
+
parsedRow = { refCounts: {} };
|
|
438
|
+
rows.set(rowID, parsedRow);
|
|
439
|
+
rc = 0;
|
|
440
|
+
}
|
|
441
|
+
else {
|
|
442
|
+
rc = parsedRow.refCounts[queryHash];
|
|
443
|
+
}
|
|
444
|
+
const updateVersion = (row) => {
|
|
445
|
+
if (!parsedRow.version) {
|
|
446
|
+
const { version, contents } = contentsAndVersion(row);
|
|
447
|
+
parsedRow.version = version;
|
|
448
|
+
parsedRow.contents = contents;
|
|
449
|
+
}
|
|
450
|
+
};
|
|
451
|
+
switch (type) {
|
|
452
|
+
case 'add':
|
|
453
|
+
updateVersion(row);
|
|
454
|
+
rc++;
|
|
455
|
+
break;
|
|
456
|
+
case 'edit':
|
|
457
|
+
updateVersion(row);
|
|
458
|
+
// No update to rc.
|
|
459
|
+
break;
|
|
460
|
+
case 'remove':
|
|
461
|
+
rc--;
|
|
462
|
+
break;
|
|
463
|
+
default:
|
|
464
|
+
unreachable(type);
|
|
465
|
+
}
|
|
466
|
+
parsedRow.refCounts[queryHash] = rc;
|
|
467
|
+
if (rows.size % CURSOR_PAGE_SIZE === 0) {
|
|
468
|
+
await processBatch();
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
if (rows.size) {
|
|
472
|
+
await processBatch();
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
/**
|
|
476
|
+
* Advance to the current snapshot of the replica and apply / send
|
|
477
|
+
* changes.
|
|
478
|
+
*
|
|
479
|
+
* Must be called from within the #lock.
|
|
480
|
+
*/
|
|
481
|
+
async #advancePipelines(cvr) {
|
|
482
|
+
assert(this.#pipelines.initialized());
|
|
483
|
+
const start = Date.now();
|
|
484
|
+
const { version, numChanges, changes } = this.#pipelines.advance();
|
|
485
|
+
const lc = this.#lc.withContext('newVersion', version);
|
|
486
|
+
// Probably need a new updater type. CVRAdvancementUpdater?
|
|
487
|
+
const updater = new CVRQueryDrivenUpdater(this.#cvrStore, cvr, version);
|
|
488
|
+
const pokers = [...this.#clients.values()].map(c => c.startPoke(updater.updatedVersion()));
|
|
489
|
+
lc.debug?.(`applying ${numChanges} to advance to ${version}`);
|
|
490
|
+
await this.#processChanges(lc, changes, updater, pokers);
|
|
491
|
+
// Commit the changes and update the CVR snapshot.
|
|
492
|
+
this.#cvr = (await updater.flush(lc)).cvr;
|
|
493
|
+
// Signal clients to commit.
|
|
494
|
+
pokers.forEach(poker => poker.end());
|
|
495
|
+
lc.info?.(`finished processing advancement (${Date.now() - start} ms)`);
|
|
496
|
+
}
|
|
497
|
+
// eslint-disable-next-line require-await
|
|
498
|
+
async stop() {
|
|
499
|
+
this.#lc.info?.('stopping view syncer');
|
|
500
|
+
this.#stateChanges.cancel();
|
|
501
|
+
}
|
|
502
|
+
#cleanup(err) {
|
|
503
|
+
this.#pipelines.destroy();
|
|
504
|
+
for (const client of this.#clients.values()) {
|
|
505
|
+
if (err) {
|
|
506
|
+
client.fail(err);
|
|
507
|
+
}
|
|
508
|
+
else {
|
|
509
|
+
client.close();
|
|
510
|
+
}
|
|
511
|
+
}
|
|
512
|
+
}
|
|
513
|
+
}
|
|
514
|
+
const CURSOR_PAGE_SIZE = 10000;
|
|
515
|
+
function contentsAndVersion(row) {
|
|
516
|
+
const { [ZERO_VERSION_COLUMN_NAME]: version, ...contents } = row;
|
|
517
|
+
if (typeof version !== 'string' || version.length === 0) {
|
|
518
|
+
throw new Error(`Invalid _0_version in ${stringify(row)}`);
|
|
519
|
+
}
|
|
520
|
+
return { contents, version };
|
|
521
|
+
}
|
|
522
|
+
//# sourceMappingURL=view-syncer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"view-syncer.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/view-syncer/view-syncer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import * as v from '../../../shared/src/valita.js';
|
|
2
|
+
export type JSONValue = null | string | number | bigint | boolean | Date | readonly JSONValue[] | JSONObject;
|
|
3
|
+
export type JSONObject = {
|
|
4
|
+
readonly [prop: string]: JSONValue | undefined;
|
|
5
|
+
};
|
|
6
|
+
export declare const jsonValueSchema: v.Type<JSONValue>;
|
|
7
|
+
export declare const jsonObjectSchema: v.Type<Readonly<Record<string, JSONValue>>>;
|
|
8
|
+
/**
|
|
9
|
+
* Parses JSON strings that may contain arbitrarily large integers. Integers
|
|
10
|
+
* larger than {@link Number.MAX_SAFE_INTEGER} are deserialized as a `bigint`.
|
|
11
|
+
*/
|
|
12
|
+
export declare function parse(str: string, reviver?: (k: string, v: unknown) => unknown): JSONValue;
|
|
13
|
+
/**
|
|
14
|
+
* Stringifies objects to JSON, supporting objects containing bigint values.
|
|
15
|
+
* Note that the resulting JSON string may not be deserializable by
|
|
16
|
+
* all environments, but it is supported by Postgres. The string should be
|
|
17
|
+
* deserialized with the corresponding {@link parse} method that will represent
|
|
18
|
+
* large numbers as bigints. From there it is up to the application to suitably
|
|
19
|
+
* handle bigints passed to downstream logic.
|
|
20
|
+
*/
|
|
21
|
+
export declare function stringify(obj: unknown, replacer?: (string | number)[] | ((key: string, value: unknown) => unknown) | null, indent?: string | number): string;
|
|
22
|
+
export declare const BigIntJSON: {
|
|
23
|
+
readonly parse: typeof parse;
|
|
24
|
+
readonly stringify: typeof stringify;
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=bigint-json.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bigint-json.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/types/bigint-json.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,CAAC,MAAM,sBAAsB,CAAC;AAW1C,MAAM,MAAM,SAAS,GACjB,IAAI,GACJ,MAAM,GACN,MAAM,GACN,MAAM,GACN,OAAO,GACP,IAAI,GACJ,SAAS,SAAS,EAAE,GACpB,UAAU,CAAC;AAEf,MAAM,MAAM,UAAU,GAAG;IAAC,QAAQ,EAAE,IAAI,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,CAAA;CAAC,CAAC;AAE1E,eAAO,MAAM,eAAe,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAY5C,CAAC;AAEH,eAAO,MAAM,gBAAgB,6CAAwC,CAAC;AAEtE;;;GAGG;AACH,wBAAgB,KAAK,CACnB,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,KAAK,OAAO,GAC3C,SAAS,CAEX;AAOD;;;;;;;GAOG;AACH,wBAAgB,SAAS,CACvB,GAAG,EAAE,OAAO,EACZ,QAAQ,CAAC,EACL,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,GACnB,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC,GAC1C,IAAI,EACR,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,UAGzB;AAGD,eAAO,MAAM,UAAU;;;CAGb,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Background for using `json-custom-numbers`:
|
|
3
|
+
*
|
|
4
|
+
* https://neon.tech/blog/parsing-json-from-postgres-in-js
|
|
5
|
+
*/
|
|
6
|
+
import { parse as customParse, stringify as customStringify, } from 'json-custom-numbers';
|
|
7
|
+
import * as v from '../../../shared/src/valita.js';
|
|
8
|
+
function numberParser(_, v) {
|
|
9
|
+
const n = +v;
|
|
10
|
+
if (n >= Number.MIN_SAFE_INTEGER && n <= Number.MAX_SAFE_INTEGER)
|
|
11
|
+
return n;
|
|
12
|
+
if (v.indexOf('.') !== -1 || v.indexOf('e') !== -1 || v.indexOf('E') !== -1)
|
|
13
|
+
return n;
|
|
14
|
+
return BigInt(v);
|
|
15
|
+
}
|
|
16
|
+
export const jsonValueSchema = v.lazy(() => {
|
|
17
|
+
const jsonObjectSchema = v.readonly(v.record(jsonValueSchema));
|
|
18
|
+
return v.union(v.null(), v.string(), v.number(), v.bigint(), v.boolean(), v.readonly(v.array(jsonValueSchema)), jsonObjectSchema);
|
|
19
|
+
});
|
|
20
|
+
export const jsonObjectSchema = v.readonly(v.record(jsonValueSchema));
|
|
21
|
+
/**
|
|
22
|
+
* Parses JSON strings that may contain arbitrarily large integers. Integers
|
|
23
|
+
* larger than {@link Number.MAX_SAFE_INTEGER} are deserialized as a `bigint`.
|
|
24
|
+
*/
|
|
25
|
+
export function parse(str, reviver) {
|
|
26
|
+
return customParse(str, reviver, numberParser);
|
|
27
|
+
}
|
|
28
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
29
|
+
function customSerializer(_, v, type) {
|
|
30
|
+
if (type === 'bigint')
|
|
31
|
+
return v.toString();
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Stringifies objects to JSON, supporting objects containing bigint values.
|
|
35
|
+
* Note that the resulting JSON string may not be deserializable by
|
|
36
|
+
* all environments, but it is supported by Postgres. The string should be
|
|
37
|
+
* deserialized with the corresponding {@link parse} method that will represent
|
|
38
|
+
* large numbers as bigints. From there it is up to the application to suitably
|
|
39
|
+
* handle bigints passed to downstream logic.
|
|
40
|
+
*/
|
|
41
|
+
export function stringify(obj, replacer, indent) {
|
|
42
|
+
return customStringify(obj, replacer, indent, customSerializer);
|
|
43
|
+
}
|
|
44
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
45
|
+
export const BigIntJSON = {
|
|
46
|
+
parse,
|
|
47
|
+
stringify,
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=bigint-json.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bigint-json.js","sourceRoot":"","sources":["../../../../../zero-cache/src/types/bigint-json.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,EACL,KAAK,IAAI,WAAW,EACpB,SAAS,IAAI,eAAe,GAC7B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,KAAK,CAAC,MAAM,sBAAsB,CAAC;AAE1C,SAAS,YAAY,CAAC,CAAU,EAAE,CAAS;IACzC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IACb,IAAI,CAAC,IAAI,MAAM,CAAC,gBAAgB,IAAI,CAAC,IAAI,MAAM,CAAC,gBAAgB;QAAE,OAAO,CAAC,CAAC;IAC3E,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACzE,OAAO,CAAC,CAAC;IACX,OAAO,MAAM,CAAC,CAAC,CAAC,CAAC;AACnB,CAAC;AAeD,MAAM,CAAC,MAAM,eAAe,GAAsB,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;IAC5D,MAAM,gBAAgB,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC;IAE/D,OAAO,CAAC,CAAC,KAAK,CACZ,CAAC,CAAC,IAAI,EAAE,EACR,CAAC,CAAC,MAAM,EAAE,EACV,CAAC,CAAC,MAAM,EAAE,EACV,CAAC,CAAC,MAAM,EAAE,EACV,CAAC,CAAC,OAAO,EAAE,EACX,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,EACpC,gBAAgB,CACjB,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC;AAEtE;;;GAGG;AACH,MAAM,UAAU,KAAK,CACnB,GAAW,EACX,OAA4C;IAE5C,OAAO,WAAW,CAAC,GAAG,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;AACjD,CAAC;AAED,8DAA8D;AAC9D,SAAS,gBAAgB,CAAC,CAAS,EAAE,CAAM,EAAE,IAAY;IACvD,IAAI,IAAI,KAAK,QAAQ;QAAE,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC;AAC7C,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,SAAS,CACvB,GAAY,EACZ,QAGQ,EACR,MAAwB;IAExB,OAAO,eAAe,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC;AAClE,CAAC;AAED,gEAAgE;AAChE,MAAM,CAAC,MAAM,UAAU,GAAG;IACxB,KAAK;IACL,SAAS;CACD,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ErrorMessage } from '../../../zero-protocol/src/mod.js';
|
|
2
|
+
export declare class ErrorForClient extends Error {
|
|
3
|
+
readonly errorMessage: ErrorMessage;
|
|
4
|
+
constructor(errorMessage: ErrorMessage, options?: ErrorOptions);
|
|
5
|
+
}
|
|
6
|
+
export declare function findErrorForClient(error: unknown): ErrorForClient | undefined;
|
|
7
|
+
//# sourceMappingURL=error-for-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-for-client.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/types/error-for-client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,eAAe,CAAC;AAEhD,qBAAa,cAAe,SAAQ,KAAK;IACvC,QAAQ,CAAC,YAAY,eAAC;gBACV,YAAY,EAAE,YAAY,EAAE,OAAO,CAAC,EAAE,YAAY;CAI/D;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,cAAc,GAAG,SAAS,CAQ7E"}
|