dialect agnostic approach
This commit is contained in:
50
cli/cli.go
50
cli/cli.go
@@ -2,45 +2,45 @@ package migratecli
|
||||
|
||||
import (
|
||||
"context"
|
||||
"database/sql"
|
||||
"fmt"
|
||||
|
||||
"gitea.auvem.com/go-toolkit/app"
|
||||
"gitea.auvem.com/go-toolkit/appcli"
|
||||
"gitea.auvem.com/go-toolkit/dbx"
|
||||
"gitea.auvem.com/go-toolkit/migrate"
|
||||
"github.com/pressly/goose/v3"
|
||||
"github.com/urfave/cli/v3"
|
||||
)
|
||||
|
||||
// MigrateCmd returns the main migrate command.
|
||||
func MigrateCmd(directDeps []*app.Module, childDeps []*app.Module) *cli.Command {
|
||||
func MigrateCmd(sqlo *sql.DB, directDeps []*app.Module, childDeps []*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "migrate",
|
||||
Usage: "Migrate the database",
|
||||
Commands: AllSubcommands(childDeps...),
|
||||
Commands: AllSubcommands(sqlo, childDeps...),
|
||||
}, directDeps...)
|
||||
}
|
||||
|
||||
// AllSubcommands returns all subcommands of the migrate command.
|
||||
func AllSubcommands(deps ...*app.Module) []*cli.Command {
|
||||
func AllSubcommands(sqlo *sql.DB, deps ...*app.Module) []*cli.Command {
|
||||
return []*cli.Command{
|
||||
MigrateStatusCmd(deps...),
|
||||
MigrateCreateCmd(deps...),
|
||||
MigrateUpCmd(deps...),
|
||||
MigrateUpToCmd(deps...),
|
||||
MigrateDownCmd(deps...),
|
||||
MigrateDownToCmd(deps...),
|
||||
MigrateRedoCmd(deps...),
|
||||
MigrateStatusCmd(sqlo, deps...),
|
||||
MigrateCreateCmd(sqlo, deps...),
|
||||
MigrateUpCmd(sqlo, deps...),
|
||||
MigrateUpToCmd(sqlo, deps...),
|
||||
MigrateDownCmd(sqlo, deps...),
|
||||
MigrateDownToCmd(sqlo, deps...),
|
||||
MigrateRedoCmd(sqlo, deps...),
|
||||
}
|
||||
}
|
||||
|
||||
// MigrateStatusCmd returns a command to get database migration status.
|
||||
func MigrateStatusCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateStatusCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "status",
|
||||
Usage: "Get database migration status",
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
if err := goose.Status(dbx.SQLO(), migrate.MigrationsConfig().BasePath); err != nil {
|
||||
if err := goose.Status(sqlo, migrate.MigrationsConfig().BasePath); err != nil {
|
||||
return fmt.Errorf("couldn't get migration status: %v", err)
|
||||
}
|
||||
|
||||
@@ -50,7 +50,7 @@ func MigrateStatusCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateCreateCmd returns a command to create a new migration.
|
||||
func MigrateCreateCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateCreateCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "create",
|
||||
Usage: "Create a new migration",
|
||||
@@ -70,7 +70,7 @@ func MigrateCreateCmd(deps ...*app.Module) *cli.Command {
|
||||
goose.SetSequential(sequential)
|
||||
}
|
||||
|
||||
if err := goose.Create(dbx.SQLO(), "migrations", cmd.StringArg("name"), cmd.StringArg("type")); err != nil {
|
||||
if err := goose.Create(sqlo, "migrations", cmd.StringArg("name"), cmd.StringArg("type")); err != nil {
|
||||
return fmt.Errorf("couldn't create migration: %v", err)
|
||||
}
|
||||
|
||||
@@ -80,12 +80,12 @@ func MigrateCreateCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateUpCmd returns a command to apply all available database migrations.
|
||||
func MigrateUpCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateUpCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "up",
|
||||
Usage: "Apply all available database migrations",
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
if err := goose.Up(dbx.SQLO(), migrate.MigrationsConfig().BasePath); err != nil {
|
||||
if err := goose.Up(sqlo, migrate.MigrationsConfig().BasePath); err != nil {
|
||||
return fmt.Errorf("couldn't apply migrations: %v", err)
|
||||
}
|
||||
return nil
|
||||
@@ -94,7 +94,7 @@ func MigrateUpCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateUpToCmd returns a command to apply all available database migrations up to a specific version.
|
||||
func MigrateUpToCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateUpToCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "up-to",
|
||||
Usage: "Apply all available database migrations up to a specific version",
|
||||
@@ -106,7 +106,7 @@ func MigrateUpToCmd(deps ...*app.Module) *cli.Command {
|
||||
},
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
version := cmd.Int64("version")
|
||||
if err := goose.UpTo(dbx.SQLO(), migrate.MigrationsConfig().BasePath, version); err != nil {
|
||||
if err := goose.UpTo(sqlo, migrate.MigrationsConfig().BasePath, version); err != nil {
|
||||
return fmt.Errorf("couldn't apply migrations to target version %d: %v", version, err)
|
||||
}
|
||||
return nil
|
||||
@@ -115,12 +115,12 @@ func MigrateUpToCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateDownCmd returns a command to rollback the most recent database migration.
|
||||
func MigrateDownCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateDownCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "down",
|
||||
Usage: "Rollback the most recent database migration",
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
if err := goose.Down(dbx.SQLO(), migrate.MigrationsConfig().BasePath); err != nil {
|
||||
if err := goose.Down(sqlo, migrate.MigrationsConfig().BasePath); err != nil {
|
||||
return fmt.Errorf("couldn't rollback migration: %v", err)
|
||||
}
|
||||
return nil
|
||||
@@ -129,7 +129,7 @@ func MigrateDownCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateDownToCmd returns a command to rollback all database migrations down to a specific version.
|
||||
func MigrateDownToCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateDownToCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "down-to",
|
||||
Usage: "Rollback all database migrations down to a specific version",
|
||||
@@ -141,7 +141,7 @@ func MigrateDownToCmd(deps ...*app.Module) *cli.Command {
|
||||
},
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
version := cmd.Int64("version")
|
||||
if err := goose.DownTo(dbx.SQLO(), migrate.MigrationsConfig().BasePath, version); err != nil {
|
||||
if err := goose.DownTo(sqlo, migrate.MigrationsConfig().BasePath, version); err != nil {
|
||||
return fmt.Errorf("couldn't rollback migrations to target version %d: %v", version, err)
|
||||
}
|
||||
return nil
|
||||
@@ -150,12 +150,12 @@ func MigrateDownToCmd(deps ...*app.Module) *cli.Command {
|
||||
}
|
||||
|
||||
// MigrateRedoCmd returns a command to rollback the most recent database migration and reapply it.
|
||||
func MigrateRedoCmd(deps ...*app.Module) *cli.Command {
|
||||
func MigrateRedoCmd(sqlo *sql.DB, deps ...*app.Module) *cli.Command {
|
||||
return appcli.NewCommand(&cli.Command{
|
||||
Name: "redo",
|
||||
Usage: "Rollback the most recent database migration and reapply it",
|
||||
Action: func(ctx context.Context, cmd *cli.Command) error {
|
||||
if err := goose.Redo(dbx.SQLO(), migrate.MigrationsConfig().BasePath); err != nil {
|
||||
if err := goose.Redo(sqlo, migrate.MigrationsConfig().BasePath); err != nil {
|
||||
return fmt.Errorf("couldn't redo migration: %v", err)
|
||||
}
|
||||
return nil
|
||||
|
||||
Reference in New Issue
Block a user