Files
dbsetup/database.go
2025-06-10 19:56:40 +02:00

67 lines
1.7 KiB
Go

package dbsetup
import (
"io/fs"
"github.com/jmoiron/sqlx"
"github.com/pressly/goose/v3"
"github.com/uptrace/opentelemetry-go-extra/otelsqlx"
)
type DatabaseConfig struct {
DatabaseURL string `name:"postgres-url" env:"POSTGRES_URL" help:"URL to use to connect to Postgres" default:"postgres://postgres:postgres@:5432/postgres?sslmode=disable"`
DatabaseDriverName string `name:"db-driver" env:"DB_DRIVER" help:"Driver to use to connect to db" default:"postgres"`
MaxOpenConnections int `name:"max-open-connections" env:"DB_MAX_CONNECTIONS" help:"Max open connections to db" default:"50"`
}
type Database struct {
cfg DatabaseConfig
}
func SetupDB(cfg DatabaseConfig) (*Database, error) {
db, err := sqlx.Connect(cfg.DatabaseDriverName, cfg.DatabaseURL)
if err != nil {
return nil, err
}
if err := db.Close(); err != nil {
return nil, err
}
return &Database{
cfg: cfg,
}, nil
}
func (d *Database) Connect() (*sqlx.DB, error) {
db, err := otelsqlx.Connect(d.cfg.DatabaseDriverName, d.cfg.DatabaseURL)
if err != nil {
return nil, err
}
db.SetMaxOpenConns(d.cfg.MaxOpenConnections)
return db, nil
}
func (d *Database) RunMigrations(tableName, dir string, fs fs.FS) error {
db, err := connect(d.cfg)
if err != nil {
return err
}
goose.SetTableName(tableName)
goose.SetBaseFS(fs)
if err := goose.SetDialect(d.gooseDriverName()); err != nil {
return err
}
return goose.Up(db.DB, dir)
}
func (d *Database) gooseDriverName() string {
if d.cfg.DatabaseDriverName == "sqlmock" {
return "postgres"
}
return d.cfg.DatabaseDriverName
}
func connect(cfg DatabaseConfig) (*sqlx.DB, error) {
return sqlx.Connect(cfg.DatabaseDriverName, cfg.DatabaseURL)
}