From b8eaf3cae20f475da1a1a72e90f19b5d426e21eb Mon Sep 17 00:00:00 2001 From: Jim McDonald Date: Tue, 15 Oct 2024 09:20:54 +0100 Subject: [PATCH] Ensure secondary registrations take place.. --- CHANGELOG.md | 3 +++ main.go | 2 +- .../standard/submitvalidatorregistrations.go | 20 ++++++++++++++----- 3 files changed, 19 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0ede73d..f3b1b34 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,6 @@ +1.9.1: + - ensure that secondary validator registrations take place for all accounts + 1.9.0: - allow Vouch to start with some consensus nodes unavailable - allow Vouch to act as an MEV-boost client for non-Vouch validators diff --git a/main.go b/main.go index 82e76e7..0eb39b6 100644 --- a/main.go +++ b/main.go @@ -110,7 +110,7 @@ import ( ) // ReleaseVersion is the release version for the code. -var ReleaseVersion = "1.9.0" +var ReleaseVersion = "1.9.1" func main() { exitCode := main2() diff --git a/services/blockrelay/standard/submitvalidatorregistrations.go b/services/blockrelay/standard/submitvalidatorregistrations.go index 9bca3be..6e05241 100644 --- a/services/blockrelay/standard/submitvalidatorregistrations.go +++ b/services/blockrelay/standard/submitvalidatorregistrations.go @@ -120,9 +120,15 @@ func (s *Service) submitValidatorRegistrationsForAccounts(ctx context.Context, consensusRegistrations := make([]*consensusapi.VersionedSignedValidatorRegistration, 0, len(accounts)) relayRegistrations := make(map[string][]*builderapi.VersionedSignedValidatorRegistration) for _, account := range accounts { - if err := s.generateValidatorRegistrationsForAccount(ctx, account, controlledValidators, consensusRegistrations, relayRegistrations); err != nil { + accountConsensusRegistrations, err := s.generateValidatorRegistrationsForAccount(ctx, + account, + controlledValidators, + relayRegistrations, + ) + if err != nil { return err } + consensusRegistrations = append(consensusRegistrations, accountConsensusRegistrations...) } span.AddEvent("Generated registrations") @@ -155,21 +161,25 @@ func (s *Service) submitValidatorRegistrationsForAccounts(ctx context.Context, func (s *Service) generateValidatorRegistrationsForAccount(ctx context.Context, account e2wtypes.Account, controlledValidators map[phase0.BLSPubKey]struct{}, - consensusRegistrations []*consensusapi.VersionedSignedValidatorRegistration, relayRegistrations map[string][]*builderapi.VersionedSignedValidatorRegistration, -) error { +) ( + []*consensusapi.VersionedSignedValidatorRegistration, + error, +) { pubkey := util.ValidatorPubkey(account) controlledValidators[pubkey] = struct{}{} proposerConfig, err := s.executionConfig.ProposerConfig(ctx, account, pubkey, s.fallbackFeeRecipient, s.fallbackGasLimit) if err != nil { - return errors.Wrap(err, "No proposer configuration; cannot submit validator registrations") + return nil, errors.Wrap(err, "No proposer configuration; cannot submit validator registrations") } if proposerConfig.FeeRecipient.IsZero() { s.log.Error().Stringer("validator", pubkey).Msg("Received 0 execution address for validator registration; using fallback") proposerConfig.FeeRecipient = s.fallbackFeeRecipient } + consensusRegistrations := make([]*consensusapi.VersionedSignedValidatorRegistration, 0, len(proposerConfig.Relays)) + for index, relay := range proposerConfig.Relays { relayRegistration, consensusRegistration, err := s.generateValidatorRegistrationForRelay(ctx, account, pubkey, relay) if err != nil { @@ -195,7 +205,7 @@ func (s *Service) generateValidatorRegistrationsForAccount(ctx context.Context, } } - return nil + return consensusRegistrations, nil } func (s *Service) submitRelayRegistrations(ctx context.Context,