import { drizzle, type PostgresJsDatabase } from 'drizzle-orm/postgres-js'; import postgres from 'postgres'; import * as schema from './schema.js'; import { DEFAULT_DATABASE_URL } from './defaults.js'; export type Db = PostgresJsDatabase; export interface DbHandle { db: Db; close: () => Promise; } export function createDb(url?: string): DbHandle { const connectionString = url ?? process.env['DATABASE_URL'] ?? DEFAULT_DATABASE_URL; const sql = postgres(connectionString); const db = drizzle(sql, { schema }); return { db, close: () => sql.end() }; }