2014-09-26 10:10:48 +03:00
|
|
|
package database
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
2014-09-27 22:00:58 +03:00
|
|
|
"os"
|
2014-09-26 10:10:48 +03:00
|
|
|
|
|
|
|
"github.com/drone/drone/server/datastore"
|
2014-09-29 06:20:35 +03:00
|
|
|
"github.com/drone/drone/server/datastore/migrate"
|
2014-09-26 10:10:48 +03:00
|
|
|
|
|
|
|
"github.com/BurntSushi/migration"
|
|
|
|
_ "github.com/go-sql-driver/mysql"
|
|
|
|
_ "github.com/lib/pq"
|
|
|
|
_ "github.com/mattn/go-sqlite3"
|
|
|
|
"github.com/russross/meddler"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
driverPostgres = "postgres"
|
|
|
|
driverSqlite = "sqlite3"
|
|
|
|
driverMysql = "mysql"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Connect is a helper function that establishes a new
|
|
|
|
// database connection and auto-generates the database
|
|
|
|
// schema. If the database already exists, it will perform
|
|
|
|
// and update as needed.
|
|
|
|
func Connect(driver, datasource string) (*sql.DB, error) {
|
|
|
|
switch driver {
|
|
|
|
case driverPostgres:
|
|
|
|
meddler.Default = meddler.PostgreSQL
|
|
|
|
case driverSqlite:
|
|
|
|
meddler.Default = meddler.SQLite
|
|
|
|
case driverMysql:
|
|
|
|
meddler.Default = meddler.MySQL
|
|
|
|
}
|
|
|
|
migration.DefaultGetVersion = migrate.GetVersion
|
|
|
|
migration.DefaultSetVersion = migrate.SetVersion
|
|
|
|
var migrations = []migration.Migrator{
|
|
|
|
migrate.Setup,
|
2014-10-22 10:13:47 +03:00
|
|
|
migrate.Migrate_20142110,
|
2014-12-30 18:37:57 +02:00
|
|
|
migrate.Migrate_20143012,
|
2014-09-26 10:10:48 +03:00
|
|
|
}
|
|
|
|
return migration.Open(driver, datasource, migrations)
|
|
|
|
}
|
|
|
|
|
2014-09-26 10:39:07 +03:00
|
|
|
// MustConnect is a helper function that creates a
|
2014-09-27 22:00:58 +03:00
|
|
|
// new database connection and auto-generates the
|
2014-09-26 10:10:48 +03:00
|
|
|
// database schema. An error causes a panic.
|
|
|
|
func MustConnect(driver, datasource string) *sql.DB {
|
|
|
|
db, err := Connect(driver, datasource)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return db
|
|
|
|
}
|
|
|
|
|
2014-09-27 22:00:58 +03:00
|
|
|
// mustConnectTest is a helper function that creates a
|
|
|
|
// new database connection using environment variables.
|
|
|
|
// If not environment varaibles are found, the default
|
|
|
|
// in-memory SQLite database is used.
|
|
|
|
func mustConnectTest() *sql.DB {
|
|
|
|
var (
|
|
|
|
driver = os.Getenv("TEST_DRIVER")
|
|
|
|
datasource = os.Getenv("TEST_DATASOURCE")
|
|
|
|
)
|
|
|
|
if len(driver) == 0 {
|
|
|
|
driver = driverSqlite
|
|
|
|
datasource = ":memory:"
|
|
|
|
}
|
|
|
|
db, err := Connect(driver, datasource)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
return db
|
|
|
|
}
|
|
|
|
|
2014-09-29 04:36:24 +03:00
|
|
|
// New returns a new Datastore
|
|
|
|
func NewDatastore(db *sql.DB) datastore.Datastore {
|
2014-09-26 10:10:48 +03:00
|
|
|
return struct {
|
|
|
|
*Userstore
|
|
|
|
*Permstore
|
|
|
|
*Repostore
|
|
|
|
*Commitstore
|
|
|
|
}{
|
|
|
|
NewUserstore(db),
|
|
|
|
NewPermstore(db),
|
|
|
|
NewRepostore(db),
|
|
|
|
NewCommitstore(db),
|
|
|
|
}
|
|
|
|
}
|