From bcf5a940b1c050f09588b14134da815e304afd63 Mon Sep 17 00:00:00 2001 From: Mateusz Morusiewicz <11313015+Ruteri@users.noreply.github.com> Date: Tue, 7 Jun 2022 12:09:57 +0200 Subject: [PATCH] Allow resending of the same validator registration (#7) --- builder/backend.go | 7 ++++++- builder/backend_test.go | 3 +-- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/builder/backend.go b/builder/backend.go index d014a7efb2..77fdbc2b31 100644 --- a/builder/backend.go +++ b/builder/backend.go @@ -182,7 +182,12 @@ func (b *Backend) handleRegisterValidator(w http.ResponseWriter, req *http.Reque for _, registerRequest := range payload { pubkeyHex := PubkeyHex(registerRequest.Message.Pubkey.String()) if previousValidatorData, ok := b.validators[pubkeyHex]; ok { - if registerRequest.Message.Timestamp <= previousValidatorData.Timestamp { + if registerRequest.Message.Timestamp < previousValidatorData.Timestamp { + respondError(w, http.StatusBadRequest, "invalid timestamp") + return + } + + if registerRequest.Message.Timestamp == previousValidatorData.Timestamp && (registerRequest.Message.FeeRecipient != previousValidatorData.FeeRecipient || registerRequest.Message.GasLimit != previousValidatorData.GasLimit) { respondError(w, http.StatusBadRequest, "invalid timestamp") return } diff --git a/builder/backend_test.go b/builder/backend_test.go index 1158d06f25..762903f923 100644 --- a/builder/backend_test.go +++ b/builder/backend_test.go @@ -64,8 +64,7 @@ func TestValidatorRegistration(t *testing.T) { require.Equal(t, ValidatorData{FeeRecipient: payload[0].Message.FeeRecipient, GasLimit: payload[0].Message.GasLimit, Timestamp: payload[0].Message.Timestamp}, backend.validators[PubkeyHex(v.Pk.String())]) rr = testRequest(t, backend, "POST", "/eth/v1/builder/validators", payload) - require.Equal(t, http.StatusBadRequest, rr.Code) - require.Equal(t, `{"code":400,"message":"invalid timestamp"}`+"\n", rr.Body.String()) + require.Equal(t, http.StatusOK, rr.Code) payload[0].Message.Timestamp += 1 // Invalid signature