mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 14:38:20 +00:00
753e285fb6
* removing all prysm remote signer code * fixing unit tests * resolving more build issues * resolving deepsource complaint * fixing lint * trying to fix bazel library * trying testonly true * removing assert and require from non test settings * fixing bazel and tests * removing more unused files related to remote signer * fixing linting * reverting some changes * reverting a change that broke some code * removing typo * fixing unit test * fixing mnemonic information
89 lines
2.8 KiB
Go
89 lines
2.8 KiB
Go
package accounts
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/pkg/errors"
|
|
grpcutil "github.com/prysmaticlabs/prysm/v3/api/grpc"
|
|
"github.com/prysmaticlabs/prysm/v3/crypto/bls"
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/accounts/wallet"
|
|
iface "github.com/prysmaticlabs/prysm/v3/validator/client/iface"
|
|
validatorClientFactory "github.com/prysmaticlabs/prysm/v3/validator/client/validator-client-factory"
|
|
validatorHelpers "github.com/prysmaticlabs/prysm/v3/validator/helpers"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/keymanager"
|
|
"github.com/prysmaticlabs/prysm/v3/validator/keymanager/derived"
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
// NewCLIManager allows for managing validator accounts via CLI commands.
|
|
func NewCLIManager(opts ...Option) (*AccountsCLIManager, error) {
|
|
acc := &AccountsCLIManager{
|
|
mnemonicLanguage: derived.DefaultMnemonicLanguage,
|
|
}
|
|
for _, opt := range opts {
|
|
if err := opt(acc); err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
return acc, nil
|
|
}
|
|
|
|
// AccountsCLIManager defines a struct capable of performing various validator
|
|
// wallet & account operations via the command line.
|
|
type AccountsCLIManager struct {
|
|
wallet *wallet.Wallet
|
|
keymanager keymanager.IKeymanager
|
|
keymanagerKind keymanager.Kind
|
|
showDepositData bool
|
|
showPrivateKeys bool
|
|
listValidatorIndices bool
|
|
deletePublicKeys bool
|
|
importPrivateKeys bool
|
|
readPasswordFile bool
|
|
skipMnemonicConfirm bool
|
|
dialOpts []grpc.DialOption
|
|
grpcHeaders []string
|
|
beaconRPCProvider string
|
|
walletKeyCount int
|
|
privateKeyFile string
|
|
passwordFilePath string
|
|
keysDir string
|
|
mnemonicLanguage string
|
|
backupsDir string
|
|
backupsPassword string
|
|
filteredPubKeys []bls.PublicKey
|
|
rawPubKeys [][]byte
|
|
formattedPubKeys []string
|
|
walletDir string
|
|
walletPassword string
|
|
mnemonic string
|
|
numAccounts int
|
|
mnemonic25thWord string
|
|
beaconApiEndpoint string
|
|
beaconApiTimeout time.Duration
|
|
}
|
|
|
|
func (acm *AccountsCLIManager) prepareBeaconClients(ctx context.Context) (*iface.ValidatorClient, *ethpb.NodeClient, error) {
|
|
if acm.dialOpts == nil {
|
|
return nil, nil, errors.New("failed to construct dial options for beacon clients")
|
|
}
|
|
|
|
ctx = grpcutil.AppendHeaders(ctx, acm.grpcHeaders)
|
|
grpcConn, err := grpc.DialContext(ctx, acm.beaconRPCProvider, acm.dialOpts...)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrapf(err, "could not dial endpoint %s", acm.beaconRPCProvider)
|
|
}
|
|
|
|
conn := validatorHelpers.NewNodeConnection(
|
|
grpcConn,
|
|
acm.beaconApiEndpoint,
|
|
acm.beaconApiTimeout,
|
|
)
|
|
|
|
validatorClient := validatorClientFactory.NewValidatorClient(conn)
|
|
nodeClient := ethpb.NewNodeClient(grpcConn)
|
|
return &validatorClient, &nodeClient, nil
|
|
}
|