2022-04-28 14:46:46 +00:00
|
|
|
package accounts
|
|
|
|
|
|
|
|
import (
|
2022-11-11 17:33:48 +00:00
|
|
|
"time"
|
|
|
|
|
2023-03-17 18:52:56 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v4/crypto/bls"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/validator/accounts/wallet"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/validator/keymanager"
|
2022-04-28 14:46:46 +00:00
|
|
|
"google.golang.org/grpc"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Option type for configuring the accounts cli manager.
|
|
|
|
type Option func(acc *AccountsCLIManager) error
|
|
|
|
|
|
|
|
// WithWallet provides a wallet to the accounts cli manager.
|
|
|
|
func WithWallet(wallet *wallet.Wallet) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.wallet = wallet
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithKeymanager provides a keymanager to the accounts cli manager.
|
|
|
|
func WithKeymanager(km keymanager.IKeymanager) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.keymanager = km
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-02 14:56:47 +00:00
|
|
|
// WithKeymanagerType provides a keymanager to the accounts cli manager.
|
|
|
|
func WithKeymanagerType(k keymanager.Kind) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.keymanagerKind = k
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-28 14:46:46 +00:00
|
|
|
// WithShowDepositData enables displaying deposit data in the accounts cli manager.
|
|
|
|
func WithShowDepositData() Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.showDepositData = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithShowPrivateKeys enables displaying private keys in the accounts cli manager.
|
|
|
|
func WithShowPrivateKeys() Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.showPrivateKeys = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithListValidatorIndices enables displaying validator indices in the accounts cli manager.
|
|
|
|
func WithListValidatorIndices() Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.listValidatorIndices = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithGRPCDialOpts adds grpc opts needed to connect to beacon nodes in the accounts cli manager.
|
|
|
|
func WithGRPCDialOpts(opts []grpc.DialOption) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.dialOpts = opts
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithGRPCHeaders adds grpc headers used when connecting to beacon nodes in the accounts cli manager.
|
|
|
|
func WithGRPCHeaders(headers []string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.grpcHeaders = headers
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithBeaconRPCProvider provides a beacon node endpoint to the accounts cli manager.
|
|
|
|
func WithBeaconRPCProvider(provider string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.beaconRPCProvider = provider
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
2022-05-17 23:13:36 +00:00
|
|
|
|
2022-11-11 17:33:48 +00:00
|
|
|
// WithBeaconRESTApiProvider provides a beacon node REST API endpoint to the accounts cli manager.
|
|
|
|
func WithBeaconRESTApiProvider(beaconApiEndpoint string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.beaconApiEndpoint = beaconApiEndpoint
|
|
|
|
acc.beaconApiTimeout = time.Second * 30
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-17 23:13:36 +00:00
|
|
|
// WithWalletKeyCount tracks the number of keys in a wallet.
|
|
|
|
func WithWalletKeyCount(walletKeyCount int) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.walletKeyCount = walletKeyCount
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-07 15:19:12 +00:00
|
|
|
// WithDeletePublicKeys indicates whether to delete the public keys.
|
2022-05-17 23:13:36 +00:00
|
|
|
func WithDeletePublicKeys(deletePublicKeys bool) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.deletePublicKeys = deletePublicKeys
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
2022-06-07 15:19:12 +00:00
|
|
|
|
2022-06-16 14:14:03 +00:00
|
|
|
// WithReadPasswordFile indicates whether to read the password from a file.
|
|
|
|
func WithReadPasswordFile(readPasswordFile bool) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.readPasswordFile = readPasswordFile
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithImportPrivateKeys indicates whether to import private keys as accounts.
|
|
|
|
func WithImportPrivateKeys(importPrivateKeys bool) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.importPrivateKeys = importPrivateKeys
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-02 14:56:47 +00:00
|
|
|
// WithSkipMnemonicConfirm indicates whether to skip the mnemonic confirmation.
|
|
|
|
func WithSkipMnemonicConfirm(s bool) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.skipMnemonicConfirm = s
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-26 21:04:00 +00:00
|
|
|
// WithMnemonicLanguage specifies the language used for the mnemonic passphrase.
|
|
|
|
func WithMnemonicLanguage(mnemonicLanguage string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.mnemonicLanguage = mnemonicLanguage
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-16 14:14:03 +00:00
|
|
|
// WithPrivateKeyFile specifies the private key path.
|
|
|
|
func WithPrivateKeyFile(privateKeyFile string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.privateKeyFile = privateKeyFile
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithKeysDir specifies the directory keys are read from.
|
|
|
|
func WithKeysDir(keysDir string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.keysDir = keysDir
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithPasswordFilePath specifies where the password is stored.
|
|
|
|
func WithPasswordFilePath(passwordFilePath string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.passwordFilePath = passwordFilePath
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-27 13:34:38 +00:00
|
|
|
// WithBackupsDir specifies the directory backups are written to.
|
2022-06-07 15:19:12 +00:00
|
|
|
func WithBackupsDir(backupsDir string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.backupsDir = backupsDir
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-27 13:34:38 +00:00
|
|
|
// WithBackupsPassword specifies the password for backups.
|
2022-06-07 15:19:12 +00:00
|
|
|
func WithBackupsPassword(backupsPassword string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.backupsPassword = backupsPassword
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
2022-06-13 15:17:46 +00:00
|
|
|
|
|
|
|
// WithFilteredPubKeys adds public key strings parsed from CLI.
|
|
|
|
func WithFilteredPubKeys(filteredPubKeys []bls.PublicKey) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.filteredPubKeys = filteredPubKeys
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithRawPubKeys adds raw public key bytes parsed from CLI.
|
|
|
|
func WithRawPubKeys(rawPubKeys [][]byte) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.rawPubKeys = rawPubKeys
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithFormattedPubKeys adds formatted public key strings parsed from CLI.
|
|
|
|
func WithFormattedPubKeys(formattedPubKeys []string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.formattedPubKeys = formattedPubKeys
|
|
|
|
return nil
|
|
|
|
}
|
2023-04-17 18:01:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func WithExitJSONOutputPath(outputPath string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.exitJSONOutputPath = outputPath
|
|
|
|
return nil
|
|
|
|
}
|
2022-06-13 15:17:46 +00:00
|
|
|
}
|
2022-08-24 16:57:03 +00:00
|
|
|
|
|
|
|
// WithWalletDir specifies the password for backups.
|
|
|
|
func WithWalletDir(walletDir string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.walletDir = walletDir
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithWalletPassword specifies the password for backups.
|
|
|
|
func WithWalletPassword(walletPassword string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.walletPassword = walletPassword
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithMnemonic specifies the password for backups.
|
|
|
|
func WithMnemonic(mnemonic string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.mnemonic = mnemonic
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithMnemonic25thWord specifies the password for backups.
|
|
|
|
func WithMnemonic25thWord(mnemonic25thWord string) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.mnemonic25thWord = mnemonic25thWord
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-17 16:20:26 +00:00
|
|
|
// WithNumAccounts specifies the number of accounts.
|
2022-08-24 16:57:03 +00:00
|
|
|
func WithNumAccounts(numAccounts int) Option {
|
|
|
|
return func(acc *AccountsCLIManager) error {
|
|
|
|
acc.numAccounts = numAccounts
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|