aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/db/index.ts
blob: 1613abc39855d4ceac250ae9006aa747dc753118 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import Database from "better-sqlite3";
import { app } from "electron";
import path from "node:path";
import fs from "node:fs";
import { initSchema } from "./schema";

let db: Database.Database | null = null;

export function getDb(): Database.Database {
  if (db) return db;

  const dbDir = app.getPath("userData");
  if (!fs.existsSync(dbDir)) {
    fs.mkdirSync(dbDir, { recursive: true });
  }

  const dbPath = path.join(dbDir, "claude-flow.db");
  db = new Database(dbPath);
  db.pragma("journal_mode = WAL");
  db.pragma("foreign_keys = ON");

  initSchema(db);
  runMigrations(db);

  return db;
}

function runMigrations(db: Database.Database): void {
  // v2: add git_branch column to sessions
  const cols = db.pragma("table_info(sessions)") as { name: string }[];
  if (!cols.find((c) => c.name === "git_branch")) {
    db.exec("ALTER TABLE sessions ADD COLUMN git_branch TEXT");
  }
}

export function closeDb() {
  if (db) {
    db.close();
    db = null;
  }
}