-
Notifications
You must be signed in to change notification settings - Fork 174
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add register_validator
endpoint
#209
Add register_validator
endpoint
#209
Conversation
2e61dae
to
7109932
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
left one comment below about defining the common types in the pyspec style somewhere and otherwise this looks great.
I strongly support this solution over #206
9469ea4
to
58859e0
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good! minor comment on the language.
plus I prefer keeping it in the validator namespace as this is something the validator uses in it's BN communications
811f4e9
to
f91bcc2
Compare
Co-authored-by: Alex Stokes <r.alex.stokes@gmail.com>
Hi @mpetrunic, would you mind taking a look at this? Thanks! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
This is another take on #206.
Rather than extending
prepare_beacon_proposer
, in this PR we create a new, separate endpointregister_validator
. This addresses two pieces of feedback raised against the extension:prepare_beacon_proposer
performs a critical operation and probably shouldn't be encumbered by any additional responsibilitiesregister_validator
will likely be executed on a different rhythm thanprepare_beacon_proposer
, so it feels more appropriate to separate out that logic--
Now a short recap on why it's important this data is sent to the beacon node in the first place.
After the merge, validators will want to extract MEV from blocks. The mechanism that will facilitate this extraction a network of external builders. These builders will provide
ExecutionPayloadHeader
s to proposers to include in their beacon blocks with the promise that they will be paid a portion of the extracted value. From the perspective of the builder, most values in the header are deterministic depending on what the parent is. However, it is important that a few parameters remain under control of the proposer.First is obviously the
fee_recipient
. Although it's not critical that the payload's actualfee_recipient
be set to the proposer's preferred address (a simple transfer at the end of the block would suffice), it is crucial block builders have this information ahead of time so that they can begin constructing blocks immediately after their forkchoice moves forward.The second parameter that is on the critical path to production is
gas_limit
. Strictly speaking, builders could decide whatever limit they like under the rules of consensus, however this gives a small number of builders a lot of power over this protocol parameter. Validators are more aligned with choosing a healthy gas limit, so it's best that value is left up to them.In order to provide these two values to builders ahead of time in an form that can be authenticated, we introduce this new endpoint. By signing over these values and a timestamp, builders can determine validator's latest preferences before they are scheduled to propose.
The Builder API and spec is currently being developed in
ethereum/builder-specs
. A new domain type has also been proposed which will be utilized by this endpoint to avoid a conflict with consensus-level messages.