mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-10 03:31:20 +00:00
ead9a83d8d
* WIP * Refactor to use iface.ValidatorClient instead of ethpb.BeaconNodeValidatorClient * Add mocks for iface.ValidatorClient * Fix mocks * Update update-mockgen.sh * Fix warnings * Fix config_setting syntax * Use custom build settings * WIP * WIP * WIP * WIP * WIP * WIP * Fix endpoint address and reduce timeout * Revert most e2e changes * Use e2e.TestParams.Ports.PrysmBeaconNodeGatewayPort * Fix BeaconRESTApiProviderFlag port * Revert e2e changes
84 lines
2.6 KiB
Go
84 lines
2.6 KiB
Go
package accounts
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/v3/cmd"
|
|
"github.com/prysmaticlabs/prysm/v3/cmd/validator/flags"
|
|
"github.com/prysmaticlabs/prysm/v3/io/prompt"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/accounts"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/accounts/userprompt"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/client"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
const backupPromptText = "Enter the directory where your backup.zip file will be written to"
|
|
|
|
func accountsBackup(c *cli.Context) error {
|
|
w, km, err := walletWithKeymanager(c)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
dialOpts := client.ConstructDialOptions(
|
|
c.Int(cmd.GrpcMaxCallRecvMsgSizeFlag.Name),
|
|
c.String(flags.CertFlag.Name),
|
|
c.Uint(flags.GrpcRetriesFlag.Name),
|
|
c.Duration(flags.GrpcRetryDelayFlag.Name),
|
|
)
|
|
grpcHeaders := strings.Split(c.String(flags.GrpcHeadersFlag.Name), ",")
|
|
|
|
opts := []accounts.Option{
|
|
accounts.WithWallet(w),
|
|
accounts.WithKeymanager(km),
|
|
accounts.WithGRPCDialOpts(dialOpts),
|
|
accounts.WithBeaconRPCProvider(c.String(flags.BeaconRPCProviderFlag.Name)),
|
|
accounts.WithBeaconRESTApiProvider(c.String(flags.BeaconRESTApiProviderFlag.Name)),
|
|
accounts.WithGRPCHeaders(grpcHeaders),
|
|
}
|
|
|
|
// Get full set of public keys from the keymanager.
|
|
publicKeys, err := km.FetchValidatingPublicKeys(c.Context)
|
|
if err != nil {
|
|
return errors.Wrap(err, "could not fetch validating public keys")
|
|
}
|
|
// Filter keys either from CLI flag or from interactive session.
|
|
filteredPubKeys, err := accounts.FilterPublicKeysFromUserInput(
|
|
c,
|
|
flags.BackupPublicKeysFlag,
|
|
publicKeys,
|
|
userprompt.SelectAccountsBackupPromptText,
|
|
)
|
|
if err != nil {
|
|
return errors.Wrap(err, "could not filter public keys for backup")
|
|
}
|
|
opts = append(opts, accounts.WithFilteredPubKeys(filteredPubKeys))
|
|
|
|
// Input the directory where they wish to backup their accounts.
|
|
backupsDir, err := userprompt.InputDirectory(c, backupPromptText, flags.BackupDirFlag)
|
|
if err != nil {
|
|
return errors.Wrap(err, "could not parse keys directory")
|
|
}
|
|
// Ask the user for their desired password for their backed up accounts.
|
|
backupsPassword, err := prompt.InputPassword(
|
|
c,
|
|
flags.BackupPasswordFile,
|
|
"Enter a new password for your backed up accounts",
|
|
"Confirm new password",
|
|
true,
|
|
prompt.ValidatePasswordInput,
|
|
)
|
|
if err != nil {
|
|
return errors.Wrap(err, "could not determine password for backed up accounts")
|
|
}
|
|
|
|
opts = append(opts, accounts.WithBackupsDir(backupsDir))
|
|
opts = append(opts, accounts.WithBackupsPassword(backupsPassword))
|
|
|
|
acc, err := accounts.NewCLIManager(opts...)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return acc.Backup(c.Context)
|
|
}
|