29 lines
706 B
TypeScript

import Database, { type Database as DatabaseType } from "better-sqlite3";
import path from "node:path";
import fs from "node:fs";
import { fileURLToPath } from "url";
const __dirname = path.dirname(fileURLToPath(import.meta.url));
export const loadDb = (
filename: string,
onCreate?: (db: DatabaseType) => void
) => {
const dbDir = path.resolve(__dirname, "../storage/db");
if (!fs.existsSync(dbDir)) {
fs.mkdirSync(dbDir, { recursive: true });
}
const dbPath = path.resolve(dbDir, filename + ".db");
const isDbExist = fs.existsSync(dbPath);
const db = new Database(dbPath);
db.pragma("journal_mode = WAL");
if (!isDbExist && onCreate) {
onCreate(db);
}
return db;
};