Whisk: don't mutate candidates during cooldown (#3483)
This commit is contained in:
parent
0b751fc259
commit
eef61448a9
|
@ -324,30 +324,25 @@ def get_shuffle_indices(randao_reveal: BLSSignature) -> Sequence[uint64]:
|
||||||
|
|
||||||
```python
|
```python
|
||||||
def process_shuffled_trackers(state: BeaconState, body: BeaconBlockBody) -> None:
|
def process_shuffled_trackers(state: BeaconState, body: BeaconBlockBody) -> None:
|
||||||
# Check the shuffle proof
|
|
||||||
shuffle_indices = get_shuffle_indices(body.randao_reveal)
|
|
||||||
pre_shuffle_trackers = [state.whisk_candidate_trackers[i] for i in shuffle_indices]
|
|
||||||
|
|
||||||
shuffle_epoch = get_current_epoch(state) % WHISK_EPOCHS_PER_SHUFFLING_PHASE
|
shuffle_epoch = get_current_epoch(state) % WHISK_EPOCHS_PER_SHUFFLING_PHASE
|
||||||
if shuffle_epoch + WHISK_PROPOSER_SELECTION_GAP + 1 >= WHISK_EPOCHS_PER_SHUFFLING_PHASE:
|
if shuffle_epoch + WHISK_PROPOSER_SELECTION_GAP + 1 >= WHISK_EPOCHS_PER_SHUFFLING_PHASE:
|
||||||
# Require trackers set to zero during cooldown
|
# Require trackers set to zero during cooldown
|
||||||
assert body.whisk_post_shuffle_trackers == Vector[WhiskTracker, WHISK_VALIDATORS_PER_SHUFFLE]()
|
assert body.whisk_post_shuffle_trackers == Vector[WhiskTracker, WHISK_VALIDATORS_PER_SHUFFLE]()
|
||||||
assert body.whisk_shuffle_proof_M_commitment == BLSG1Point()
|
assert body.whisk_shuffle_proof_M_commitment == BLSG1Point()
|
||||||
assert body.whisk_shuffle_proof == WhiskShuffleProof()
|
assert body.whisk_shuffle_proof == WhiskShuffleProof()
|
||||||
post_shuffle_trackers = pre_shuffle_trackers
|
|
||||||
else:
|
else:
|
||||||
# Require shuffled trackers during shuffle
|
# Require shuffled trackers during shuffle
|
||||||
|
shuffle_indices = get_shuffle_indices(body.randao_reveal)
|
||||||
|
pre_shuffle_trackers = [state.whisk_candidate_trackers[i] for i in shuffle_indices]
|
||||||
assert IsValidWhiskShuffleProof(
|
assert IsValidWhiskShuffleProof(
|
||||||
pre_shuffle_trackers,
|
pre_shuffle_trackers,
|
||||||
body.whisk_post_shuffle_trackers,
|
body.whisk_post_shuffle_trackers,
|
||||||
body.whisk_shuffle_proof_M_commitment,
|
body.whisk_shuffle_proof_M_commitment,
|
||||||
body.whisk_shuffle_proof,
|
body.whisk_shuffle_proof,
|
||||||
)
|
)
|
||||||
post_shuffle_trackers = body.whisk_post_shuffle_trackers
|
# Shuffle candidate trackers
|
||||||
|
for i, shuffle_index in enumerate(shuffle_indices):
|
||||||
# Shuffle candidate trackers
|
state.whisk_candidate_trackers[shuffle_index] = body.whisk_post_shuffle_trackers[i]
|
||||||
for i, shuffle_index in enumerate(shuffle_indices):
|
|
||||||
state.whisk_candidate_trackers[shuffle_index] = post_shuffle_trackers[i]
|
|
||||||
```
|
```
|
||||||
|
|
||||||
```python
|
```python
|
||||||
|
|
Loading…
Reference in New Issue