rxdb
Version:
A local-first realtime NoSQL Database for JavaScript applications - https://rxdb.info/
131 lines (125 loc) • 4.45 kB
JavaScript
import { createRevision, flatClone, getDefaultRevision, getDefaultRxDocumentMeta, now } from "./plugins/utils/index.js";
import { fillObjectWithDefaults, fillPrimaryKey } from "./rx-schema-helper.js";
import { runAsyncPluginHooks } from "./hooks.js";
import { getAllCollectionDocuments } from "./rx-database-internal-store.js";
import { flatCloneDocWithMeta } from "./rx-storage-helper.js";
import { overwritable } from "./overwritable.js";
import { newRxError } from "./rx-error.js";
/**
* fills in the default data.
* This also clones the data.
*/
export function fillObjectDataBeforeInsert(schema, data) {
data = flatClone(data);
data = fillObjectWithDefaults(schema, data);
if (typeof schema.jsonSchema.primaryKey !== 'string') {
data = fillPrimaryKey(schema.primaryPath, schema.jsonSchema, data);
}
data._meta = getDefaultRxDocumentMeta();
if (!Object.prototype.hasOwnProperty.call(data, '_deleted')) {
data._deleted = false;
}
if (!Object.prototype.hasOwnProperty.call(data, '_attachments')) {
data._attachments = {};
}
if (!Object.prototype.hasOwnProperty.call(data, '_rev')) {
data._rev = getDefaultRevision();
}
return data;
}
/**
* Creates the storage instances that are used internally in the collection
*/
export async function createRxCollectionStorageInstance(rxDatabase, storageInstanceCreationParams) {
storageInstanceCreationParams.multiInstance = rxDatabase.multiInstance;
var storageInstance = await rxDatabase.storage.createStorageInstance(storageInstanceCreationParams);
return storageInstance;
}
/**
* Removes the main storage of the collection
* and all connected storages like the ones from the replication meta etc.
*/
export async function removeCollectionStorages(storage, databaseInternalStorage, databaseInstanceToken, databaseName, collectionName, multiInstance, password,
/**
* If no hash function is provided,
* we assume that the whole internal store is removed anyway
* so we do not have to delete the meta documents.
*/
hashFunction) {
var allCollectionMetaDocs = await getAllCollectionDocuments(databaseInternalStorage);
var relevantCollectionMetaDocs = allCollectionMetaDocs.filter(metaDoc => metaDoc.data.name === collectionName);
var removeStorages = [];
relevantCollectionMetaDocs.forEach(metaDoc => {
removeStorages.push({
collectionName: metaDoc.data.name,
schema: metaDoc.data.schema,
isCollection: true
});
metaDoc.data.connectedStorages.forEach(row => removeStorages.push({
collectionName: row.collectionName,
isCollection: false,
schema: row.schema
}));
});
// ensure uniqueness
var alreadyAdded = new Set();
removeStorages = removeStorages.filter(row => {
var key = row.collectionName + '||' + row.schema.version;
if (alreadyAdded.has(key)) {
return false;
} else {
alreadyAdded.add(key);
return true;
}
});
// remove all the storages
await Promise.all(removeStorages.map(async row => {
var storageInstance = await storage.createStorageInstance({
collectionName: row.collectionName,
databaseInstanceToken,
databaseName,
/**
* multiInstance must be set to true if multiInstance
* was true on the database
* so that the storageInstance can inform other
* instances about being removed.
*/
multiInstance,
options: {},
schema: row.schema,
password,
devMode: overwritable.isDevMode()
});
await storageInstance.remove();
if (row.isCollection) {
await runAsyncPluginHooks('postRemoveRxCollection', {
storage,
databaseName: databaseName,
collectionName
});
}
}));
// remove the meta documents
if (hashFunction) {
var writeRows = relevantCollectionMetaDocs.map(doc => {
var writeDoc = flatCloneDocWithMeta(doc);
writeDoc._deleted = true;
writeDoc._meta.lwt = now();
writeDoc._rev = createRevision(databaseInstanceToken, doc);
return {
previous: doc,
document: writeDoc
};
});
await databaseInternalStorage.bulkWrite(writeRows, 'rx-database-remove-collection-all');
}
}
export function ensureRxCollectionIsNotClosed(collection) {
if (collection.closed) {
throw newRxError('COL21', {
collection: collection.name,
version: collection.schema.version
});
}
}
//# sourceMappingURL=rx-collection-helper.js.map