add db commands
This commit is contained in:
parent
b1f6175226
commit
c8cc15eb35
8 changed files with 274 additions and 3 deletions
|
@ -197,7 +197,6 @@ var handlerCmd = &cobra.Command{
|
|||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
defer viewFileOut.Close()
|
||||
|
||||
var buffer bytes.Buffer
|
||||
if err := viewTempl.Execute(&buffer, tmplData); err != nil {
|
||||
|
@ -253,7 +252,6 @@ var handlerCmd = &cobra.Command{
|
|||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
defer handlerFileOut.Close()
|
||||
|
||||
var buffer bytes.Buffer
|
||||
if err := handlerTempl.Execute(&buffer, tmplData); err != nil {
|
||||
|
@ -268,7 +266,6 @@ var handlerCmd = &cobra.Command{
|
|||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
defer handlerFileOut.Close()
|
||||
|
||||
var buffer bytes.Buffer
|
||||
if err := handlerTempl.Execute(&buffer, tmplData); err != nil {
|
||||
|
|
62
cmd/lock.go
Normal file
62
cmd/lock.go
Normal file
|
@ -0,0 +1,62 @@
|
|||
/*
|
||||
Package cmd
|
||||
Copyright © 2024 Shane C. <shane@scaffoe.com>
|
||||
*/
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/jackc/pgx/v5/pgxpool"
|
||||
"github.com/jackc/pgx/v5/stdlib"
|
||||
"github.com/uptrace/bun"
|
||||
"github.com/uptrace/bun/dialect/pgdialect"
|
||||
"github.com/uptrace/bun/migrate"
|
||||
"log"
|
||||
"omnibill.net/omnibill/migrations"
|
||||
"omnibill.net/omnibill/shared"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
// lockCmd represents the lock command
|
||||
var lockCmd = &cobra.Command{
|
||||
Use: "lock",
|
||||
Short: "Locks DB migrations",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
dsn := shared.GetPostgresURI()
|
||||
|
||||
config, err := pgxpool.ParseConfig(dsn)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
pool, err := pgxpool.NewWithConfig(context.Background(), config)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
sqldb := stdlib.OpenDBFromPool(pool)
|
||||
db := bun.NewDB(sqldb, pgdialect.New())
|
||||
|
||||
migrator := migrate.NewMigrator(db, migrations.Migrations)
|
||||
ctx := context.Background()
|
||||
|
||||
err = migrator.Lock(ctx)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
migrateCmd.AddCommand(lockCmd)
|
||||
|
||||
// Here you will define your flags and configuration settings.
|
||||
|
||||
// Cobra supports Persistent Flags which will work for this command
|
||||
// and all subcommands, e.g.:
|
||||
// lockCmd.PersistentFlags().String("foo", "", "A help for foo")
|
||||
|
||||
// Cobra supports local flags which will only run when this command
|
||||
// is called directly, e.g.:
|
||||
// lockCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
|
||||
}
|
66
cmd/migrate.go
Normal file
66
cmd/migrate.go
Normal file
|
@ -0,0 +1,66 @@
|
|||
/*
|
||||
Package cmd
|
||||
Copyright © 2024 Shane C. <shane@scaffoe.com>
|
||||
*/
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"github.com/jackc/pgx/v5/pgxpool"
|
||||
"github.com/jackc/pgx/v5/stdlib"
|
||||
"github.com/spf13/cobra"
|
||||
"github.com/uptrace/bun"
|
||||
"github.com/uptrace/bun/dialect/pgdialect"
|
||||
"github.com/uptrace/bun/migrate"
|
||||
"log"
|
||||
"omnibill.net/omnibill/migrations"
|
||||
"omnibill.net/omnibill/shared"
|
||||
)
|
||||
|
||||
// migrateCmd represents the migrate command
|
||||
var migrateCmd = &cobra.Command{
|
||||
Use: "migrate",
|
||||
Short: "Migrate the db to the most recent version available",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
dsn := shared.GetPostgresURI()
|
||||
|
||||
config, err := pgxpool.ParseConfig(dsn)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
pool, err := pgxpool.NewWithConfig(context.Background(), config)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
sqldb := stdlib.OpenDBFromPool(pool)
|
||||
db := bun.NewDB(sqldb, pgdialect.New())
|
||||
|
||||
migrator := migrate.NewMigrator(db, migrations.Migrations)
|
||||
ctx := context.Background()
|
||||
if err := migrator.Init(ctx); err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
if err := migrator.Lock(ctx); err != nil {
|
||||
log.Fatalln(err)
|
||||
|
||||
}
|
||||
defer migrator.Unlock(ctx)
|
||||
|
||||
group, err := migrator.Migrate(ctx)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
if group.IsZero() {
|
||||
fmt.Printf("there are no new migrations to run (database is up to date)\n")
|
||||
return
|
||||
}
|
||||
fmt.Printf("migrated to %s\n", group)
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
rootCmd.AddCommand(migrateCmd)
|
||||
}
|
67
cmd/rollback.go
Normal file
67
cmd/rollback.go
Normal file
|
@ -0,0 +1,67 @@
|
|||
/*
|
||||
Package cmd
|
||||
Copyright © 2024 Shane C. <shane@scaffoe.com>
|
||||
*/
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"github.com/jackc/pgx/v5/pgxpool"
|
||||
"github.com/jackc/pgx/v5/stdlib"
|
||||
"github.com/uptrace/bun"
|
||||
"github.com/uptrace/bun/dialect/pgdialect"
|
||||
"github.com/uptrace/bun/migrate"
|
||||
"log"
|
||||
"omnibill.net/omnibill/migrations"
|
||||
"omnibill.net/omnibill/shared"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
// rollbackCmd represents the rollback command
|
||||
var rollbackCmd = &cobra.Command{
|
||||
Use: "rollback",
|
||||
Short: "Rollback db migrations",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
dsn := shared.GetPostgresURI()
|
||||
|
||||
config, err := pgxpool.ParseConfig(dsn)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
pool, err := pgxpool.NewWithConfig(context.Background(), config)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
sqldb := stdlib.OpenDBFromPool(pool)
|
||||
db := bun.NewDB(sqldb, pgdialect.New())
|
||||
|
||||
migrator := migrate.NewMigrator(db, migrations.Migrations)
|
||||
ctx := context.Background()
|
||||
if err := migrator.Init(ctx); err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
if err := migrator.Lock(ctx); err != nil {
|
||||
log.Fatalln(err)
|
||||
|
||||
}
|
||||
defer migrator.Unlock(ctx)
|
||||
|
||||
group, err := migrator.Rollback(ctx)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
if group.IsZero() {
|
||||
fmt.Printf("there is nothing to rollback\n")
|
||||
return
|
||||
}
|
||||
fmt.Printf("rolled back to %s\n", group)
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
migrateCmd.AddCommand(rollbackCmd)
|
||||
}
|
16
cmd/root_dev.go
Normal file
16
cmd/root_dev.go
Normal file
|
@ -0,0 +1,16 @@
|
|||
//go:build dev
|
||||
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"github.com/spf13/viper"
|
||||
"os"
|
||||
)
|
||||
|
||||
func init() {
|
||||
path, err := os.Getwd()
|
||||
if err != nil {
|
||||
panic(err)
|
||||
}
|
||||
viper.AddConfigPath(path)
|
||||
}
|
|
@ -1,3 +1,10 @@
|
|||
/*
|
||||
Handler Information:
|
||||
Route: /{{.Path}}
|
||||
Has View:{{ if .GetView }} yes {{ else }} no {{ end }}
|
||||
Needs Auth:{{ if .RequireAuth }} yes {{ else }} no {{ end }}
|
||||
*/
|
||||
|
||||
package {{.PackagePath}}
|
||||
|
||||
import (
|
||||
|
|
52
cmd/unlock.go
Normal file
52
cmd/unlock.go
Normal file
|
@ -0,0 +1,52 @@
|
|||
/*
|
||||
Package cmd
|
||||
Copyright © 2024 Shane C. <shane@scaffoe.com>
|
||||
*/
|
||||
package cmd
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/jackc/pgx/v5/pgxpool"
|
||||
"github.com/jackc/pgx/v5/stdlib"
|
||||
"github.com/uptrace/bun"
|
||||
"github.com/uptrace/bun/dialect/pgdialect"
|
||||
"github.com/uptrace/bun/migrate"
|
||||
"log"
|
||||
"omnibill.net/omnibill/migrations"
|
||||
"omnibill.net/omnibill/shared"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
// unlockCmd represents the unlock command
|
||||
var unlockCmd = &cobra.Command{
|
||||
Use: "unlock",
|
||||
Short: "Unlocks DB migrations",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
dsn := shared.GetPostgresURI()
|
||||
|
||||
config, err := pgxpool.ParseConfig(dsn)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
pool, err := pgxpool.NewWithConfig(context.Background(), config)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
|
||||
sqldb := stdlib.OpenDBFromPool(pool)
|
||||
db := bun.NewDB(sqldb, pgdialect.New())
|
||||
|
||||
migrator := migrate.NewMigrator(db, migrations.Migrations)
|
||||
ctx := context.Background()
|
||||
|
||||
err = migrator.Unlock(ctx)
|
||||
if err != nil {
|
||||
log.Fatalln(err)
|
||||
}
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
migrateCmd.AddCommand(unlockCmd)
|
||||
}
|
|
@ -9,6 +9,10 @@ use_https = false
|
|||
proxy = ""
|
||||
port = 9000
|
||||
|
||||
# Queue Settings
|
||||
[omnibill.queues]
|
||||
enable_ui = false
|
||||
|
||||
# Database Settings
|
||||
[omnibill.database]
|
||||
host = "127.0.0.1"
|
||||
|
|
Loading…
Reference in a new issue