prysm-pulse/validator/db/migrate.go
terencechain 9387a36b66
Refactor Exported Names to Follow Golang Best Practices (#13075)
* Fix exported names that start with a package name

* A few more renames

* Fix exported names that start with a package name

* A few more renames

* Radek's feedback

* Fix conflict

* fix keymanager test

* Fix comments

---------

Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
2023-10-20 16:45:33 +00:00

49 lines
1.2 KiB
Go

package db
import (
"context"
"path"
"github.com/pkg/errors"
"github.com/prysmaticlabs/prysm/v4/cmd"
"github.com/prysmaticlabs/prysm/v4/io/file"
"github.com/prysmaticlabs/prysm/v4/validator/db/kv"
"github.com/urfave/cli/v2"
)
// MigrateUp for a validator database.
func MigrateUp(cliCtx *cli.Context) error {
dataDir := cliCtx.String(cmd.DataDirFlag.Name)
if !file.Exists(path.Join(dataDir, kv.ProtectionDbFileName)) {
return errors.New("No validator db found at path, nothing to migrate")
}
ctx := context.Background()
log.Info("Opening DB")
validatorDB, err := kv.NewKVStore(ctx, dataDir, &kv.Config{})
if err != nil {
return err
}
log.Info("Running migrations")
return validatorDB.RunUpMigrations(ctx)
}
// MigrateDown for a validator database.
func MigrateDown(cliCtx *cli.Context) error {
dataDir := cliCtx.String(cmd.DataDirFlag.Name)
if !file.Exists(path.Join(dataDir, kv.ProtectionDbFileName)) {
return errors.New("No validator db found at path, nothing to rollback")
}
ctx := context.Background()
log.Info("Opening DB")
validatorDB, err := kv.NewKVStore(ctx, dataDir, &kv.Config{})
if err != nil {
return err
}
log.Info("Running migrations")
return validatorDB.RunDownMigrations(ctx)
}