2018-02-12 17:29:03 +01:00
|
|
|
package database
|
|
|
|
|
|
|
|
import (
|
2018-03-08 11:25:40 +01:00
|
|
|
"os"
|
2018-02-12 17:29:03 +01:00
|
|
|
"path/filepath"
|
|
|
|
|
|
|
|
"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-13 10:48:46 +01:00
|
|
|
ooni "github.com/openobservatory/gooni"
|
2018-02-12 17:29:03 +01:00
|
|
|
"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 {
|
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) {
|
|
|
|
home, err := ooni.GetOONIHome()
|
2018-02-12 17:29:03 +01:00
|
|
|
if err != nil {
|
2018-03-08 11:25:40 +01:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, e := os.Stat(filepath.Join(home, "db")); e != nil {
|
|
|
|
err = os.MkdirAll(filepath.Join(home, "db"), 0700)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
2018-02-12 17:29:03 +01:00
|
|
|
}
|
2018-03-08 11:25:40 +01:00
|
|
|
|
|
|
|
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
|
|
|
}
|
|
|
|
|
2018-02-13 17:11:22 +01:00
|
|
|
// DefaultDatabasePath for the main database
|
2018-02-12 17:29:03 +01:00
|
|
|
func DefaultDatabasePath() (string, error) {
|
2018-02-13 10:48:46 +01:00
|
|
|
home, err := ooni.GetOONIHome()
|
2018-02-12 17:29:03 +01:00
|
|
|
if err != nil {
|
2018-02-13 10:48:46 +01:00
|
|
|
return "", errors.Wrap(err, "default database path")
|
2018-02-12 17:29:03 +01:00
|
|
|
}
|
2018-02-13 17:11:22 +01:00
|
|
|
return filepath.Join(home, "db", "main.sqlite3"), nil
|
2018-02-12 17:29:03 +01:00
|
|
|
}
|