Semaphore/db/migrations.go

110 lines
2.2 KiB
Go
Raw Normal View History

2016-05-24 11:55:48 +02:00
package db
2016-01-05 00:32:53 +01:00
import (
"fmt"
"time"
2016-03-16 22:49:43 +01:00
"github.com/ansible-semaphore/semaphore/util"
"github.com/go-sql-driver/mysql"
2016-01-05 00:32:53 +01:00
)
func (version *DBVersion) CheckExists() (bool, error) {
2016-05-24 11:55:48 +02:00
exists, err := Mysql.SelectInt("select count(1) as ex from migrations where version=?", version.VersionString())
2016-01-05 00:32:53 +01:00
if err != nil {
switch err.(type) {
case *mysql.MySQLError:
// 1146 is mysql table does not exist
if err.(*mysql.MySQLError).Number != 1146 {
return false, err
}
fmt.Println("Creating migrations table")
2016-05-24 11:55:48 +02:00
if _, err := Mysql.Exec(initialSQL); err != nil {
2016-01-05 00:32:53 +01:00
panic(err)
}
return version.CheckExists()
default:
return false, err
}
}
return exists > 0, nil
}
func (version *DBVersion) Run() error {
fmt.Printf("Executing migration %s (at %v)...\n", version.HumanoidVersion(), time.Now())
2016-05-24 11:55:48 +02:00
tx, err := Mysql.Begin()
2016-01-05 00:32:53 +01:00
if err != nil {
return err
}
sql := version.GetSQL(version.GetPath())
for i, query := range sql {
fmt.Printf("\r [%d/%d]", i+1, len(sql))
if len(query) == 0 {
continue
}
if _, err := tx.Exec(query); err != nil {
tx.Rollback()
fmt.Printf("\n ERR! Query: %v\n\n", query)
return err
}
}
if _, err := tx.Exec("insert into migrations set version=?, upgraded_date=?", version.VersionString(), time.Now()); err != nil {
tx.Rollback()
return err
}
fmt.Println()
return tx.Commit()
}
func (version *DBVersion) TryRollback() {
fmt.Printf("Rolling back %s (time: %v)...\n", version.HumanoidVersion(), time.Now())
if _, err := util.Asset(version.GetErrPath()); err != nil {
fmt.Println("Rollback SQL doesn't exist.")
fmt.Println()
return
}
sql := version.GetSQL(version.GetErrPath())
for _, query := range sql {
fmt.Printf(" [ROLLBACK] > %v\n", query)
2016-05-24 11:55:48 +02:00
if _, err := Mysql.Exec(query); err != nil {
2016-01-05 00:32:53 +01:00
fmt.Println(" [ROLLBACK] - Stopping")
return
}
}
}
func MigrateAll() error {
// go from beginning to the end
for _, version := range Versions {
if exists, err := version.CheckExists(); err != nil || exists == true {
if exists == true {
fmt.Printf("Skipping %s\n", version.HumanoidVersion())
continue
}
return err
}
if err := version.Run(); err != nil {
version.TryRollback()
return err
}
}
return nil
}