mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 18:51:19 +00:00
6672d1499a
* wip proposer settings * WIP validator client APIs * adding proposer settings output * adding unit tests * fixing linting * fixing deepsource issues * fixing e2e * fixing deep source issue * updating naming to not stutter * updating bazel * fixing linting error * reverting comment * adding builder settings * gaz * Update validator/client/validator.go Co-authored-by: Sammy Rosso <15244892+saolyn@users.noreply.github.com> * adding comments * adding some tests * gaz * Update cmd/prysmctl/validator/proposer_settings.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/prysmctl/validator/proposer_settings.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/prysmctl/validator/proposer_settings.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/prysmctl/validator/proposer_settings.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/options.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/options.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/errors.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/options.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/options.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/validator/client.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/prysmctl/validator/cmd.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/validator/client.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/validator/client.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update cmd/prysmctl/validator/proposer_settings.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update api/client/errors.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * fixing feedback * fixing unit test * addressign comments --------- Co-authored-by: Sammy Rosso <15244892+saolyn@users.noreply.github.com> Co-authored-by: Radosław Kapka <rkapka@wp.pl>
113 lines
3.6 KiB
Go
113 lines
3.6 KiB
Go
package validator
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"io"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"github.com/prysmaticlabs/prysm/v4/api/client"
|
|
"github.com/prysmaticlabs/prysm/v4/api/client/validator"
|
|
"github.com/prysmaticlabs/prysm/v4/cmd/validator/flags"
|
|
"github.com/prysmaticlabs/prysm/v4/config/params"
|
|
validatorType "github.com/prysmaticlabs/prysm/v4/consensus-types/validator"
|
|
"github.com/prysmaticlabs/prysm/v4/encoding/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/v4/io/file"
|
|
"github.com/prysmaticlabs/prysm/v4/io/prompt"
|
|
validatorpb "github.com/prysmaticlabs/prysm/v4/proto/prysm/v1alpha1/validator-client"
|
|
log "github.com/sirupsen/logrus"
|
|
"github.com/urfave/cli/v2"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
func getProposerSettings(c *cli.Context, r io.Reader) error {
|
|
ctx, span := trace.StartSpan(c.Context, "prysmctl.getProposerSettings")
|
|
defer span.End()
|
|
if !c.IsSet(ValidatorHostFlag.Name) {
|
|
return errNoFlag(ValidatorHostFlag.Name)
|
|
}
|
|
if !c.IsSet(TokenFlag.Name) {
|
|
return errNoFlag(TokenFlag.Name)
|
|
}
|
|
defaultFeeRecipient := params.BeaconConfig().DefaultFeeRecipient.Hex()
|
|
if c.IsSet(ProposerSettingsOutputFlag.Name) {
|
|
if c.IsSet(DefaultFeeRecipientFlag.Name) {
|
|
recipient := c.String(DefaultFeeRecipientFlag.Name)
|
|
if err := validateIsExecutionAddress(recipient); err != nil {
|
|
return err
|
|
}
|
|
defaultFeeRecipient = recipient
|
|
} else {
|
|
promptText := "Please enter a default fee recipient address (an ethereum address in hex format)"
|
|
resp, err := prompt.ValidatePrompt(r, promptText, validateIsExecutionAddress)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defaultFeeRecipient = resp
|
|
}
|
|
}
|
|
|
|
cl, err := validator.NewClient(c.String(ValidatorHostFlag.Name), client.WithAuthenticationToken(c.String(TokenFlag.Name)))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
validators, err := cl.GetValidatorPubKeys(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
feeRecipients, err := cl.GetFeeRecipientAddresses(ctx, validators)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
log.Infoln("===============DISPLAYING CURRENT PROPOSER SETTINGS===============")
|
|
|
|
for index := range validators {
|
|
log.Infof("Validator: %s. Fee-recipient: %s", validators[index], feeRecipients[index])
|
|
}
|
|
|
|
if c.IsSet(ProposerSettingsOutputFlag.Name) {
|
|
log.Infof("The default fee recipient is set to %s", defaultFeeRecipient)
|
|
var builderSettings *validatorpb.BuilderConfig
|
|
if c.Bool(WithBuilderFlag.Name) {
|
|
builderSettings = &validatorpb.BuilderConfig{
|
|
Enabled: true,
|
|
GasLimit: validatorType.Uint64(params.BeaconConfig().DefaultBuilderGasLimit),
|
|
}
|
|
} else {
|
|
log.Infof("Default builder settings can be included with the `--%s` flag", WithBuilderFlag.Name)
|
|
}
|
|
proposerConfig := make(map[string]*validatorpb.ProposerOptionPayload)
|
|
for index, val := range validators {
|
|
proposerConfig[val] = &validatorpb.ProposerOptionPayload{
|
|
FeeRecipient: feeRecipients[index],
|
|
Builder: builderSettings,
|
|
}
|
|
}
|
|
fileConfig := &validatorpb.ProposerSettingsPayload{
|
|
ProposerConfig: proposerConfig,
|
|
DefaultConfig: &validatorpb.ProposerOptionPayload{
|
|
FeeRecipient: defaultFeeRecipient,
|
|
Builder: builderSettings,
|
|
},
|
|
}
|
|
b, err := json.Marshal(fileConfig)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := file.WriteFile(c.String(ProposerSettingsOutputFlag.Name), b); err != nil {
|
|
return err
|
|
}
|
|
log.Infof("Successfully created `%s`. Settings can be imported into validator client using --%s flag.", c.String(ProposerSettingsOutputFlag.Name), flags.ProposerSettingsFlag.Name)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func validateIsExecutionAddress(input string) error {
|
|
if !bytesutil.IsHex([]byte(input)) || !(len(input) == common.AddressLength*2+2) {
|
|
return errors.New("no default address entered")
|
|
}
|
|
return nil
|
|
}
|