mirror of https://github.com/pressly/goose.git
Move the MySQL normalize DNS function dependency to cmd/
parent
f8632df590
commit
0cdcc45122
|
@ -1,8 +1,33 @@
|
||||||
// +build !no_mysql
|
// +build mysql
|
||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/go-sql-driver/mysql"
|
||||||
|
|
||||||
_ "github.com/go-sql-driver/mysql"
|
_ "github.com/go-sql-driver/mysql"
|
||||||
_ "github.com/ziutek/mymysql/godrv"
|
_ "github.com/ziutek/mymysql/godrv"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// normalizeMySQLDSN parses the dsn used with the mysql driver to always have
|
||||||
|
// the parameter `parseTime` set to true. This allows internal goose logic
|
||||||
|
// to assume that DATETIME/DATE/TIMESTAMP can be scanned into the time.Time
|
||||||
|
// type.
|
||||||
|
func normalizeDBString(str string) string {
|
||||||
|
var err error
|
||||||
|
str, err = normalizeMySQLDSN(dns string)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalf("failed to normalize MySQL connection string: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func normalizeMySQLDSN(dns string) (string, error) {
|
||||||
|
config, err := mysql.ParseDSN(dsn)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
config.ParseTime = true
|
||||||
|
return config.FormatDSN(), nil
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
// +build !mysql
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
_ "github.com/go-sql-driver/mysql"
|
||||||
|
_ "github.com/ziutek/mymysql/godrv"
|
||||||
|
)
|
||||||
|
|
||||||
|
func normalizeDBString(str string) string {
|
||||||
|
return str
|
||||||
|
}
|
|
@ -55,13 +55,7 @@ func main() {
|
||||||
|
|
||||||
driver, dbstring, command := args[0], args[1], args[2]
|
driver, dbstring, command := args[0], args[1], args[2]
|
||||||
|
|
||||||
switch dbstring {
|
db, err := goose.OpenDBWithDriver(driver, normalizeDBString(dbstring))
|
||||||
case "":
|
|
||||||
log.Fatalf("-dbstring=%q not supported\n", dbstring)
|
|
||||||
default:
|
|
||||||
}
|
|
||||||
|
|
||||||
db, err := goose.OpenDBWithDriver(driver, dbstring)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalf("-dbstring=%q: %v\n", dbstring, err)
|
log.Fatalf("-dbstring=%q: %v\n", dbstring, err)
|
||||||
}
|
}
|
||||||
|
|
23
db.go
23
db.go
|
@ -3,8 +3,6 @@ package goose
|
||||||
import (
|
import (
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/go-sql-driver/mysql"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// OpenDBWithDriver creates a connection a database, and modifies goose
|
// OpenDBWithDriver creates a connection a database, and modifies goose
|
||||||
|
@ -22,28 +20,9 @@ func OpenDBWithDriver(driver string, dbstring string) (*sql.DB, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
switch driver {
|
switch driver {
|
||||||
case "postgres", "sqlite3":
|
case "postgres", "sqlite3", "mysql":
|
||||||
return sql.Open(driver, dbstring)
|
return sql.Open(driver, dbstring)
|
||||||
case "mysql":
|
|
||||||
dsn, err := normalizeMySQLDSN(dbstring)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return sql.Open(driver, dsn)
|
|
||||||
default:
|
default:
|
||||||
return nil, fmt.Errorf("unsupported driver %s", driver)
|
return nil, fmt.Errorf("unsupported driver %s", driver)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// normalizeMySQLDSN parses the dsn used with the mysql driver to always have
|
|
||||||
// the parameter `parseTime` set to true. This allows internal goose logic
|
|
||||||
// to assume that DATETIME/DATE/TIMESTAMP can be scanned into the time.Time
|
|
||||||
// type.
|
|
||||||
func normalizeMySQLDSN(dsn string) (string, error) {
|
|
||||||
config, err := mysql.ParseDSN(dsn)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
config.ParseTime = true
|
|
||||||
return config.FormatDSN(), nil
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue