aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/db/db.go
blob: 82139035592575a0ddecdd6418a6d2e0192960c4 (plain) (blame)
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
42
43
44
45
46
package db

import (
	"database/sql"
	"log/slog"
	"os"

	_ "github.com/mattn/go-sqlite3"
)

var Logger *slog.Logger

// Create a new database connection
func New() *sql.DB {
	conn, err := sql.Open("sqlite3", "./foo.db")
	if err != nil {
		Logger.Error("Failed to create database connection")
		panic(err)
	}

    if err = InitTables(conn); err != nil {
        panic(err)
    }

	return conn
}

func InitTables(conn *sql.DB) error {
	_, err := conn.Exec(`
    CREATE TABLE IF NOT EXISTS users (
        id INTEGER PRIMARY KEY AUTOINCREMENT,
        username TEXT UNIQUE NOT NULL,
        salt BLOB NOT NULL,
        saltedHash BLOB NOT NULL
    )
    `)

	if err != nil {
		return err
	}
	return nil
}

func init() {
	Logger = slog.New(slog.NewTextHandler(os.Stdout, nil))
}