Skip to content
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 EIP: Upgrade block proposer election to Whisk #7441

Merged
merged 16 commits into from
Sep 5, 2023
101 changes: 101 additions & 0 deletions EIPS/eip-7441.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
---
eip: 7441
title: Upgrade block proposer election to Whisk SSLE
dapplion marked this conversation as resolved.
Show resolved Hide resolved
description: Allow elected block proposers to remain private until block publishing, to prevent DoS attacks
author: George Kadianakis (@asn-d6), Justin Drake (@JustinDrake), dapplion (@dapplion)
discussions-to: https://ethereum-magicians.org/t/eip-7441-upgrade-block-proposer-election-to-whisk-ssle/15316
status: Draft
type: Standards Track
category: Core
created: 2023-09-01
---

## Abstract

Upgrades the block proposer election mechanism to Whisk, a single secret leader election (SSLE) protocol. Currently, block proposers are publicly known in advance, sufficiently to allow sequential DoS attacks that could disable Ethereum. This upgrade makes the next block proposer unknown until its block is published.
dapplion marked this conversation as resolved.
Show resolved Hide resolved

## Motivation

The beacon chain currently elects the next 32 block proposers at the beginning of each epoch. The results of this election are public and everyone gets to learn the identity of those future block proposers.

This information leak enables attackers to launch DoS attacks against each proposer sequentially in an attempt to disable Ethereum.
Copy link
Contributor

@g11tech g11tech Aug 8, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

there was an EIP which described how proposers and/or users can collude to avoid paying higher base fee and pocket more tips leading to irregular block size, will see which was that . this EIP can potentially address that scenario as well

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

With whisk, each proposer is aware of its future proposer slots much more in advance. So if there's collusion and proposers want to reveal such information to selected parties, Whisk makes the attack you describe easier.

Copy link
Contributor

@g11tech g11tech Aug 9, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

may be then we can add this in security considerations ?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it's a significant change into the status quo security in this regard. With RANDAO based shuffling actors can still collude if they have proposer slots in a row


## Specification

g11tech marked this conversation as resolved.
Show resolved Hide resolved
### Execution layer

This requires no changes to the Execution Layer.

### Consensus layer

The protocol can be summarized in the following concurrent steps:

Copy link
Contributor

@g11tech g11tech Aug 8, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
- Proposals are now divided into shuffling phases of `WHISK_EPOCHS_PER_SHUFFLING_PHASE` epochs

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure if this sentence is necessary. TBH this mini summary of the protocol is not necessary either. It does not provide any specification and is only a general overview for readers. Should it be removed altogether?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

so the flow of someone looking into this feature would be (or atleast how we want it to be) : Read EIP => Read consensus specs => get into client implementations if someone wants to follow through on this. So mini summary helps making that jump

keeping that in mind, what kind of mini summary would you deem good to fit here. else if we have that somewhere in consensus specs (fork.md?) then we can refer it here i guess

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think such summary would fit anywhere in the specs. Since it's derived information it mostly fits here or in a blog / etheresearch post introduction.

- Validators register a tracker on their first proposal after the fork
dapplion marked this conversation as resolved.
Show resolved Hide resolved
- At the start of a shuffling phase a list of candidate trackers is selected using public randomness from RANDAO
- During one shuffling phase each proposer shuffles a subset of the candidate trackers using private randomness
dapplion marked this conversation as resolved.
Show resolved Hide resolved
- After one shuffling phase an ordered list of proposer trackers is selected from the candidate set using RANDAO
dapplion marked this conversation as resolved.
Show resolved Hide resolved

The full specification of the proposed change can be found in [`/_features/whisk/beacon-chain.md`](https://github.com/ethereum/consensus-specs/blob/a39abe388bc2d1abd5b4fd62fd18aed497956b30/specs/_features/whisk/beacon-chain.md). In summary:

- Update `BeaconState` with fields needed to track validator trackers, commitments, and the two rounds of candidate election.
Copy link
Contributor

@g11tech g11tech Aug 9, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

may be we don't need this detail (how to update beacon state) as its defined in the full specification already refered and could do away with this

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would be good define some guidelines on what this section is expected to include or not? Other editors can chip-in and @djrtwo

- Add `select_whisk_candidate_trackers` to compute the next vector of candidates from the validator set.
- Add `select_whisk_proposer_trackers` to compute the next vector of proposers from current candidates.
- Add `process_whisk_updates` to epoch processing logic.
- Add `process_whisk_opening_proof` to validate block proposer has knowledge of this slot's elected tracker.
- Modify `process_block_header` to not assert proposer election with `get_beacon_proposer_index`, instead assert valid opening proof.
- Update `BeaconBlockBody` with fields to submit opening proof, shuffled trackers with proof, and tracker registration with proof.
- Add `get_shuffle_indices` to compute pre-shuffle candidate selection
- Add `process_shuffled_trackers` to submit shuffled candidate trackers.
- Add `process_whisk` to block processing logic.
- Modify `apply_deposit` to register an initial unique tracker and commitment without entropy.

## Rationale

### Fields per validator

Whisk requires appending one tracker `(rG,krG)` and one commitment `kG` per validator. Both are updated at max once through a validator's lifetime.
dapplion marked this conversation as resolved.
Show resolved Hide resolved

Trackers are registered with a randomized base `(rG,krG)` to make it harder for adversaries to track them through shuffling gates. It can become an issue if the set of honest shufflers is small.

### Identity binding

Each tracker must be bound to a validator's identity to prevent multiple parties to claim the same proposer slot. Otherwise, it would allow proposers to sell their proposer slot, and cause fork-choice issues if two competing blocks appear.

Whisk does identity binding by storing a commitment to the tracker's secret `kG` in the validator record. Storing the commitment also ensures the uniqueness of `k`.

Alternatively, identity binding can be achieved by forcing the hash prefix of `hash(kG)` to match its validator index. However, validators would have to brute force `k` making bootstrap of the system harder for participants with fewer computational resources.

Identity binding can also be achieved by setting `k = hash(nonce + pubkey)`. However, proposers will need to reveal `k` and be de-anonymized for repeated proposals on adjacent shuffling phases.

### Alternative: non-single secret election

Secret non-single leader election is based on protocol engineering rather than cryptography, thus much simpler and cheap than Whisk. However, it complicates the fork-choice and opens it up to potential MEV time-buying attacks, making it an unsuitable option at the time of writing.
dapplion marked this conversation as resolved.
Show resolved Hide resolved

### Alternative: network anonymity

Privacy-preserving networking protocols like Dandelion or Dandelion++ increase the privacy of network participants but not sufficiently for Ethereum's use case.

SASSAFRAS is a simpler alternative SSLE protocol consensus-wise, but it relies on a network anonymity layer. Its specific trade-offs do not fit Ethereum's overall threat model better than Whisk.

## Backwards Compatibility

This EIP introduces backward incompatible changes to the block validation rule set on the consensus layer and must be accompanied by a hard fork.

PBS participants (e.g. builders) will not know the next proposer validator index to use a specific pre-registered fee recipient; unless the proposer chooses to reveal itself ahead of time. Block explorers and tooling will not be able to attribute missing slots to a specific validator index.

## Security Considerations

The shuffling strategy is analyzed in a companion paper and considered sufficiently safe for Whisk's use case. The data and computational complexity of this EIP are significant but constant, thus does not open new DoS vectors.

### Anonymity set

The anonymity set in Whisk equals `WHISK_CANDIDATE_TRACKERS_COUNT - WHISK_PROPOSER_TRACKERS_COUNT` (8,192) which are the candidates that did not get selected as proposers. That count of validators corresponds to a smaller number of p2p nodes. Assuming a Pareto principle where "20% of the nodes run 80% of the validators" the anonymity corresponds to 2,108 nodes on average. A bigger candidate pool could make the shuffling strategy unsafe while shuffling more trackers per round would increase the cost of the ZK proofs.
g11tech marked this conversation as resolved.
Show resolved Hide resolved

### RANDAO biasing

Whisk uses RANDAO in the candidate selection and proposer selection events, and is susceptible to potential RANDAO biasing attacks by malicious proposers. Whisk security could be made identical to the status quo by spreading the selection events over an entire shuffling period. However, status quo security is not ideal either and it would complicate the protocol further.

## Copyright

Copyright and related rights waived via [CC0](../LICENSE.md).