mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-14 22:18:20 +00:00
d17996f8b0
* Update V3 from V4 * Fix build v3 -> v4 * Update ssz * Update beacon_chain.pb.go * Fix formatter import * Update update-mockgen.sh comment to v4 * Fix conflicts. Pass build and tests * Fix test
103 lines
3.6 KiB
Go
103 lines
3.6 KiB
Go
package client
|
|
|
|
import (
|
|
"context"
|
|
"strings"
|
|
|
|
"github.com/ethereum/go-ethereum/common/hexutil"
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/builder"
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/core/signing"
|
|
"github.com/prysmaticlabs/prysm/v4/config/params"
|
|
"github.com/prysmaticlabs/prysm/v4/encoding/bytesutil"
|
|
ethpb "github.com/prysmaticlabs/prysm/v4/proto/prysm/v1alpha1"
|
|
validatorpb "github.com/prysmaticlabs/prysm/v4/proto/prysm/v1alpha1/validator-client"
|
|
"github.com/prysmaticlabs/prysm/v4/validator/client/iface"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
// SubmitValidatorRegistrations signs validator registration objects and submits it to the beacon node.
|
|
func SubmitValidatorRegistrations(
|
|
ctx context.Context,
|
|
validatorClient iface.ValidatorClient,
|
|
signedRegs []*ethpb.SignedValidatorRegistrationV1,
|
|
) error {
|
|
ctx, span := trace.StartSpan(ctx, "validator.SubmitValidatorRegistrations")
|
|
defer span.End()
|
|
|
|
if len(signedRegs) == 0 {
|
|
return nil
|
|
}
|
|
|
|
if _, err := validatorClient.SubmitValidatorRegistrations(ctx, ðpb.SignedValidatorRegistrationsV1{
|
|
Messages: signedRegs,
|
|
}); err != nil {
|
|
if strings.Contains(err.Error(), builder.ErrNoBuilder.Error()) {
|
|
log.Warnln("Beacon node does not utilize a custom builder via the --http-mev-relay flag. Validator registration skipped.")
|
|
return nil
|
|
}
|
|
return errors.Wrap(err, "could not submit signed registrations to beacon node")
|
|
}
|
|
log.Infoln("Submitted builder validator registration settings for custom builders")
|
|
return nil
|
|
}
|
|
|
|
// Sings validator registration obj with the proposer domain and private key.
|
|
func signValidatorRegistration(ctx context.Context, signer iface.SigningFunc, reg *ethpb.ValidatorRegistrationV1) ([]byte, error) {
|
|
// Per spec, we want the fork version and genesis validator to be nil.
|
|
// Which is genesis value and zero by default.
|
|
d, err := signing.ComputeDomain(
|
|
params.BeaconConfig().DomainApplicationBuilder,
|
|
nil, /* fork version */
|
|
nil /* genesis val root */)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
r, err := signing.ComputeSigningRoot(reg, d)
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, signingRootErr)
|
|
}
|
|
|
|
sig, err := signer(ctx, &validatorpb.SignRequest{
|
|
PublicKey: reg.Pubkey,
|
|
SigningRoot: r[:],
|
|
SignatureDomain: d,
|
|
Object: &validatorpb.SignRequest_Registration{Registration: reg},
|
|
})
|
|
if err != nil {
|
|
return nil, errors.Wrap(err, "could not sign validator registration")
|
|
}
|
|
return sig.Marshal(), nil
|
|
}
|
|
|
|
// SignValidatorRegistrationRequest compares and returns either the cached validator registration request or signs a new one.
|
|
func (v *validator) SignValidatorRegistrationRequest(ctx context.Context, signer iface.SigningFunc, newValidatorRegistration *ethpb.ValidatorRegistrationV1) (*ethpb.SignedValidatorRegistrationV1, error) {
|
|
signedReg, ok := v.signedValidatorRegistrations[bytesutil.ToBytes48(newValidatorRegistration.Pubkey)]
|
|
if ok && isValidatorRegistrationSame(signedReg.Message, newValidatorRegistration) {
|
|
return signedReg, nil
|
|
} else {
|
|
sig, err := signValidatorRegistration(ctx, signer, newValidatorRegistration)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
newRequest := ðpb.SignedValidatorRegistrationV1{
|
|
Message: newValidatorRegistration,
|
|
Signature: sig,
|
|
}
|
|
v.signedValidatorRegistrations[bytesutil.ToBytes48(newValidatorRegistration.Pubkey)] = newRequest
|
|
return newRequest, nil
|
|
}
|
|
}
|
|
|
|
func isValidatorRegistrationSame(cachedVR *ethpb.ValidatorRegistrationV1, newVR *ethpb.ValidatorRegistrationV1) bool {
|
|
isSame := true
|
|
if cachedVR.GasLimit != newVR.GasLimit {
|
|
isSame = false
|
|
}
|
|
if hexutil.Encode(cachedVR.FeeRecipient) != hexutil.Encode(newVR.FeeRecipient) {
|
|
isSame = false
|
|
}
|
|
return isSame
|
|
}
|