UNPKG

rxdb

Version:

A local-first realtime NoSQL Database for JavaScript applications - https://rxdb.info/

75 lines (72 loc) 2.54 kB
import { PROMISE_RESOLVE_TRUE } from "../../plugins/utils/index.js"; import { REPLICATION_STATE_BY_COLLECTION } from "../replication/index.js"; import { DEFAULT_CLEANUP_POLICY } from "./cleanup-helper.js"; import { initialCleanupWait } from "./cleanup.js"; import { firstValueFrom } from 'rxjs'; var RXSTATE_CLEANUP_QUEUE = PROMISE_RESOLVE_TRUE; export async function startCleanupForRxState(state) { var rxCollection = state.collection; var rxDatabase = rxCollection.database; var cleanupPolicy = Object.assign({}, DEFAULT_CLEANUP_POLICY, rxDatabase.cleanupPolicy ? rxDatabase.cleanupPolicy : {}); await initialCleanupWait(rxCollection, cleanupPolicy); if (rxCollection.closed) { return; } // initially cleanup the state await cleanupRxState(state, cleanupPolicy); /** * Afterwards we listen to writes * and only re-run the cleanup if there was a write * to the state. */ await runCleanupAfterWrite(state, cleanupPolicy); } /** * Runs the cleanup for a single RxState */ export async function cleanupRxState(state, cleanupPolicy) { var rxCollection = state.collection; var rxDatabase = rxCollection.database; // run cleanup() until it returns true var isDone = false; while (!isDone && !rxCollection.closed) { if (cleanupPolicy.awaitReplicationsInSync) { var replicationStates = REPLICATION_STATE_BY_COLLECTION.get(rxCollection); if (replicationStates) { await Promise.all(replicationStates.map(replicationState => { if (!replicationState.isStopped()) { return replicationState.awaitInSync(); } })); } } if (rxCollection.closed) { return; } RXSTATE_CLEANUP_QUEUE = RXSTATE_CLEANUP_QUEUE.then(async () => { if (rxCollection.closed) { return true; } await rxDatabase.requestIdlePromise(); return state._cleanup(); }); isDone = await RXSTATE_CLEANUP_QUEUE; } } export async function runCleanupAfterWrite(state, cleanupPolicy) { var rxCollection = state.collection; while (!rxCollection.closed) { /** * We only start the timer if there was actually a write * to the collection. Otherwise the cleanup would * just run on intervals even if nothing has changed. */ await firstValueFrom(rxCollection.eventBulks$).catch(() => {}); await rxCollection.promiseWait(cleanupPolicy.runEach); if (rxCollection.closed) { return; } await cleanupRxState(state, cleanupPolicy); } } //# sourceMappingURL=cleanup-state.js.map