mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-16 23:08:45 +00:00
60558b7970
* keymanagers no longer use cli ctx * rename important values to keymanageropts * further refactor accounts methods to reduce cli dependency * separating cli vs non cli methods for various accounts functions * recover wallet cli vs non-cli mode * ensure half of tests build * accounts v2 package now builds * full revamp wallet creation or opening wallets * everything builds * tests pass finally * Merge branch 'master' into no-cli-keymanagers * ensure commands work as expected * Merge branch 'no-cli-keymanagers' of github.com:prysmaticlabs/prysm into no-cli-keymanagers * further fix build * account creation comments * fix imports and comments * fix up failing test * fix build * Update derived.go * Update direct.go * Update remote.go * Fixed variable * fix up red tests * use Cli instead of CLI, fix tests, and address Radek's feedback * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers * Merge refs/heads/master into no-cli-keymanagers
169 lines
5.0 KiB
Go
169 lines
5.0 KiB
Go
package v2
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"strings"
|
|
|
|
"github.com/logrusorgru/aurora"
|
|
"github.com/manifoldco/promptui"
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/shared/fileutil"
|
|
"github.com/prysmaticlabs/prysm/shared/promptutil"
|
|
"github.com/prysmaticlabs/prysm/validator/flags"
|
|
"github.com/prysmaticlabs/prysm/validator/keymanager/v2/remote"
|
|
"github.com/urfave/cli/v2"
|
|
)
|
|
|
|
const (
|
|
importKeysDirPromptText = "Enter the directory or filepath where your keystores to import are located"
|
|
walletDirPromptText = "Enter a wallet directory"
|
|
selectAccountsDeletePromptText = "Select the account(s) you would like to delete"
|
|
selectAccountsBackupPromptText = "Select the account(s) you wish to backup"
|
|
selectAccountsDepositPromptText = "Select the validating public keys you wish to submit deposits for"
|
|
selectAccountsVoluntaryExitPromptText = "Select the account(s) on which you wish to perform a voluntary exit"
|
|
)
|
|
|
|
var au = aurora.NewAurora(true)
|
|
|
|
func inputDirectory(cliCtx *cli.Context, promptText string, flag *cli.StringFlag) (string, error) {
|
|
directory := cliCtx.String(flag.Name)
|
|
if cliCtx.IsSet(flag.Name) {
|
|
return fileutil.ExpandPath(directory)
|
|
}
|
|
// Append and log the appropriate directory name depending on the flag used.
|
|
if flag.Name == flags.WalletDirFlag.Name {
|
|
ok, err := fileutil.HasDir(directory)
|
|
if err != nil {
|
|
return "", errors.Wrapf(err, "could not check if wallet dir %s exists", directory)
|
|
}
|
|
if ok {
|
|
log.Infof("%s %s", au.BrightMagenta("(wallet path)"), directory)
|
|
return directory, nil
|
|
}
|
|
}
|
|
|
|
inputtedDir, err := promptutil.DefaultPrompt(au.Bold(promptText).String(), directory)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
if inputtedDir == directory {
|
|
return directory, nil
|
|
}
|
|
return fileutil.ExpandPath(inputtedDir)
|
|
}
|
|
|
|
func inputWeakPassword(cliCtx *cli.Context, passwordFileFlag *cli.StringFlag, promptText string) (string, error) {
|
|
if cliCtx.IsSet(passwordFileFlag.Name) {
|
|
passwordFilePathInput := cliCtx.String(passwordFileFlag.Name)
|
|
passwordFilePath, err := fileutil.ExpandPath(passwordFilePathInput)
|
|
if err != nil {
|
|
return "", errors.Wrap(err, "could not determine absolute path of password file")
|
|
}
|
|
data, err := ioutil.ReadFile(passwordFilePath)
|
|
if err != nil {
|
|
return "", errors.Wrap(err, "could not read password file")
|
|
}
|
|
return strings.TrimRight(string(data), "\r\n"), nil
|
|
}
|
|
walletPassword, err := promptutil.PasswordPrompt(promptText, promptutil.NotEmpty)
|
|
if err != nil {
|
|
return "", fmt.Errorf("could not read account password: %v", err)
|
|
}
|
|
return walletPassword, nil
|
|
}
|
|
|
|
func inputRemoteKeymanagerConfig(cliCtx *cli.Context) (*remote.KeymanagerOpts, error) {
|
|
addr := cliCtx.String(flags.GrpcRemoteAddressFlag.Name)
|
|
crt := cliCtx.String(flags.RemoteSignerCertPathFlag.Name)
|
|
key := cliCtx.String(flags.RemoteSignerKeyPathFlag.Name)
|
|
ca := cliCtx.String(flags.RemoteSignerCACertPathFlag.Name)
|
|
log.Info("Input desired configuration")
|
|
var err error
|
|
if addr == "" {
|
|
addr, err = promptutil.ValidatePrompt(
|
|
os.Stdin,
|
|
"Remote gRPC address (such as host.example.com:4000)",
|
|
promptutil.NotEmpty)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
if crt == "" {
|
|
crt, err = promptutil.ValidatePrompt(
|
|
os.Stdin,
|
|
"Path to TLS crt (such as /path/to/client.crt)",
|
|
validateCertPath)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
if key == "" {
|
|
key, err = promptutil.ValidatePrompt(
|
|
os.Stdin,
|
|
"Path to TLS key (such as /path/to/client.key)",
|
|
validateCertPath)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
if ca == "" {
|
|
ca, err = promptutil.ValidatePrompt(
|
|
os.Stdin,
|
|
"Path to certificate authority (CA) crt (such as /path/to/ca.crt)",
|
|
validateCertPath)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
crtPath, err := fileutil.ExpandPath(strings.TrimRight(crt, "\r\n"))
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "could not determine absolute path for %s", crt)
|
|
}
|
|
keyPath, err := fileutil.ExpandPath(strings.TrimRight(key, "\r\n"))
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "could not determine absolute path for %s", crt)
|
|
}
|
|
caPath, err := fileutil.ExpandPath(strings.TrimRight(ca, "\r\n"))
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "could not determine absolute path for %s", crt)
|
|
}
|
|
newCfg := &remote.KeymanagerOpts{
|
|
RemoteCertificate: &remote.CertificateConfig{
|
|
ClientCertPath: crtPath,
|
|
ClientKeyPath: keyPath,
|
|
CACertPath: caPath,
|
|
},
|
|
RemoteAddr: addr,
|
|
}
|
|
fmt.Printf("%s\n", newCfg)
|
|
return newCfg, nil
|
|
}
|
|
|
|
func validateCertPath(input string) error {
|
|
if input == "" {
|
|
return errors.New("crt path cannot be empty")
|
|
}
|
|
if !promptutil.IsValidUnicode(input) {
|
|
return errors.New("not valid unicode")
|
|
}
|
|
if !fileutil.FileExists(input) {
|
|
return fmt.Errorf("no crt found at path: %s", input)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func formatPromptError(err error) error {
|
|
switch err {
|
|
case promptui.ErrAbort:
|
|
return errors.New("wallet creation aborted, closing")
|
|
case promptui.ErrInterrupt:
|
|
return errors.New("keyboard interrupt, closing")
|
|
case promptui.ErrEOF:
|
|
return errors.New("no input received, closing")
|
|
default:
|
|
return err
|
|
}
|
|
}
|