* clean up helpers * shared in it's own top level folder * workspaces setup * build fix * disable workspaces? * run ci * rename job-flow to gradcracker * optional dependencies * formatting? * more optional modules * allow post install runs * node bump * remove post install * add optionals * add more * formatting * comments, but im unsure * run typescript DIRECTLY * better build * camoufox simplification * lint * build process doesn't exist * build fix * lockfile * type check everything, build only for client * rename steps correctly * import from package! * fix formatting * don't fetch twice * fix concern
31 lines
758 B
TypeScript
31 lines
758 B
TypeScript
/**
|
|
* Database connection and initialization.
|
|
*/
|
|
|
|
import { existsSync, mkdirSync } from "node:fs";
|
|
import { dirname, join } from "node:path";
|
|
import Database from "better-sqlite3";
|
|
import { drizzle } from "drizzle-orm/better-sqlite3";
|
|
import { getDataDir } from "../config/dataDir";
|
|
import * as schema from "./schema";
|
|
|
|
// Database path - can be overridden via env for Docker
|
|
const DB_PATH = join(getDataDir(), "jobs.db");
|
|
|
|
// Ensure data directory exists
|
|
const dataDir = dirname(DB_PATH);
|
|
if (!existsSync(dataDir)) {
|
|
mkdirSync(dataDir, { recursive: true });
|
|
}
|
|
|
|
const sqlite = new Database(DB_PATH);
|
|
sqlite.pragma("journal_mode = WAL");
|
|
|
|
export const db = drizzle(sqlite, { schema });
|
|
|
|
export { schema };
|
|
|
|
export function closeDb() {
|
|
sqlite.close();
|
|
}
|