@rocicorp/zero 0.2.2024101101 → 0.3.2024102500
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/out/react.js +91 -39
- package/out/react.js.map +2 -2
- package/out/replicache/src/async-iterable-to-array.js +8 -0
- package/out/replicache/src/async-iterable-to-array.js.map +1 -0
- package/out/replicache/src/bg-interval.js +38 -0
- package/out/replicache/src/bg-interval.js.map +1 -0
- package/out/replicache/src/binary-search.js +31 -0
- package/out/replicache/src/binary-search.js.map +1 -0
- package/out/replicache/src/broadcast-channel.js +29 -0
- package/out/replicache/src/broadcast-channel.js.map +1 -0
- package/out/replicache/src/btree/diff.js +6 -0
- package/out/replicache/src/btree/diff.js.map +1 -0
- package/out/replicache/src/btree/node.js +392 -0
- package/out/replicache/src/btree/node.js.map +1 -0
- package/out/replicache/src/btree/read.js +227 -0
- package/out/replicache/src/btree/read.js.map +1 -0
- package/out/replicache/src/btree/splice.js +79 -0
- package/out/replicache/src/btree/splice.js.map +1 -0
- package/out/replicache/src/btree/write.js +154 -0
- package/out/replicache/src/btree/write.js.map +1 -0
- package/out/replicache/src/call-default-fetch.js +37 -0
- package/out/replicache/src/call-default-fetch.js.map +1 -0
- package/out/replicache/src/config.js +13 -0
- package/out/replicache/src/config.js.map +1 -0
- package/out/replicache/src/connection-loop-delegates.js +30 -0
- package/out/replicache/src/connection-loop-delegates.js.map +1 -0
- package/out/replicache/src/connection-loop.js +268 -0
- package/out/replicache/src/connection-loop.js.map +1 -0
- package/out/replicache/src/cookies.js +41 -0
- package/out/replicache/src/cookies.js.map +1 -0
- package/out/replicache/src/dag/chunk.js +60 -0
- package/out/replicache/src/dag/chunk.js.map +1 -0
- package/out/replicache/src/dag/gc.js +126 -0
- package/out/replicache/src/dag/gc.js.map +1 -0
- package/out/replicache/src/dag/key-type-enum.js +6 -0
- package/out/replicache/src/dag/key-type-enum.js.map +1 -0
- package/out/replicache/src/dag/key.js +54 -0
- package/out/replicache/src/dag/key.js.map +1 -0
- package/out/replicache/src/dag/lazy-store.js +532 -0
- package/out/replicache/src/dag/lazy-store.js.map +1 -0
- package/out/replicache/src/dag/store-impl.js +175 -0
- package/out/replicache/src/dag/store-impl.js.map +1 -0
- package/out/replicache/src/dag/store.js +22 -0
- package/out/replicache/src/dag/store.js.map +1 -0
- package/out/replicache/src/dag/visitor.js +22 -0
- package/out/replicache/src/dag/visitor.js.map +1 -0
- package/out/replicache/src/db/commit.js +443 -0
- package/out/replicache/src/db/commit.js.map +1 -0
- package/out/replicache/src/db/index-operation-enum.js +4 -0
- package/out/replicache/src/db/index-operation-enum.js.map +1 -0
- package/out/replicache/src/db/index.js +170 -0
- package/out/replicache/src/db/index.js.map +1 -0
- package/out/replicache/src/db/meta-type-enum.js +7 -0
- package/out/replicache/src/db/meta-type-enum.js.map +1 -0
- package/out/replicache/src/db/read.js +59 -0
- package/out/replicache/src/db/read.js.map +1 -0
- package/out/replicache/src/db/rebase.js +56 -0
- package/out/replicache/src/db/rebase.js.map +1 -0
- package/out/replicache/src/db/scan.js +2 -0
- package/out/replicache/src/db/scan.js.map +1 -0
- package/out/replicache/src/db/write.js +260 -0
- package/out/replicache/src/db/write.js.map +1 -0
- package/out/replicache/src/error-responses.js +30 -0
- package/out/replicache/src/error-responses.js.map +1 -0
- package/out/replicache/src/filter-async-iterable.js +15 -0
- package/out/replicache/src/filter-async-iterable.js.map +1 -0
- package/out/replicache/src/format-version-enum.js +9 -0
- package/out/replicache/src/format-version-enum.js.map +1 -0
- package/out/replicache/src/format-version.js +8 -0
- package/out/replicache/src/format-version.js.map +1 -0
- package/out/replicache/src/frozen-json.js +151 -0
- package/out/replicache/src/frozen-json.js.map +1 -0
- package/out/replicache/src/get-default-puller.js +74 -0
- package/out/replicache/src/get-default-puller.js.map +1 -0
- package/out/replicache/src/get-default-pusher.js +36 -0
- package/out/replicache/src/get-default-pusher.js.map +1 -0
- package/out/replicache/src/hash.js +73 -0
- package/out/replicache/src/hash.js.map +1 -0
- package/out/replicache/src/http-request-info.js +7 -0
- package/out/replicache/src/http-request-info.js.map +1 -0
- package/out/replicache/src/impl.js +2 -0
- package/out/replicache/src/impl.js.map +1 -0
- package/out/replicache/src/index-defs.js +28 -0
- package/out/replicache/src/index-defs.js.map +1 -0
- package/out/replicache/src/invoke-kind-enum.js +4 -0
- package/out/replicache/src/invoke-kind-enum.js.map +1 -0
- package/out/replicache/src/iterable-union.js +5 -0
- package/out/replicache/src/iterable-union.js.map +1 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js +93 -0
- package/out/replicache/src/kv/idb-store-with-mem-fallback.js.map +1 -0
- package/out/replicache/src/kv/idb-store.js +179 -0
- package/out/replicache/src/kv/idb-store.js.map +1 -0
- package/out/replicache/src/kv/mem-store.js +61 -0
- package/out/replicache/src/kv/mem-store.js.map +1 -0
- package/out/replicache/src/kv/read-impl.js +23 -0
- package/out/replicache/src/kv/read-impl.js.map +1 -0
- package/out/replicache/src/kv/store.js +2 -0
- package/out/replicache/src/kv/store.js.map +1 -0
- package/out/replicache/src/kv/write-impl-base.js +48 -0
- package/out/replicache/src/kv/write-impl-base.js.map +1 -0
- package/out/replicache/src/kv/write-impl.js +25 -0
- package/out/replicache/src/kv/write-impl.js.map +1 -0
- package/out/replicache/src/lazy.js +10 -0
- package/out/replicache/src/lazy.js.map +1 -0
- package/out/replicache/src/log-options.js +13 -0
- package/out/replicache/src/log-options.js.map +1 -0
- package/out/replicache/src/merge-async-iterables.js +61 -0
- package/out/replicache/src/merge-async-iterables.js.map +1 -0
- package/out/replicache/src/mod.js +14 -0
- package/out/replicache/src/mod.js.map +1 -0
- package/out/replicache/src/mutation-recovery.js +439 -0
- package/out/replicache/src/mutation-recovery.js.map +1 -0
- package/out/replicache/src/new-client-channel.js +77 -0
- package/out/replicache/src/new-client-channel.js.map +1 -0
- package/out/replicache/src/on-persist-channel.js +33 -0
- package/out/replicache/src/on-persist-channel.js.map +1 -0
- package/out/replicache/src/patch-operation.js +37 -0
- package/out/replicache/src/patch-operation.js.map +1 -0
- package/out/replicache/src/pending-mutations.js +18 -0
- package/out/replicache/src/pending-mutations.js.map +1 -0
- package/out/replicache/src/persist/client-gc.js +38 -0
- package/out/replicache/src/persist/client-gc.js.map +1 -0
- package/out/replicache/src/persist/client-group-gc.js +38 -0
- package/out/replicache/src/persist/client-group-gc.js.map +1 -0
- package/out/replicache/src/persist/client-groups.js +180 -0
- package/out/replicache/src/persist/client-groups.js.map +1 -0
- package/out/replicache/src/persist/clients.js +390 -0
- package/out/replicache/src/persist/clients.js.map +1 -0
- package/out/replicache/src/persist/collect-idb-databases.js +174 -0
- package/out/replicache/src/persist/collect-idb-databases.js.map +1 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.js +25 -0
- package/out/replicache/src/persist/gather-mem-only-visitor.js.map +1 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.js +35 -0
- package/out/replicache/src/persist/gather-not-cached-visitor.js.map +1 -0
- package/out/replicache/src/persist/heartbeat.js +37 -0
- package/out/replicache/src/persist/heartbeat.js.map +1 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.js +18 -0
- package/out/replicache/src/persist/idb-databases-store-db-name.js.map +1 -0
- package/out/replicache/src/persist/idb-databases-store.js +90 -0
- package/out/replicache/src/persist/idb-databases-store.js.map +1 -0
- package/out/replicache/src/persist/make-client-id.js +13 -0
- package/out/replicache/src/persist/make-client-id.js.map +1 -0
- package/out/replicache/src/persist/persist.js +132 -0
- package/out/replicache/src/persist/persist.js.map +1 -0
- package/out/replicache/src/persist/refresh.js +147 -0
- package/out/replicache/src/persist/refresh.js.map +1 -0
- package/out/replicache/src/process-scheduler.js +93 -0
- package/out/replicache/src/process-scheduler.js.map +1 -0
- package/out/replicache/src/puller.js +2 -0
- package/out/replicache/src/puller.js.map +1 -0
- package/out/replicache/src/pusher.js +32 -0
- package/out/replicache/src/pusher.js.map +1 -0
- package/out/replicache/src/replicache-impl.js +1007 -0
- package/out/replicache/src/replicache-impl.js.map +1 -0
- package/out/replicache/src/replicache-options.js +2 -0
- package/out/replicache/src/replicache-options.js.map +1 -0
- package/out/replicache/src/replicache.js +387 -0
- package/out/replicache/src/replicache.js.map +1 -0
- package/out/replicache/src/request-idle.js +15 -0
- package/out/replicache/src/request-idle.js.map +1 -0
- package/out/replicache/src/scan-iterator.js +202 -0
- package/out/replicache/src/scan-iterator.js.map +1 -0
- package/out/replicache/src/scan-options.js +45 -0
- package/out/replicache/src/scan-options.js.map +1 -0
- package/out/replicache/src/set-interval-with-signal.js +7 -0
- package/out/replicache/src/set-interval-with-signal.js.map +1 -0
- package/out/replicache/src/size-of-value.js +77 -0
- package/out/replicache/src/size-of-value.js.map +1 -0
- package/out/replicache/src/subscriptions.js +357 -0
- package/out/replicache/src/subscriptions.js.map +1 -0
- package/out/replicache/src/sync/diff.js +75 -0
- package/out/replicache/src/sync/diff.js.map +1 -0
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js +5 -0
- package/out/replicache/src/sync/handle-pull-response-result-type-enum.js.map +1 -0
- package/out/replicache/src/sync/ids.js +4 -0
- package/out/replicache/src/sync/ids.js.map +1 -0
- package/out/replicache/src/sync/patch.js +41 -0
- package/out/replicache/src/sync/patch.js.map +1 -0
- package/out/replicache/src/sync/pull-error.js +16 -0
- package/out/replicache/src/sync/pull-error.js.map +1 -0
- package/out/replicache/src/sync/pull.js +375 -0
- package/out/replicache/src/sync/pull.js.map +1 -0
- package/out/replicache/src/sync/push.js +141 -0
- package/out/replicache/src/sync/push.js.map +1 -0
- package/out/replicache/src/sync/request-id.js +31 -0
- package/out/replicache/src/sync/request-id.js.map +1 -0
- package/out/replicache/src/sync/sync-head-name.js +2 -0
- package/out/replicache/src/sync/sync-head-name.js.map +1 -0
- package/out/replicache/src/test-license-key.js +3 -0
- package/out/replicache/src/test-license-key.js.map +1 -0
- package/out/replicache/src/to-error.js +7 -0
- package/out/replicache/src/to-error.js.map +1 -0
- package/out/replicache/src/transaction-closed-error.js +17 -0
- package/out/replicache/src/transaction-closed-error.js.map +1 -0
- package/out/replicache/src/transactions.js +144 -0
- package/out/replicache/src/transactions.js.map +1 -0
- package/out/replicache/src/types.js +2 -0
- package/out/replicache/src/types.js.map +1 -0
- package/out/replicache/src/version.js +5 -0
- package/out/replicache/src/version.js.map +1 -0
- package/out/replicache/src/with-transactions.js +28 -0
- package/out/replicache/src/with-transactions.js.map +1 -0
- package/out/shared/src/browser-env.js +14 -0
- package/out/shared/src/browser-env.js.map +1 -0
- package/out/shared/src/document-visible.js +76 -0
- package/out/shared/src/document-visible.js.map +1 -0
- package/out/shared/src/immutable.js +2 -0
- package/out/shared/src/immutable.js.map +1 -0
- package/out/shared/src/iterables.d.ts +2 -2
- package/out/shared/src/iterables.d.ts.map +1 -1
- package/out/shared/src/iterables.js +40 -0
- package/out/shared/src/iterables.js.map +1 -0
- package/out/shared/src/navigator.js +3 -0
- package/out/shared/src/navigator.js.map +1 -0
- package/out/shared/src/random-uint64.js +8 -0
- package/out/shared/src/random-uint64.js.map +1 -0
- package/out/shared/src/random-values.d.ts +1 -0
- package/out/shared/src/random-values.d.ts.map +1 -1
- package/out/shared/src/random-values.js +22 -0
- package/out/shared/src/random-values.js.map +1 -0
- package/out/shared/src/set-utils.d.ts +1 -1
- package/out/shared/src/set-utils.d.ts.map +1 -1
- package/out/shared/src/set-utils.js +6 -4
- package/out/shared/src/set-utils.js.map +1 -1
- package/out/shared/src/sorted-entries.d.ts +2 -0
- package/out/shared/src/sorted-entries.d.ts.map +1 -0
- package/out/shared/src/sorted-entries.js +6 -0
- package/out/shared/src/sorted-entries.js.map +1 -0
- package/out/shared/src/types.js +2 -0
- package/out/shared/src/types.js.map +1 -0
- package/out/shared/src/valita.d.ts +1 -1
- package/out/shared/src/valita.d.ts.map +1 -1
- package/out/shared/src/valita.js.map +1 -1
- package/out/shared/src/writable.d.ts +4 -0
- package/out/shared/src/writable.d.ts.map +1 -0
- package/out/shared/src/writable.js +2 -0
- package/out/shared/src/writable.js.map +1 -0
- package/out/zero/src/config.d.ts +2 -0
- package/out/zero/src/config.d.ts.map +1 -0
- package/out/zero/src/config.js +2 -0
- package/out/zero/src/config.js.map +1 -0
- package/out/zero-cache/src/config/config-query.d.ts +18 -0
- package/out/zero-cache/src/config/config-query.d.ts.map +1 -0
- package/out/zero-cache/src/config/config-query.js +19 -0
- package/out/zero-cache/src/config/config-query.js.map +1 -0
- package/out/zero-cache/src/config/define-config.d.ts +43 -0
- package/out/zero-cache/src/config/define-config.d.ts.map +1 -0
- package/out/zero-cache/src/config/define-config.js +120 -0
- package/out/zero-cache/src/config/define-config.js.map +1 -0
- package/out/zero-cache/src/config/refs.d.ts +3 -0
- package/out/zero-cache/src/config/refs.d.ts.map +1 -0
- package/out/zero-cache/src/config/refs.js +14 -0
- package/out/zero-cache/src/config/refs.js.map +1 -0
- package/out/zero-cache/src/config/zero-config.d.ts +126 -686
- package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
- package/out/zero-cache/src/config/zero-config.js +43 -161
- package/out/zero-cache/src/config/zero-config.js.map +1 -1
- package/out/zero-cache/src/db/create.d.ts +8 -0
- package/out/zero-cache/src/db/create.d.ts.map +1 -0
- package/out/zero-cache/src/db/create.js +39 -0
- package/out/zero-cache/src/db/create.js.map +1 -0
- package/out/zero-cache/src/db/lite-tables.d.ts +3 -3
- package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -1
- package/out/zero-cache/src/db/lite-tables.js +29 -20
- package/out/zero-cache/src/db/lite-tables.js.map +1 -1
- package/out/zero-cache/src/db/migration-lite.d.ts +60 -20
- package/out/zero-cache/src/db/migration-lite.d.ts.map +1 -1
- package/out/zero-cache/src/db/migration-lite.js +89 -69
- package/out/zero-cache/src/db/migration-lite.js.map +1 -1
- package/out/zero-cache/src/db/migration.d.ts +61 -20
- package/out/zero-cache/src/db/migration.d.ts.map +1 -1
- package/out/zero-cache/src/db/migration.js +92 -75
- package/out/zero-cache/src/db/migration.js.map +1 -1
- package/out/zero-cache/src/db/pg-to-lite.d.ts +11 -0
- package/out/zero-cache/src/db/pg-to-lite.d.ts.map +1 -0
- package/out/zero-cache/src/{services/change-streamer/pg/schema/lite.js → db/pg-to-lite.js} +27 -15
- package/out/zero-cache/src/db/pg-to-lite.js.map +1 -0
- package/out/zero-cache/src/db/specs.d.ts +73 -0
- package/out/zero-cache/src/db/specs.d.ts.map +1 -0
- package/out/zero-cache/src/db/specs.js +30 -0
- package/out/zero-cache/src/db/specs.js.map +1 -0
- package/out/zero-cache/src/db/statements.d.ts +1 -1
- package/out/zero-cache/src/db/statements.d.ts.map +1 -1
- package/out/zero-cache/src/server/life-cycle.d.ts.map +1 -1
- package/out/zero-cache/src/server/life-cycle.js +9 -5
- package/out/zero-cache/src/server/life-cycle.js.map +1 -1
- package/out/zero-cache/src/server/main.js +3 -3
- package/out/zero-cache/src/server/main.js.map +1 -1
- package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
- package/out/zero-cache/src/server/syncer.js +2 -1
- package/out/zero-cache/src/server/syncer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +1 -4
- package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +455 -13
- package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/change-streamer.js +16 -0
- package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js +313 -88
- package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +13 -54
- package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +239 -59
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js +291 -183
- package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.d.ts +5 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.js +18 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/init.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +4 -4
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js +14 -19
- package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.d.ts +17 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.d.ts.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.js +150 -0
- package/out/zero-cache/src/services/change-streamer/pg/schema/shard.js.map +1 -0
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +11 -5
- package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +325 -26
- package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.js +84 -1
- package/out/zero-cache/src/services/change-streamer/schema/change.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts +2 -2
- package/out/zero-cache/src/services/change-streamer/schema/init.d.ts.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/init.js +13 -5
- package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -1
- package/out/zero-cache/src/services/change-streamer/schema/tables.js +6 -6
- package/out/zero-cache/src/services/change-streamer/storer.js +4 -4
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +1 -0
- package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +1 -1
- package/out/zero-cache/src/services/dispatcher/connect-params.js +5 -2
- package/out/zero-cache/src/services/dispatcher/connect-params.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/mutagen.js +21 -22
- package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +1 -1
- package/out/zero-cache/src/services/mutagen/write-authorizer.js +18 -9
- package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +1 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/incremental-sync.js +131 -16
- package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +20 -3
- package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/change-log.js +46 -14
- package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +1 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -1
- package/out/zero-cache/src/services/replicator/schema/replication-state.js +9 -9
- package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +4 -3
- package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/client-handler.js +27 -21
- package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +6 -4
- package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr-store.js +63 -18
- package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts +11 -8
- package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/cvr.js +22 -13
- package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.js +1 -1
- package/out/zero-cache/src/services/view-syncer/database-storage.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts +31 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.js +53 -0
- package/out/zero-cache/src/services/view-syncer/drain-coordinator.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +13 -5
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +27 -0
- package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts +2 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js +5 -4
- package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/init.d.ts +4 -0
- package/out/zero-cache/src/services/view-syncer/schema/init.d.ts.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/init.js +16 -0
- package/out/zero-cache/src/services/view-syncer/schema/init.js.map +1 -0
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +8 -216
- package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/schema/types.js +2 -4
- package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +12 -4
- package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/snapshotter.js +59 -49
- package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +3 -4
- package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
- package/out/zero-cache/src/services/view-syncer/view-syncer.js +105 -44
- package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
- package/out/zero-cache/src/types/lite.d.ts.map +1 -1
- package/out/zero-cache/src/types/lite.js +8 -9
- package/out/zero-cache/src/types/lite.js.map +1 -1
- package/out/zero-cache/src/types/pg.d.ts +10 -4
- package/out/zero-cache/src/types/pg.d.ts.map +1 -1
- package/out/zero-cache/src/types/pg.js +37 -15
- package/out/zero-cache/src/types/pg.js.map +1 -1
- package/out/zero-cache/src/workers/connection.d.ts +4 -2
- package/out/zero-cache/src/workers/connection.d.ts.map +1 -1
- package/out/zero-cache/src/workers/connection.js +21 -2
- package/out/zero-cache/src/workers/connection.js.map +1 -1
- package/out/zero-cache/src/workers/syncer.d.ts +2 -1
- package/out/zero-cache/src/workers/syncer.d.ts.map +1 -1
- package/out/zero-cache/src/workers/syncer.js +20 -9
- package/out/zero-cache/src/workers/syncer.js.map +1 -1
- package/out/zero-client/src/client/context.d.ts +1 -1
- package/out/zero-client/src/client/context.d.ts.map +1 -1
- package/out/zero-client/src/client/context.js +99 -0
- package/out/zero-client/src/client/context.js.map +1 -0
- package/out/zero-client/src/client/crud.d.ts +8 -10
- package/out/zero-client/src/client/crud.d.ts.map +1 -1
- package/out/zero-client/src/client/crud.js +181 -0
- package/out/zero-client/src/client/crud.js.map +1 -0
- package/out/zero-client/src/client/enable-analytics.js +21 -0
- package/out/zero-client/src/client/enable-analytics.js.map +1 -0
- package/out/zero-client/src/client/http-string.js +14 -0
- package/out/zero-client/src/client/http-string.js.map +1 -0
- package/out/zero-client/src/client/keys.d.ts +3 -2
- package/out/zero-client/src/client/keys.d.ts.map +1 -1
- package/out/zero-client/src/client/keys.js +32 -0
- package/out/zero-client/src/client/keys.js.map +1 -0
- package/out/zero-client/src/client/log-options.js +57 -0
- package/out/zero-client/src/client/log-options.js.map +1 -0
- package/out/zero-client/src/client/metrics.js +268 -0
- package/out/zero-client/src/client/metrics.js.map +1 -0
- package/out/zero-client/src/client/normalized-schema.d.ts +17 -0
- package/out/zero-client/src/client/normalized-schema.d.ts.map +1 -0
- package/out/zero-client/src/client/normalized-schema.js +31 -0
- package/out/zero-client/src/client/normalized-schema.js.map +1 -0
- package/out/zero-client/src/client/options.js +2 -0
- package/out/zero-client/src/client/options.js.map +1 -0
- package/out/zero-client/src/client/query-manager.d.ts +18 -3
- package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
- package/out/zero-client/src/client/query-manager.js +149 -0
- package/out/zero-client/src/client/query-manager.js.map +1 -0
- package/out/zero-client/src/client/reload-error-handler.js +23 -0
- package/out/zero-client/src/client/reload-error-handler.js.map +1 -0
- package/out/zero-client/src/client/replicache-types.js +2 -0
- package/out/zero-client/src/client/replicache-types.js.map +1 -0
- package/out/zero-client/src/client/server-error.js +22 -0
- package/out/zero-client/src/client/server-error.js.map +1 -0
- package/out/zero-client/src/client/server-option.js +37 -0
- package/out/zero-client/src/client/server-option.js.map +1 -0
- package/out/zero-client/src/client/version.js +5 -0
- package/out/zero-client/src/client/version.js.map +1 -0
- package/out/zero-client/src/client/zero-poke-handler.d.ts +3 -3
- package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -1
- package/out/zero-client/src/client/zero-poke-handler.js +240 -0
- package/out/zero-client/src/client/zero-poke-handler.js.map +1 -0
- package/out/zero-client/src/client/zero.d.ts +3 -2
- package/out/zero-client/src/client/zero.d.ts.map +1 -1
- package/out/zero-client/src/client/zero.js +1212 -0
- package/out/zero-client/src/client/zero.js.map +1 -0
- package/out/zero-client/src/mod.d.ts +1 -0
- package/out/zero-client/src/mod.d.ts.map +1 -1
- package/out/zero-client/src/mod.js +5 -0
- package/out/zero-client/src/mod.js.map +1 -0
- package/out/zero-client/src/util/nanoid.js +34 -0
- package/out/zero-client/src/util/nanoid.js.map +1 -0
- package/out/zero-client/src/util/socket.js +4 -0
- package/out/zero-client/src/util/socket.js.map +1 -0
- package/out/zero-protocol/src/ast.d.ts +87 -1
- package/out/zero-protocol/src/ast.d.ts.map +1 -1
- package/out/zero-protocol/src/ast.js +53 -0
- package/out/zero-protocol/src/ast.js.map +1 -1
- package/out/zero-protocol/src/change-desired-queries.d.ts +6 -6
- package/out/zero-protocol/src/change-desired-queries.d.ts.map +1 -1
- package/out/zero-protocol/src/clients-patch.d.ts +1 -1
- package/out/zero-protocol/src/connect.d.ts +15 -8
- package/out/zero-protocol/src/connect.d.ts.map +1 -1
- package/out/zero-protocol/src/connect.js +21 -0
- package/out/zero-protocol/src/connect.js.map +1 -1
- package/out/zero-protocol/src/data.d.ts +36 -0
- package/out/zero-protocol/src/data.d.ts.map +1 -0
- package/out/zero-protocol/src/data.js +4 -0
- package/out/zero-protocol/src/data.js.map +1 -0
- package/out/zero-protocol/src/delete-clients.d.ts +4 -4
- package/out/zero-protocol/src/delete-clients.d.ts.map +1 -1
- package/out/zero-protocol/src/down.d.ts +18 -16
- package/out/zero-protocol/src/down.d.ts.map +1 -1
- package/out/zero-protocol/src/down.js +2 -1
- package/out/zero-protocol/src/down.js.map +1 -1
- package/out/zero-protocol/src/mod.d.ts +1 -2
- package/out/zero-protocol/src/mod.d.ts.map +1 -1
- package/out/zero-protocol/src/mod.js +2 -2
- package/out/zero-protocol/src/mod.js.map +1 -1
- package/out/zero-protocol/src/ping.d.ts +1 -1
- package/out/zero-protocol/src/ping.d.ts.map +1 -1
- package/out/zero-protocol/src/poke.d.ts +26 -26
- package/out/zero-protocol/src/poke.d.ts.map +1 -1
- package/out/zero-protocol/src/poke.js +8 -5
- package/out/zero-protocol/src/poke.js.map +1 -1
- package/out/zero-protocol/src/pong.d.ts +1 -1
- package/out/zero-protocol/src/pong.d.ts.map +1 -1
- package/out/zero-protocol/src/primary-key.d.ts +2 -3
- package/out/zero-protocol/src/primary-key.d.ts.map +1 -1
- package/out/zero-protocol/src/primary-key.js +1 -3
- package/out/zero-protocol/src/primary-key.js.map +1 -1
- package/out/zero-protocol/src/pull.d.ts +4 -4
- package/out/zero-protocol/src/pull.d.ts.map +1 -1
- package/out/zero-protocol/src/push.d.ts +105 -98
- package/out/zero-protocol/src/push.d.ts.map +1 -1
- package/out/zero-protocol/src/push.js +17 -13
- package/out/zero-protocol/src/push.js.map +1 -1
- package/out/zero-protocol/src/queries-patch.d.ts +4 -4
- package/out/zero-protocol/src/row-patch.d.ts +38 -0
- package/out/zero-protocol/src/row-patch.d.ts.map +1 -0
- package/out/zero-protocol/src/{entities-patch.js → row-patch.js} +10 -11
- package/out/zero-protocol/src/row-patch.js.map +1 -0
- package/out/zero-protocol/src/up.d.ts +28 -27
- package/out/zero-protocol/src/up.d.ts.map +1 -1
- package/out/zero-protocol/src/warm.d.ts +10 -0
- package/out/zero-protocol/src/warm.d.ts.map +1 -0
- package/out/zero-protocol/src/warm.js +6 -0
- package/out/zero-protocol/src/warm.js.map +1 -0
- package/out/zero-react/src/use-query.d.ts.map +1 -1
- package/out/zero.js +522 -217
- package/out/zero.js.map +4 -4
- package/out/zql/src/zql/builder/builder.d.ts +3 -4
- package/out/zql/src/zql/builder/builder.d.ts.map +1 -1
- package/out/zql/src/zql/builder/builder.js +1 -2
- package/out/zql/src/zql/builder/builder.js.map +1 -1
- package/out/zql/src/zql/builder/filter.d.ts +2 -2
- package/out/zql/src/zql/builder/filter.d.ts.map +1 -1
- package/out/zql/src/zql/builder/filter.js.map +1 -1
- package/out/zql/src/zql/ivm/array-view.d.ts +5 -12
- package/out/zql/src/zql/ivm/array-view.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/array-view.js +226 -0
- package/out/zql/src/zql/ivm/array-view.js.map +1 -0
- package/out/zql/src/zql/ivm/change.d.ts +2 -1
- package/out/zql/src/zql/ivm/change.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/data.d.ts +2 -33
- package/out/zql/src/zql/ivm/data.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/data.js.map +1 -1
- package/out/zql/src/zql/ivm/filter.d.ts +2 -1
- package/out/zql/src/zql/ivm/filter.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/filter.js.map +1 -1
- package/out/zql/src/zql/ivm/join.d.ts +1 -1
- package/out/zql/src/zql/ivm/join.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/join.js +68 -24
- package/out/zql/src/zql/ivm/join.js.map +1 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts +1 -1
- package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/memory-source.d.ts +8 -6
- package/out/zql/src/zql/ivm/memory-source.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/memory-source.js +2 -0
- package/out/zql/src/zql/ivm/memory-source.js.map +1 -1
- package/out/zql/src/zql/ivm/memory-storage.js +33 -0
- package/out/zql/src/zql/ivm/memory-storage.js.map +1 -0
- package/out/zql/src/zql/ivm/operator.d.ts +2 -1
- package/out/zql/src/zql/ivm/operator.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/schema.d.ts +3 -3
- package/out/zql/src/zql/ivm/schema.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/schema.js.map +1 -1
- package/out/zql/src/zql/ivm/skip.d.ts +2 -1
- package/out/zql/src/zql/ivm/skip.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/skip.js.map +1 -1
- package/out/zql/src/zql/ivm/source.d.ts +2 -2
- package/out/zql/src/zql/ivm/source.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/take.d.ts.map +1 -1
- package/out/zql/src/zql/ivm/take.js.map +1 -1
- package/out/zql/src/zql/query/like.d.ts +2 -0
- package/out/zql/src/zql/query/like.d.ts.map +1 -0
- package/out/zql/src/zql/query/like.js +18 -0
- package/out/zql/src/zql/query/like.js.map +1 -0
- package/out/zql/src/zql/query/normalize-table-schema.d.ts +48 -0
- package/out/zql/src/zql/query/normalize-table-schema.d.ts.map +1 -0
- package/out/zql/src/zql/query/normalize-table-schema.js +116 -0
- package/out/zql/src/zql/query/normalize-table-schema.js.map +1 -0
- package/out/zql/src/zql/query/query-impl.d.ts +6 -5
- package/out/zql/src/zql/query/query-impl.d.ts.map +1 -1
- package/out/zql/src/zql/query/query-impl.js +263 -0
- package/out/zql/src/zql/query/query-impl.js.map +1 -0
- package/out/zql/src/zql/query/query.d.ts +1 -1
- package/out/zql/src/zql/query/query.d.ts.map +1 -1
- package/out/zql/src/zql/query/query.js +3 -0
- package/out/zql/src/zql/query/query.js.map +1 -0
- package/out/zql/src/zql/query/schema.d.ts +13 -4
- package/out/zql/src/zql/query/schema.d.ts.map +1 -1
- package/out/zql/src/zql/query/schema.js +7 -0
- package/out/zql/src/zql/query/schema.js.map +1 -0
- package/out/zql/src/zql/query/typed-view.d.ts +5 -2
- package/out/zql/src/zql/query/typed-view.d.ts.map +1 -1
- package/out/zql/src/zql/query/typed-view.js +2 -0
- package/out/zql/src/zql/query/typed-view.js.map +1 -0
- package/out/zqlite/src/db.d.ts +1 -1
- package/out/zqlite/src/db.d.ts.map +1 -1
- package/out/zqlite/src/db.js +1 -1
- package/out/zqlite/src/db.js.map +1 -1
- package/out/zqlite/src/table-source.d.ts +2 -2
- package/out/zqlite/src/table-source.d.ts.map +1 -1
- package/out/zqlite/src/table-source.js.map +1 -1
- package/package.json +10 -8
- package/deps/sqlite3/sqlite3.c +0 -260574
- package/deps/sqlite3/sqlite3.h +0 -13572
- package/deps/sqlite3/sqlite3ext.h +0 -719
- 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/lite.d.ts +0 -6
- 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.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/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/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-client/src/client/make-id-from-primary-key.d.ts +0 -5
- package/out/zero-client/src/client/make-id-from-primary-key.d.ts.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.map +0 -1
- 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/tool/install-sqlite3.js +0 -37
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clients.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/clients.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import { assert } from '../../../shared/src/asserts.js';
|
|
2
|
+
import { initBgIntervalProcess } from '../bg-interval.js';
|
|
3
|
+
import { StoreImpl } from '../dag/store-impl.js';
|
|
4
|
+
import * as FormatVersion from '../format-version-enum.js';
|
|
5
|
+
import { assertHash, newRandomHash } from '../hash.js';
|
|
6
|
+
import { IDBStore } from '../kv/idb-store.js';
|
|
7
|
+
import { createLogContext } from '../log-options.js';
|
|
8
|
+
import { getKVStoreProvider } from '../replicache.js';
|
|
9
|
+
import { withRead } from '../with-transactions.js';
|
|
10
|
+
import { clientGroupHasPendingMutations, getClientGroups, } from './client-groups.js';
|
|
11
|
+
import { getClients } from './clients.js';
|
|
12
|
+
import { IDBDatabasesStore } from './idb-databases-store.js';
|
|
13
|
+
/**
|
|
14
|
+
* How frequently to try to collect
|
|
15
|
+
*/
|
|
16
|
+
export const COLLECT_IDB_INTERVAL = 12 * 60 * 60 * 1000; // 12 hours
|
|
17
|
+
/**
|
|
18
|
+
* If an IDB database is older than MAX_AGE, then it can be collected.
|
|
19
|
+
*/
|
|
20
|
+
export const SDD_IDB_MAX_AGE = 30 * 24 * 60 * 60 * 1000; // 1 month
|
|
21
|
+
/**
|
|
22
|
+
* If an IDB database is older than DD31_MAX_AGE **and** has no pending
|
|
23
|
+
* mutations, then it can be collected.
|
|
24
|
+
*/
|
|
25
|
+
export const DD31_IDB_MAX_AGE = 14 * 24 * 60 * 60 * 1000; // 2 weeks
|
|
26
|
+
/**
|
|
27
|
+
* We delay the initial collection to prevent doing it at startup.
|
|
28
|
+
*/
|
|
29
|
+
export const INITIAL_COLLECT_IDB_DELAY = 5 * 60 * 1000; // 5 minutes
|
|
30
|
+
export function initCollectIDBDatabases(idbDatabasesStore, kvDropStore, collectInterval, initialCollectDelay, sddMaxAge, dd31MaxAge, lc, signal) {
|
|
31
|
+
let initial = true;
|
|
32
|
+
initBgIntervalProcess('CollectIDBDatabases', async () => {
|
|
33
|
+
await collectIDBDatabases(idbDatabasesStore, Date.now(), sddMaxAge, dd31MaxAge, kvDropStore);
|
|
34
|
+
}, () => {
|
|
35
|
+
if (initial) {
|
|
36
|
+
initial = false;
|
|
37
|
+
return initialCollectDelay;
|
|
38
|
+
}
|
|
39
|
+
return collectInterval;
|
|
40
|
+
}, lc, signal);
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Collects IDB databases that are no longer needed.
|
|
44
|
+
*/
|
|
45
|
+
export async function collectIDBDatabases(idbDatabasesStore, now, sddMaxAge, dd31MaxAge, kvDropStore, newDagStore = defaultNewDagStore) {
|
|
46
|
+
const databases = await idbDatabasesStore.getDatabases();
|
|
47
|
+
const dbs = Object.values(databases);
|
|
48
|
+
const canCollectResults = await Promise.all(dbs.map(async (db) => [
|
|
49
|
+
db.name,
|
|
50
|
+
await canCollectDatabase(db, now, sddMaxAge, dd31MaxAge, newDagStore),
|
|
51
|
+
]));
|
|
52
|
+
const namesToRemove = canCollectResults
|
|
53
|
+
.filter(result => result[1])
|
|
54
|
+
.map(result => result[0]);
|
|
55
|
+
const { errors } = await dropDatabases(idbDatabasesStore, namesToRemove, kvDropStore);
|
|
56
|
+
if (errors.length) {
|
|
57
|
+
throw errors[0];
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async function dropDatabaseInternal(name, idbDatabasesStore, kvDropStore) {
|
|
61
|
+
await kvDropStore(name);
|
|
62
|
+
await idbDatabasesStore.deleteDatabases([name]);
|
|
63
|
+
}
|
|
64
|
+
async function dropDatabases(idbDatabasesStore, namesToRemove, kvDropStore) {
|
|
65
|
+
// Try to remove the databases in parallel. Don't let a single reject fail the
|
|
66
|
+
// other ones. We will check for failures afterwards.
|
|
67
|
+
const dropStoreResults = await Promise.allSettled(namesToRemove.map(async (name) => {
|
|
68
|
+
await dropDatabaseInternal(name, idbDatabasesStore, kvDropStore);
|
|
69
|
+
return name;
|
|
70
|
+
}));
|
|
71
|
+
const dropped = [];
|
|
72
|
+
const errors = [];
|
|
73
|
+
for (const result of dropStoreResults) {
|
|
74
|
+
if (result.status === 'fulfilled') {
|
|
75
|
+
dropped.push(result.value);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
errors.push(result.reason);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return { dropped, errors };
|
|
82
|
+
}
|
|
83
|
+
function defaultNewDagStore(name) {
|
|
84
|
+
const perKvStore = new IDBStore(name);
|
|
85
|
+
return new StoreImpl(perKvStore, newRandomHash, assertHash);
|
|
86
|
+
}
|
|
87
|
+
async function canCollectDatabase(db, now, sddMaxAge, dd31MaxAge, newDagStore) {
|
|
88
|
+
if (db.replicacheFormatVersion > FormatVersion.Latest) {
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
// 0 is used in testing
|
|
92
|
+
if (db.lastOpenedTimestampMS !== undefined) {
|
|
93
|
+
const isDD31 = db.replicacheFormatVersion >= FormatVersion.DD31;
|
|
94
|
+
// - For SDD we can delete the database if it is older than maxAge.
|
|
95
|
+
// - For DD31 we can delete the database if it is older than dd31MaxAge and
|
|
96
|
+
// there are no pending mutations.
|
|
97
|
+
if (now - db.lastOpenedTimestampMS < (isDD31 ? dd31MaxAge : sddMaxAge)) {
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
if (!isDD31) {
|
|
101
|
+
return true;
|
|
102
|
+
}
|
|
103
|
+
// If increase the format version we need to decide how to deal with this
|
|
104
|
+
// logic.
|
|
105
|
+
assert(db.replicacheFormatVersion === FormatVersion.DD31 ||
|
|
106
|
+
db.replicacheFormatVersion === FormatVersion.V6 ||
|
|
107
|
+
db.replicacheFormatVersion === FormatVersion.V7);
|
|
108
|
+
return !(await anyPendingMutationsInClientGroups(newDagStore(db.name)));
|
|
109
|
+
}
|
|
110
|
+
// For legacy databases we do not have a lastOpenedTimestampMS so we check the
|
|
111
|
+
// time stamps of the clients
|
|
112
|
+
const perdag = newDagStore(db.name);
|
|
113
|
+
const clientMap = await withRead(perdag, getClients);
|
|
114
|
+
await perdag.close();
|
|
115
|
+
return allClientsOlderThan(clientMap, now, sddMaxAge);
|
|
116
|
+
}
|
|
117
|
+
function allClientsOlderThan(clients, now, maxAge) {
|
|
118
|
+
for (const client of clients.values()) {
|
|
119
|
+
if (now - client.heartbeatTimestampMs < maxAge) {
|
|
120
|
+
return false;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return true;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Deletes a single Replicache database.
|
|
127
|
+
* @param dbName
|
|
128
|
+
* @param createKVStore
|
|
129
|
+
*/
|
|
130
|
+
export async function dropDatabase(dbName, opts) {
|
|
131
|
+
const logContext = createLogContext(opts?.logLevel, opts?.logSinks, {
|
|
132
|
+
dropDatabase: undefined,
|
|
133
|
+
});
|
|
134
|
+
const kvStoreProvider = getKVStoreProvider(logContext, opts?.kvStore);
|
|
135
|
+
await dropDatabaseInternal(dbName, new IDBDatabasesStore(kvStoreProvider.create), kvStoreProvider.drop);
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Deletes all IndexedDB data associated with Replicache.
|
|
139
|
+
*
|
|
140
|
+
* Returns an object with the names of the successfully dropped databases
|
|
141
|
+
* and any errors encountered while dropping.
|
|
142
|
+
*/
|
|
143
|
+
export async function dropAllDatabases(opts) {
|
|
144
|
+
const logContext = createLogContext(opts?.logLevel, opts?.logSinks, {
|
|
145
|
+
dropAllDatabases: undefined,
|
|
146
|
+
});
|
|
147
|
+
const kvStoreProvider = getKVStoreProvider(logContext, opts?.kvStore);
|
|
148
|
+
const store = new IDBDatabasesStore(kvStoreProvider.create);
|
|
149
|
+
const databases = await store.getDatabases();
|
|
150
|
+
const dbNames = Object.values(databases).map(db => db.name);
|
|
151
|
+
const result = await dropDatabases(store, dbNames, kvStoreProvider.drop);
|
|
152
|
+
return result;
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Deletes all IndexedDB data associated with Replicache.
|
|
156
|
+
*
|
|
157
|
+
* Returns an object with the names of the successfully dropped databases
|
|
158
|
+
* and any errors encountered while dropping.
|
|
159
|
+
*
|
|
160
|
+
* @deprecated Use `dropAllDatabases` instead.
|
|
161
|
+
*/
|
|
162
|
+
export function deleteAllReplicacheData(opts) {
|
|
163
|
+
return dropAllDatabases(opts);
|
|
164
|
+
}
|
|
165
|
+
async function anyPendingMutationsInClientGroups(perdag) {
|
|
166
|
+
const clientGroups = await withRead(perdag, getClientGroups);
|
|
167
|
+
for (const clientGroup of clientGroups.values()) {
|
|
168
|
+
if (clientGroupHasPendingMutations(clientGroup)) {
|
|
169
|
+
return true;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return false;
|
|
173
|
+
}
|
|
174
|
+
//# sourceMappingURL=collect-idb-databases.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collect-idb-databases.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/collect-idb-databases.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { promiseVoid } from '../../../shared/src/resolved-promises.js';
|
|
2
|
+
import { Visitor } from '../dag/visitor.js';
|
|
3
|
+
export class GatherMemoryOnlyVisitor extends Visitor {
|
|
4
|
+
#gatheredChunks = new Map();
|
|
5
|
+
#lazyRead;
|
|
6
|
+
constructor(dagRead) {
|
|
7
|
+
super(dagRead);
|
|
8
|
+
this.#lazyRead = dagRead;
|
|
9
|
+
}
|
|
10
|
+
get gatheredChunks() {
|
|
11
|
+
return this.#gatheredChunks;
|
|
12
|
+
}
|
|
13
|
+
visit(h) {
|
|
14
|
+
if (!this.#lazyRead.isMemOnlyChunkHash(h)) {
|
|
15
|
+
// Not a memory-only hash, no need to visit anything else.
|
|
16
|
+
return promiseVoid;
|
|
17
|
+
}
|
|
18
|
+
return super.visit(h);
|
|
19
|
+
}
|
|
20
|
+
visitChunk(chunk) {
|
|
21
|
+
this.#gatheredChunks.set(chunk.hash, chunk);
|
|
22
|
+
return super.visitChunk(chunk);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=gather-mem-only-visitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gather-mem-only-visitor.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/gather-mem-only-visitor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAC,MAAM,0CAA0C,CAAC;AAGrE,OAAO,EAAC,OAAO,EAAC,MAAM,mBAAmB,CAAC;AAG1C,MAAM,OAAO,uBAAwB,SAAQ,OAAO;IACzC,eAAe,GAAqB,IAAI,GAAG,EAAE,CAAC;IAC9C,SAAS,CAAW;IAE7B,YAAY,OAAiB;QAC3B,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;IAC3B,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAEQ,KAAK,CAAC,CAAO;QACpB,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,CAAC;YAC1C,0DAA0D;YAC1D,OAAO,WAAW,CAAC;QACrB,CAAC;QACD,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAEQ,UAAU,CAAC,KAAY;QAC9B,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC5C,OAAO,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;CACF"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { promiseVoid } from '../../../shared/src/resolved-promises.js';
|
|
2
|
+
import { Visitor } from '../dag/visitor.js';
|
|
3
|
+
import { getSizeOfValue } from '../size-of-value.js';
|
|
4
|
+
export class GatherNotCachedVisitor extends Visitor {
|
|
5
|
+
#gatheredChunks = new Map();
|
|
6
|
+
#gatheredChunksTotalSize = 0;
|
|
7
|
+
#lazyStore;
|
|
8
|
+
#gatherSizeLimit;
|
|
9
|
+
#getSizeOfChunk;
|
|
10
|
+
constructor(dagRead, lazyStore, gatherSizeLimit, getSizeOfChunk = getSizeOfValue) {
|
|
11
|
+
super(dagRead);
|
|
12
|
+
this.#lazyStore = lazyStore;
|
|
13
|
+
this.#gatherSizeLimit = gatherSizeLimit;
|
|
14
|
+
this.#getSizeOfChunk = getSizeOfChunk;
|
|
15
|
+
}
|
|
16
|
+
get gatheredChunks() {
|
|
17
|
+
return this.#gatheredChunks;
|
|
18
|
+
}
|
|
19
|
+
visit(h) {
|
|
20
|
+
if (this.#gatheredChunksTotalSize >= this.#gatherSizeLimit ||
|
|
21
|
+
this.#lazyStore.isCached(h)) {
|
|
22
|
+
return promiseVoid;
|
|
23
|
+
}
|
|
24
|
+
return super.visit(h);
|
|
25
|
+
}
|
|
26
|
+
visitChunk(chunk) {
|
|
27
|
+
if (this.#gatheredChunksTotalSize < this.#gatherSizeLimit) {
|
|
28
|
+
const size = this.#getSizeOfChunk(chunk);
|
|
29
|
+
this.#gatheredChunks.set(chunk.hash, { chunk, size });
|
|
30
|
+
this.#gatheredChunksTotalSize += size;
|
|
31
|
+
}
|
|
32
|
+
return super.visitChunk(chunk);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=gather-not-cached-visitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gather-not-cached-visitor.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/gather-not-cached-visitor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAC,MAAM,0CAA0C,CAAC;AAIrE,OAAO,EAAC,OAAO,EAAC,MAAM,mBAAmB,CAAC;AAE1C,OAAO,EAAC,cAAc,EAAC,MAAM,qBAAqB,CAAC;AAInD,MAAM,OAAO,sBAAuB,SAAQ,OAAO;IACxC,eAAe,GAA6B,IAAI,GAAG,EAAE,CAAC;IAC/D,wBAAwB,GAAG,CAAC,CAAC;IACpB,UAAU,CAAY;IACtB,gBAAgB,CAAS;IACzB,eAAe,CAA2B;IAEnD,YACE,OAAa,EACb,SAAoB,EACpB,eAAuB,EACvB,iBAA2C,cAAc;QAEzD,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QACxC,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;IACxC,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAEQ,KAAK,CAAC,CAAO;QACpB,IACE,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,gBAAgB;YACtD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,EAC3B,CAAC;YACD,OAAO,WAAW,CAAC;QACrB,CAAC;QACD,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAEQ,UAAU,CAAC,KAAY;QAC9B,IAAI,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1D,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC;YACpD,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC;QACxC,CAAC;QAED,OAAO,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;CACF"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { initBgIntervalProcess } from '../bg-interval.js';
|
|
2
|
+
import { withWrite } from '../with-transactions.js';
|
|
3
|
+
import { ClientStateNotFoundError, getClients, setClients, } from './clients.js';
|
|
4
|
+
export const HEARTBEAT_INTERVAL = 60 * 1000;
|
|
5
|
+
export let latestHeartbeatUpdate;
|
|
6
|
+
export function startHeartbeats(clientID, dagStore, onClientStateNotFound, heartbeatIntervalMs, lc, signal) {
|
|
7
|
+
initBgIntervalProcess('Heartbeat', async () => {
|
|
8
|
+
latestHeartbeatUpdate = writeHeartbeat(clientID, dagStore);
|
|
9
|
+
try {
|
|
10
|
+
return await latestHeartbeatUpdate;
|
|
11
|
+
}
|
|
12
|
+
catch (e) {
|
|
13
|
+
if (e instanceof ClientStateNotFoundError) {
|
|
14
|
+
onClientStateNotFound();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
throw e;
|
|
18
|
+
}
|
|
19
|
+
}, () => heartbeatIntervalMs, lc, signal);
|
|
20
|
+
}
|
|
21
|
+
export function writeHeartbeat(clientID, dagStore) {
|
|
22
|
+
return withWrite(dagStore, async (dagWrite) => {
|
|
23
|
+
const clients = await getClients(dagWrite);
|
|
24
|
+
const client = clients.get(clientID);
|
|
25
|
+
if (!client) {
|
|
26
|
+
throw new ClientStateNotFoundError(clientID);
|
|
27
|
+
}
|
|
28
|
+
const newClient = {
|
|
29
|
+
...client,
|
|
30
|
+
heartbeatTimestampMs: Date.now(),
|
|
31
|
+
};
|
|
32
|
+
const newClients = new Map(clients).set(clientID, newClient);
|
|
33
|
+
await setClients(newClients, dagWrite);
|
|
34
|
+
return newClients;
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=heartbeat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"heartbeat.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/heartbeat.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,qBAAqB,EAAC,MAAM,mBAAmB,CAAC;AAGxD,OAAO,EAAC,SAAS,EAAC,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAEL,wBAAwB,EACxB,UAAU,EACV,UAAU,GACX,MAAM,cAAc,CAAC;AAEtB,MAAM,CAAC,MAAM,kBAAkB,GAAG,EAAE,GAAG,IAAI,CAAC;AAE5C,MAAM,CAAC,IAAI,qBAAqD,CAAC;AAEjE,MAAM,UAAU,eAAe,CAC7B,QAAkB,EAClB,QAAe,EACf,qBAAiC,EACjC,mBAA2B,EAC3B,EAAc,EACd,MAAmB;IAEnB,qBAAqB,CACnB,WAAW,EACX,KAAK,IAAI,EAAE;QACT,qBAAqB,GAAG,cAAc,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC;YACH,OAAO,MAAM,qBAAqB,CAAC;QACrC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,IAAI,CAAC,YAAY,wBAAwB,EAAE,CAAC;gBAC1C,qBAAqB,EAAE,CAAC;gBACxB,OAAO;YACT,CAAC;YACD,MAAM,CAAC,CAAC;QACV,CAAC;IACH,CAAC,EACD,GAAG,EAAE,CAAC,mBAAmB,EACzB,EAAE,EACF,MAAM,CACP,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,QAAkB,EAClB,QAAe;IAEf,OAAO,SAAS,CAAC,QAAQ,EAAE,KAAK,EAAC,QAAQ,EAAC,EAAE;QAC1C,MAAM,OAAO,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,wBAAwB,CAAC,QAAQ,CAAC,CAAC;QAC/C,CAAC;QAED,MAAM,SAAS,GAAG;YAChB,GAAG,MAAM;YACT,oBAAoB,EAAE,IAAI,CAAC,GAAG,EAAE;SACjC,CAAC;QACF,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAE7D,MAAM,UAAU,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QACvC,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { randomUint64 } from '../../../shared/src/random-uint64.js';
|
|
2
|
+
import { dropIDBStoreWithMemFallback } from '../kv/idb-store-with-mem-fallback.js';
|
|
3
|
+
const IDB_DATABASES_VERSION = 0;
|
|
4
|
+
const IDB_DATABASES_DB_NAME = 'replicache-dbs-v' + IDB_DATABASES_VERSION;
|
|
5
|
+
let testNamespace = '';
|
|
6
|
+
/** Namespace db name in test to isolate tests' indexeddb state. */
|
|
7
|
+
export function setupForTest() {
|
|
8
|
+
testNamespace = randomUint64().toString(36);
|
|
9
|
+
}
|
|
10
|
+
export function teardownForTest() {
|
|
11
|
+
const idbDatabasesDBName = getIDBDatabasesDBName();
|
|
12
|
+
testNamespace = '';
|
|
13
|
+
return dropIDBStoreWithMemFallback(idbDatabasesDBName);
|
|
14
|
+
}
|
|
15
|
+
export function getIDBDatabasesDBName() {
|
|
16
|
+
return testNamespace + IDB_DATABASES_DB_NAME;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=idb-databases-store-db-name.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idb-databases-store-db-name.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/idb-databases-store-db-name.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,sCAAsC,CAAC;AAClE,OAAO,EAAC,2BAA2B,EAAC,MAAM,sCAAsC,CAAC;AAEjF,MAAM,qBAAqB,GAAG,CAAC,CAAC;AAChC,MAAM,qBAAqB,GAAG,kBAAkB,GAAG,qBAAqB,CAAC;AAEzE,IAAI,aAAa,GAAG,EAAE,CAAC;AAEvB,mEAAmE;AACnE,MAAM,UAAU,YAAY;IAC1B,aAAa,GAAG,YAAY,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,MAAM,kBAAkB,GAAG,qBAAqB,EAAE,CAAC;IACnD,aAAa,GAAG,EAAE,CAAC;IACnB,OAAO,2BAA2B,CAAC,kBAAkB,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,qBAAqB;IACnC,OAAO,aAAa,GAAG,qBAAqB,CAAC;AAC/C,CAAC"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { assert, assertNumber, assertObject, assertString, } from '../../../shared/src/asserts.js';
|
|
2
|
+
import { deepFreeze } from '../frozen-json.js';
|
|
3
|
+
import { withRead, withWrite } from '../with-transactions.js';
|
|
4
|
+
import { getIDBDatabasesDBName } from './idb-databases-store-db-name.js';
|
|
5
|
+
import { makeClientID } from './make-client-id.js';
|
|
6
|
+
const DBS_KEY = 'dbs';
|
|
7
|
+
const PROFILE_ID_KEY = 'profileId';
|
|
8
|
+
function assertIndexedDBDatabaseRecord(value) {
|
|
9
|
+
assertObject(value);
|
|
10
|
+
for (const [name, db] of Object.entries(value)) {
|
|
11
|
+
assertString(name);
|
|
12
|
+
assertIndexedDBDatabase(db);
|
|
13
|
+
assert(name === db.name);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
function assertIndexedDBDatabase(value) {
|
|
17
|
+
assertObject(value);
|
|
18
|
+
assertString(value.name);
|
|
19
|
+
assertString(value.replicacheName);
|
|
20
|
+
assertNumber(value.replicacheFormatVersion);
|
|
21
|
+
assertString(value.schemaVersion);
|
|
22
|
+
if (value.lastOpenedTimestampMS !== undefined) {
|
|
23
|
+
assertNumber(value.lastOpenedTimestampMS);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export class IDBDatabasesStore {
|
|
27
|
+
#kvStore;
|
|
28
|
+
constructor(createKVStore) {
|
|
29
|
+
this.#kvStore = createKVStore(getIDBDatabasesDBName());
|
|
30
|
+
}
|
|
31
|
+
putDatabase(db) {
|
|
32
|
+
return this.#putDatabase({ ...db, lastOpenedTimestampMS: Date.now() });
|
|
33
|
+
}
|
|
34
|
+
putDatabaseForTesting(db) {
|
|
35
|
+
return this.#putDatabase(db);
|
|
36
|
+
}
|
|
37
|
+
#putDatabase(db) {
|
|
38
|
+
return withWrite(this.#kvStore, async (write) => {
|
|
39
|
+
const oldDbRecord = await getDatabases(write);
|
|
40
|
+
const dbRecord = {
|
|
41
|
+
...oldDbRecord,
|
|
42
|
+
[db.name]: db,
|
|
43
|
+
};
|
|
44
|
+
await write.put(DBS_KEY, dbRecord);
|
|
45
|
+
return dbRecord;
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
clearDatabases() {
|
|
49
|
+
return withWrite(this.#kvStore, write => write.del(DBS_KEY));
|
|
50
|
+
}
|
|
51
|
+
deleteDatabases(names) {
|
|
52
|
+
return withWrite(this.#kvStore, async (write) => {
|
|
53
|
+
const oldDbRecord = await getDatabases(write);
|
|
54
|
+
const dbRecord = {
|
|
55
|
+
...oldDbRecord,
|
|
56
|
+
};
|
|
57
|
+
for (const name of names) {
|
|
58
|
+
delete dbRecord[name];
|
|
59
|
+
}
|
|
60
|
+
await write.put(DBS_KEY, dbRecord);
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
getDatabases() {
|
|
64
|
+
return withRead(this.#kvStore, getDatabases);
|
|
65
|
+
}
|
|
66
|
+
close() {
|
|
67
|
+
return this.#kvStore.close();
|
|
68
|
+
}
|
|
69
|
+
getProfileID() {
|
|
70
|
+
return withWrite(this.#kvStore, async (write) => {
|
|
71
|
+
let profileId = await write.get(PROFILE_ID_KEY);
|
|
72
|
+
if (profileId === undefined) {
|
|
73
|
+
// Profile id is 'p' followed by a random number.
|
|
74
|
+
profileId = `p${makeClientID()}`;
|
|
75
|
+
await write.put(PROFILE_ID_KEY, profileId);
|
|
76
|
+
}
|
|
77
|
+
assertString(profileId);
|
|
78
|
+
return profileId;
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
async function getDatabases(read) {
|
|
83
|
+
let dbRecord = await read.get(DBS_KEY);
|
|
84
|
+
if (!dbRecord) {
|
|
85
|
+
dbRecord = deepFreeze({});
|
|
86
|
+
}
|
|
87
|
+
assertIndexedDBDatabaseRecord(dbRecord);
|
|
88
|
+
return dbRecord;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=idb-databases-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idb-databases-store.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/idb-databases-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { randomUint64 } from '../../../shared/src/random-uint64.js';
|
|
2
|
+
/**
|
|
3
|
+
* Returns a random 18 character string encoded in base32 suitable as a client
|
|
4
|
+
* ID.
|
|
5
|
+
*/
|
|
6
|
+
export function makeClientID() {
|
|
7
|
+
const length = 18;
|
|
8
|
+
const high = randomUint64();
|
|
9
|
+
const low = randomUint64();
|
|
10
|
+
const combined = (high << 64n) | low;
|
|
11
|
+
return combined.toString(32).slice(-length).padStart(length, '0');
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=make-client-id.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-client-id.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/make-client-id.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,sCAAsC,CAAC;AAElE;;;GAGG;AACH,MAAM,UAAU,YAAY;IAC1B,MAAM,MAAM,GAAG,EAAE,CAAC;IAClB,MAAM,IAAI,GAAG,YAAY,EAAE,CAAC;IAC5B,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;IAC3B,MAAM,QAAQ,GAAG,CAAC,IAAI,IAAI,GAAG,CAAC,GAAG,GAAG,CAAC;IACrC,OAAO,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AACpE,CAAC"}
|
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { assert } from '../../../shared/src/asserts.js';
|
|
2
|
+
import { Commit, DEFAULT_HEAD_NAME, assertSnapshotCommitDD31, baseSnapshotFromCommit, commitFromHash, commitFromHead, compareCookiesForSnapshots, localMutationsDD31, localMutationsGreaterThan, } from '../db/commit.js';
|
|
3
|
+
import { rebaseMutationAndPutCommit } from '../db/rebase.js';
|
|
4
|
+
import { withRead, withWrite } from '../with-transactions.js';
|
|
5
|
+
import { getClientGroup, setClientGroup, } from './client-groups.js';
|
|
6
|
+
import { assertClientV6, assertHasClientState, getClientGroupIDForClient, mustGetClient, setClient, } from './clients.js';
|
|
7
|
+
import { GatherMemoryOnlyVisitor } from './gather-mem-only-visitor.js';
|
|
8
|
+
/**
|
|
9
|
+
* Persists the client's memdag state to the client's perdag client group.
|
|
10
|
+
*
|
|
11
|
+
* Persists the base snapshot from memdag to the client's perdag client group,
|
|
12
|
+
* but only if it’s newer than the client's perdag client group’s base snapshot.
|
|
13
|
+
* The base snapshot is persisted by gathering all memory-only chunks in the dag
|
|
14
|
+
* subgraph rooted at the base snapshot's commit and writing them to the perdag.
|
|
15
|
+
* Once the base snapshot is persisted, rebases onto this new base snapshot all
|
|
16
|
+
* local commits from the client's perdag client group that are not already
|
|
17
|
+
* reflected in the base snapshot.
|
|
18
|
+
*
|
|
19
|
+
* Whether or not the base snapshot is persisted, rebases onto the client's
|
|
20
|
+
* perdag client group all memdag local commits not already in the client's
|
|
21
|
+
* perdag client group's history.
|
|
22
|
+
*
|
|
23
|
+
* Also updates the `lastMutationIDs` and `lastServerAckdMutationIDs` properties
|
|
24
|
+
* of the client's client group's entry in the `ClientGroupMap`.
|
|
25
|
+
*/
|
|
26
|
+
export async function persistDD31(lc, clientID, memdag, perdag, mutators, closed, formatVersion, onGatherMemOnlyChunksForTest = () => Promise.resolve()) {
|
|
27
|
+
if (closed()) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
const [perdagLMID, perdagBaseSnapshot, mainClientGroupID] = await withRead(perdag, async (perdagRead) => {
|
|
31
|
+
await assertHasClientState(clientID, perdagRead);
|
|
32
|
+
const mainClientGroupID = await getClientGroupIDForClient(clientID, perdagRead);
|
|
33
|
+
assert(mainClientGroupID, `No main client group for clientID: ${clientID}`);
|
|
34
|
+
const [, perdagMainClientGroupHeadCommit] = await getClientGroupInfo(perdagRead, mainClientGroupID);
|
|
35
|
+
const perdagLMID = await perdagMainClientGroupHeadCommit.getMutationID(clientID, perdagRead);
|
|
36
|
+
const perdagBaseSnapshot = await baseSnapshotFromCommit(perdagMainClientGroupHeadCommit, perdagRead);
|
|
37
|
+
assertSnapshotCommitDD31(perdagBaseSnapshot);
|
|
38
|
+
return [perdagLMID, perdagBaseSnapshot, mainClientGroupID];
|
|
39
|
+
});
|
|
40
|
+
if (closed()) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const [newMemdagMutations, memdagBaseSnapshot, gatheredChunks] = await withRead(memdag, async (memdagRead) => {
|
|
44
|
+
const memdagHeadCommit = await commitFromHead(DEFAULT_HEAD_NAME, memdagRead);
|
|
45
|
+
const newMutations = await localMutationsGreaterThan(memdagHeadCommit, { [clientID]: perdagLMID || 0 }, memdagRead);
|
|
46
|
+
const memdagBaseSnapshot = await baseSnapshotFromCommit(memdagHeadCommit, memdagRead);
|
|
47
|
+
assertSnapshotCommitDD31(memdagBaseSnapshot);
|
|
48
|
+
let gatheredChunks;
|
|
49
|
+
if (compareCookiesForSnapshots(memdagBaseSnapshot, perdagBaseSnapshot) > 0) {
|
|
50
|
+
await onGatherMemOnlyChunksForTest();
|
|
51
|
+
// Might need to persist snapshot, we will have to double check
|
|
52
|
+
// after gathering the snapshot chunks from memdag
|
|
53
|
+
const memdagBaseSnapshotHash = memdagBaseSnapshot.chunk.hash;
|
|
54
|
+
// Gather all memory only chunks from base snapshot on the memdag.
|
|
55
|
+
const visitor = new GatherMemoryOnlyVisitor(memdagRead);
|
|
56
|
+
await visitor.visit(memdagBaseSnapshotHash);
|
|
57
|
+
gatheredChunks = visitor.gatheredChunks;
|
|
58
|
+
}
|
|
59
|
+
return [newMutations, memdagBaseSnapshot, gatheredChunks];
|
|
60
|
+
});
|
|
61
|
+
if (closed()) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
let memdagBaseSnapshotPersisted = false;
|
|
65
|
+
await withWrite(perdag, async (perdagWrite) => {
|
|
66
|
+
const [mainClientGroup, latestPerdagMainClientGroupHeadCommit] = await getClientGroupInfo(perdagWrite, mainClientGroupID);
|
|
67
|
+
// These initial values for newMainClientGroupHeadHash, mutationIDs,
|
|
68
|
+
// lastServerAckdMutationIDs are correct for the case where the memdag
|
|
69
|
+
// snapshot is *not* persisted. If the memdag snapshot is persisted
|
|
70
|
+
// these values are overwritten appropriately.
|
|
71
|
+
let newMainClientGroupHeadHash = latestPerdagMainClientGroupHeadCommit.chunk.hash;
|
|
72
|
+
let mutationIDs = {
|
|
73
|
+
...mainClientGroup.mutationIDs,
|
|
74
|
+
};
|
|
75
|
+
let { lastServerAckdMutationIDs } = mainClientGroup;
|
|
76
|
+
if (gatheredChunks) {
|
|
77
|
+
// check if memdag snapshot still newer than perdag snapshot
|
|
78
|
+
const client = await mustGetClient(clientID, perdagWrite);
|
|
79
|
+
assertClientV6(client);
|
|
80
|
+
const latestPerdagBaseSnapshot = await baseSnapshotFromCommit(latestPerdagMainClientGroupHeadCommit, perdagWrite);
|
|
81
|
+
assertSnapshotCommitDD31(latestPerdagBaseSnapshot);
|
|
82
|
+
// check if memdag snapshot still newer than perdag snapshot
|
|
83
|
+
if (compareCookiesForSnapshots(memdagBaseSnapshot, latestPerdagBaseSnapshot) > 0) {
|
|
84
|
+
// still newer, persist memdag snapshot by writing chunks
|
|
85
|
+
memdagBaseSnapshotPersisted = true;
|
|
86
|
+
await Promise.all(Array.from(gatheredChunks.values(), c => perdagWrite.putChunk(c)));
|
|
87
|
+
await setClient(clientID, {
|
|
88
|
+
...client,
|
|
89
|
+
persistHash: memdagBaseSnapshot.chunk.hash,
|
|
90
|
+
}, perdagWrite);
|
|
91
|
+
// Rebase local mutations from perdag main client group onto new
|
|
92
|
+
// snapshot
|
|
93
|
+
newMainClientGroupHeadHash = memdagBaseSnapshot.chunk.hash;
|
|
94
|
+
const mainClientGroupLocalMutations = await localMutationsDD31(mainClientGroup.headHash, perdagWrite);
|
|
95
|
+
lastServerAckdMutationIDs = memdagBaseSnapshot.meta.lastMutationIDs;
|
|
96
|
+
mutationIDs = { ...lastServerAckdMutationIDs };
|
|
97
|
+
newMainClientGroupHeadHash = await rebase(mainClientGroupLocalMutations, newMainClientGroupHeadHash, perdagWrite, mutators, mutationIDs, lc, formatVersion);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
// rebase new memdag mutations onto perdag
|
|
101
|
+
newMainClientGroupHeadHash = await rebase(newMemdagMutations, newMainClientGroupHeadHash, perdagWrite, mutators, mutationIDs, lc, formatVersion);
|
|
102
|
+
const newMainClientGroup = {
|
|
103
|
+
...mainClientGroup,
|
|
104
|
+
headHash: newMainClientGroupHeadHash,
|
|
105
|
+
mutationIDs,
|
|
106
|
+
lastServerAckdMutationIDs,
|
|
107
|
+
};
|
|
108
|
+
await setClientGroup(mainClientGroupID, newMainClientGroup, perdagWrite);
|
|
109
|
+
});
|
|
110
|
+
if (gatheredChunks && memdagBaseSnapshotPersisted) {
|
|
111
|
+
await withWrite(memdag, memdagWrite => memdagWrite.chunksPersisted([...gatheredChunks.keys()]));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
async function getClientGroupInfo(perdagRead, clientGroupID) {
|
|
115
|
+
const clientGroup = await getClientGroup(clientGroupID, perdagRead);
|
|
116
|
+
assert(clientGroup, `No client group for clientGroupID: ${clientGroupID}`);
|
|
117
|
+
return [clientGroup, await commitFromHash(clientGroup.headHash, perdagRead)];
|
|
118
|
+
}
|
|
119
|
+
async function rebase(mutations, basis, write, mutators, mutationIDs, lc, formatVersion) {
|
|
120
|
+
for (let i = mutations.length - 1; i >= 0; i--) {
|
|
121
|
+
const mutationCommit = mutations[i];
|
|
122
|
+
const { meta } = mutationCommit;
|
|
123
|
+
const newMainHead = await commitFromHash(basis, write);
|
|
124
|
+
if ((await mutationCommit.getMutationID(meta.clientID, write)) >
|
|
125
|
+
(await newMainHead.getMutationID(meta.clientID, write))) {
|
|
126
|
+
mutationIDs[meta.clientID] = meta.mutationID;
|
|
127
|
+
basis = (await rebaseMutationAndPutCommit(mutationCommit, write, basis, mutators, lc, meta.clientID, formatVersion)).chunk.hash;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
return basis;
|
|
131
|
+
}
|
|
132
|
+
//# sourceMappingURL=persist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persist.js","sourceRoot":"","sources":["../../../../../replicache/src/persist/persist.ts"],"names":[],"mappings":"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"}
|