2020-10-15 22:31:52 +00:00
|
|
|
package accounts
|
2020-08-20 19:14:03 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/hex"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
2022-01-06 17:33:08 +00:00
|
|
|
fieldparams "github.com/prysmaticlabs/prysm/config/fieldparams"
|
2021-09-15 22:55:11 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/crypto/bls"
|
2020-08-20 19:14:03 +00:00
|
|
|
"github.com/urfave/cli/v2"
|
|
|
|
)
|
|
|
|
|
2022-05-17 23:13:36 +00:00
|
|
|
// FilterPublicKeysFromUserInput collects the set of public keys from the
|
|
|
|
// command line or an interactive session.
|
|
|
|
func FilterPublicKeysFromUserInput(
|
2020-08-20 19:14:03 +00:00
|
|
|
cliCtx *cli.Context,
|
|
|
|
publicKeysFlag *cli.StringFlag,
|
2022-01-06 17:33:08 +00:00
|
|
|
validatingPublicKeys [][fieldparams.BLSPubkeyLength]byte,
|
2020-08-20 19:14:03 +00:00
|
|
|
selectionPrompt string,
|
|
|
|
) ([]bls.PublicKey, error) {
|
|
|
|
if cliCtx.IsSet(publicKeysFlag.Name) {
|
|
|
|
pubKeyStrings := strings.Split(cliCtx.String(publicKeysFlag.Name), ",")
|
|
|
|
if len(pubKeyStrings) == 0 {
|
|
|
|
return nil, fmt.Errorf(
|
|
|
|
"could not parse %s. It must be a string of comma-separated hex strings",
|
|
|
|
publicKeysFlag.Name,
|
|
|
|
)
|
|
|
|
}
|
2022-05-17 23:13:36 +00:00
|
|
|
return filterPublicKeys(pubKeyStrings)
|
2020-08-20 19:14:03 +00:00
|
|
|
}
|
|
|
|
return selectAccounts(selectionPrompt, validatingPublicKeys)
|
|
|
|
}
|
2022-05-17 23:13:36 +00:00
|
|
|
|
|
|
|
func filterPublicKeys(pubKeyStrings []string) ([]bls.PublicKey, error) {
|
|
|
|
var filteredPubKeys []bls.PublicKey
|
|
|
|
for _, str := range pubKeyStrings {
|
|
|
|
pkString := str
|
|
|
|
if strings.Contains(pkString, "0x") {
|
|
|
|
pkString = pkString[2:]
|
|
|
|
}
|
|
|
|
pubKeyBytes, err := hex.DecodeString(pkString)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Wrapf(err, "could not decode string %s as hex", pkString)
|
|
|
|
}
|
|
|
|
blsPublicKey, err := bls.PublicKeyFromBytes(pubKeyBytes)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Wrapf(err, "%#x is not a valid BLS public key", pubKeyBytes)
|
|
|
|
}
|
|
|
|
filteredPubKeys = append(filteredPubKeys, blsPublicKey)
|
|
|
|
}
|
|
|
|
return filteredPubKeys, nil
|
|
|
|
}
|