feat: create drizzle database client
This commit is contained in:
77
src/database/drizzle.ts
Normal file
77
src/database/drizzle.ts
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
import { drizzle as drizzlePostgres } from "drizzle-orm/node-postgres";
|
||||||
|
import { drizzle as drizzleSqlite } from "drizzle-orm/better-sqlite3";
|
||||||
|
import Database from "better-sqlite3";
|
||||||
|
import { Pool } from "pg";
|
||||||
|
import { config } from "../config";
|
||||||
|
import { createChildLogger } from "../logger";
|
||||||
|
import * as schema from "./schema";
|
||||||
|
|
||||||
|
const logger = createChildLogger("drizzle");
|
||||||
|
|
||||||
|
let db: ReturnType<typeof drizzlePostgres> | ReturnType<typeof drizzleSqlite> | null = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initialize the database connection based on DATABASE_TYPE config
|
||||||
|
* Supports both PostgreSQL and SQLite
|
||||||
|
*/
|
||||||
|
export async function initializeDatabase() {
|
||||||
|
if (db !== null) {
|
||||||
|
logger.debug("Database already initialized, skipping");
|
||||||
|
return db;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (config.DATABASE_TYPE === "postgres") {
|
||||||
|
const pool = new Pool({
|
||||||
|
host: config.POSTGRES_HOST,
|
||||||
|
port: config.POSTGRES_PORT,
|
||||||
|
user: config.POSTGRES_USER,
|
||||||
|
password: config.POSTGRES_PASSWORD,
|
||||||
|
database: config.POSTGRES_DB,
|
||||||
|
min: config.POSTGRES_POOL_MIN,
|
||||||
|
max: config.POSTGRES_POOL_MAX,
|
||||||
|
});
|
||||||
|
|
||||||
|
db = drizzlePostgres(pool, { schema });
|
||||||
|
logger.info("PostgreSQL database initialized");
|
||||||
|
} else {
|
||||||
|
const sqlite = new Database(".muxer-queue.db");
|
||||||
|
sqlite.pragma("journal_mode = WAL");
|
||||||
|
|
||||||
|
db = drizzleSqlite(sqlite, { schema });
|
||||||
|
logger.info("SQLite database initialized");
|
||||||
|
}
|
||||||
|
|
||||||
|
return db;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the initialized database instance
|
||||||
|
* Throws if database has not been initialized
|
||||||
|
*/
|
||||||
|
export function getDatabase() {
|
||||||
|
if (db === null) {
|
||||||
|
throw new Error(
|
||||||
|
"Database not initialized. Call initializeDatabase() first."
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return db;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Close the database connection
|
||||||
|
* For PostgreSQL, the pool will close on process exit
|
||||||
|
* For SQLite, closes the database connection
|
||||||
|
*/
|
||||||
|
export async function closeDatabase() {
|
||||||
|
if (db === null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (config.DATABASE_TYPE === "postgres") {
|
||||||
|
logger.info("PostgreSQL connection pool will close on process exit");
|
||||||
|
} else {
|
||||||
|
logger.info("SQLite database closed");
|
||||||
|
}
|
||||||
|
|
||||||
|
db = null;
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user