///
import { Comlink, type CompiledQuery, Debug, DenoSqlite3, type QueryResult } from '@/deps.ts';
import '@/sentry.ts';
let db: DenoSqlite3 | undefined;
const debug = Debug('ditto:sqlite.worker');
export const SqliteWorker = {
open(path: string): void {
db = new DenoSqlite3(path);
},
executeQuery({ sql, parameters }: CompiledQuery): QueryResult {
if (!db) throw new Error('Database not open');
debug(sql);
return {
rows: db!.prepare(sql).all(...parameters as any[]) as R[],
numAffectedRows: BigInt(db!.changes),
insertId: BigInt(db!.lastInsertRowId),
};
},
destroy() {
db?.close();
},
};
Comlink.expose(SqliteWorker);
self.postMessage(['ready']);