signal-desktop/ts/indexeddb.ts
2025-06-16 11:59:31 -07:00

64 lines
1.7 KiB
TypeScript

// Copyright 2018 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { createLogger } from './logging/log';
const log = createLogger('indexeddb');
const LEGACY_DATABASE_ID = 'signal';
export async function doesDatabaseExist(): Promise<boolean> {
log.info('Checking for the existence of IndexedDB data...');
return new Promise((resolve, reject) => {
const req = window.indexedDB.open(LEGACY_DATABASE_ID);
let existed = true;
let timer: undefined | ReturnType<typeof setTimeout> = setTimeout(() => {
log.warn(
'doesDatabaseExist: Timed out attempting to check IndexedDB status'
);
return resolve(false);
}, 1000);
const clearTimer = () => {
if (timer !== undefined) {
clearTimeout(timer);
timer = undefined;
}
};
req.onerror = error => {
clearTimer();
reject(error);
};
req.onsuccess = () => {
clearTimer();
req.result.close();
resolve(existed);
};
req.onupgradeneeded = () => {
if (req.result.version === 1) {
existed = false;
window.indexedDB.deleteDatabase(LEGACY_DATABASE_ID);
}
};
});
}
export function removeDatabase(): Promise<void> {
return new Promise<void>((resolve, reject) => {
log.info(
`removeDatabase: Deleting IndexedDB database '${LEGACY_DATABASE_ID}'`
);
const request = window.indexedDB.deleteDatabase(LEGACY_DATABASE_ID);
request.onerror = () => {
log.error('removeDatabase: Error deleting database.');
reject(new Error('Error deleting database'));
};
request.onsuccess = () => {
log.info('removeDatabase: Database deleted successfully');
resolve();
};
});
}