2018-02-12 17:29:03 +01:00
|
|
|
package database
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/apex/log"
|
|
|
|
"github.com/jmoiron/sqlx"
|
2018-02-13 17:11:22 +01:00
|
|
|
_ "github.com/mattn/go-sqlite3" // this is needed to load the sqlite3 driver
|
2018-02-12 17:29:03 +01:00
|
|
|
"github.com/openobservatory/gooni/internal/bindata"
|
|
|
|
migrate "github.com/rubenv/sql-migrate"
|
|
|
|
)
|
|
|
|
|
|
|
|
// RunMigrations runs the database migrations
|
|
|
|
func RunMigrations(db *sqlx.DB) error {
|
2018-02-13 17:11:22 +01:00
|
|
|
log.Debugf("running migrations")
|
2018-02-12 17:29:03 +01:00
|
|
|
migrations := &migrate.AssetMigrationSource{
|
|
|
|
Asset: bindata.Asset,
|
|
|
|
AssetDir: bindata.AssetDir,
|
|
|
|
Dir: "data/migrations",
|
|
|
|
}
|
|
|
|
n, err := migrate.Exec(db.DB, "sqlite3", migrations, migrate.Up)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
log.Debugf("performed %d migrations", n)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2018-02-13 17:11:22 +01:00
|
|
|
// Connect to the database
|
2018-03-08 11:25:40 +01:00
|
|
|
func Connect(path string) (db *sqlx.DB, err error) {
|
|
|
|
db, err = sqlx.Connect("sqlite3", path)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2018-02-13 17:11:22 +01:00
|
|
|
err = RunMigrations(db)
|
|
|
|
if err != nil {
|
2018-03-08 11:25:40 +01:00
|
|
|
db = nil
|
2018-02-13 17:11:22 +01:00
|
|
|
}
|
2018-03-08 11:25:40 +01:00
|
|
|
return
|
2018-02-12 17:29:03 +01:00
|
|
|
}
|