46 lines
1.0 KiB
Go
46 lines
1.0 KiB
Go
package database
|
|
|
|
import (
|
|
"path/filepath"
|
|
|
|
"github.com/apex/log"
|
|
"github.com/jmoiron/sqlx"
|
|
_ "github.com/mattn/go-sqlite3"
|
|
ooni "github.com/openobservatory/gooni"
|
|
"github.com/openobservatory/gooni/internal/bindata"
|
|
"github.com/pkg/errors"
|
|
migrate "github.com/rubenv/sql-migrate"
|
|
)
|
|
|
|
// RunMigrations runs the database migrations
|
|
func RunMigrations(db *sqlx.DB) error {
|
|
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
|
|
}
|
|
|
|
func Connect(path string) (*sqlx.DB, error) {
|
|
db, err := sqlx.Connect("sqlite3", path)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
// XXX RunMigrations(db)
|
|
return db, nil
|
|
}
|
|
|
|
func DefaultDatabasePath() (string, error) {
|
|
home, err := ooni.GetOONIHome()
|
|
if err != nil {
|
|
return "", errors.Wrap(err, "default database path")
|
|
}
|
|
return filepath.Join(home, "db", "main.db"), nil
|
|
}
|