-
Notifications
You must be signed in to change notification settings - Fork 120
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
[spec proposal] Default BidTrace Updated to Support Timestamp and ExtraData #257
Comments
To summarize, the proposal is this?
I am in favor of these changes, they seem to make the data API more useful, without downsides. And it seems fairly easy to implement. |
Out of curiosity, is |
Totally up, just never got around to do the remaining work, and needed some database updates too. Open to contributions, or might get around to this at a later date. |
This issue was implemented I believe here: flashbots/relay-specs@adae2d4 and referenced as the discussion for flashbots/relay-specs#7 So this can be closed now. |
Merging flashbots/relay-specs#7 has been reverted ub flashbots/relay-specs#18, because the relay is not yet exposing these fields. |
Will make sure our relay does so as well, thanks for the update. |
Context:
Currently, the relay/v1/data/bidtraces/proposer_payload_delivered endpoint returns a
BidTraceV2
object that does not include atimestamp
. This becomes a problem when one tries to analyze the impact of time on block proposals. As discussed in [1] and [2], time impacts proposers' incentives, and correct analysis can help us better understand how the game is played.I'm currently working on finding the unrealized value (UNREV) in payloads delivered through mev-boost. Since it is not always the case that proposers pick the (latest-delivered -> as only the latest submitted block of each builder matters) most valuable block available in any relay, UNREV emerges.
Although one reason for UNREV can be a proposer being irrational (in the sense that not always aiming to maximize his utility, e.g., because he only wants to work with a specific relay), another reason is the timing/availability of blocks. It is highly possible that a proposer had accepted a block too early, exposing UNREV. For example, in slot 4,849,684, the delivered payload paid 0.06 ETH. One second later, a block offered 465 ETH (0x18ce78328850d8de2f9d4c6f3fbafdd3ae143b97a9860f8b8b78ad5ac7606167).
With the current endpoints (proposer_payload_delivered and builder_blocks_received), one cannot do a complete UNREV analysis for each block as:
BidTraceV2
object that does not include atimestamp
(unlikeBidTraceV2WithTimestamp
). One can try to find the same block through builder_blocks_received endpoint and use the timestamp there but I'm not sure if the timestamp of the delivered payload would be the same as the submitted builder block's.Changes:
BidTraceV3
which inherits fromBidTraceV2WithTimestamp
and adds anextra_data
field as proposed by @metachris .BidTraceV3
now. However, it is open to discussion whether both should return the sametimestamp
for a given block.The text was updated successfully, but these errors were encountered: