2023-09-10 15:39:34 +00:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
2023-10-04 13:37:04 +00:00
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
2023-09-10 15:39:34 +00:00
|
|
|
|
|
|
|
_ "github.com/lib/pq"
|
|
|
|
)
|
|
|
|
|
|
|
|
type DB struct {
|
|
|
|
*sql.DB
|
|
|
|
}
|
|
|
|
|
2023-10-04 13:37:04 +00:00
|
|
|
var (
|
|
|
|
initSqlPath = "./db/init.sql"
|
|
|
|
)
|
|
|
|
|
2023-10-04 11:36:54 +00:00
|
|
|
func New(dbUrl string) (*DB, error) {
|
|
|
|
var (
|
|
|
|
db_ *sql.DB
|
|
|
|
db *DB
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
if db_, err = sql.Open("postgres", dbUrl); err != nil {
|
|
|
|
return nil, err
|
2023-09-10 15:39:34 +00:00
|
|
|
}
|
|
|
|
// test connection
|
2023-10-04 11:36:54 +00:00
|
|
|
if _, err = db_.Exec("SELECT 1"); err != nil {
|
|
|
|
return nil, err
|
2023-09-10 15:39:34 +00:00
|
|
|
}
|
|
|
|
// TODO: run migrations
|
2023-10-04 11:36:54 +00:00
|
|
|
db = &DB{DB: db_}
|
|
|
|
return db, nil
|
2023-09-10 15:39:34 +00:00
|
|
|
}
|
2023-10-04 13:37:04 +00:00
|
|
|
|
|
|
|
func (db *DB) Reset(dbName string) error {
|
|
|
|
var (
|
|
|
|
f []byte
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
if err = db.Clear(dbName); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if f, err = ioutil.ReadFile(initSqlPath); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if _, err = db.Exec(string(f)); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DB) Clear(dbName string) error {
|
|
|
|
var (
|
|
|
|
tables = []string{"lnauth", "users", "sessions", "markets", "shares", "invoices", "order_side", "orders", "matches"}
|
|
|
|
sql []string
|
|
|
|
err error
|
|
|
|
)
|
|
|
|
for _, t := range tables {
|
|
|
|
sql = append(sql, fmt.Sprintf("DROP TABLE IF EXISTS %s CASCADE", t))
|
|
|
|
}
|
|
|
|
sql = append(sql, "DROP EXTENSION IF EXISTS \"uuid-ossp\"")
|
|
|
|
sql = append(sql, "DROP TYPE IF EXISTS order_side")
|
|
|
|
for _, s := range sql {
|
|
|
|
if _, err = db.Exec(s); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|