Refactor pending deposit processing

This commit is contained in:
Mikhail Kalinin 2024-06-20 18:46:38 +06:00
parent fd75470eab
commit 2a202c8ecb
1 changed files with 44 additions and 24 deletions

View File

@ -58,6 +58,7 @@
- [New `get_active_balance`](#new-get_active_balance) - [New `get_active_balance`](#new-get_active_balance)
- [New `get_pending_balance_to_withdraw`](#new-get_pending_balance_to_withdraw) - [New `get_pending_balance_to_withdraw`](#new-get_pending_balance_to_withdraw)
- [Modified `get_attesting_indices`](#modified-get_attesting_indices) - [Modified `get_attesting_indices`](#modified-get_attesting_indices)
- [`get_activation_churn_consumption`](#get_activation_churn_consumption)
- [Beacon state mutators](#beacon-state-mutators) - [Beacon state mutators](#beacon-state-mutators)
- [Updated `initiate_validator_exit`](#updated--initiate_validator_exit) - [Updated `initiate_validator_exit`](#updated--initiate_validator_exit)
- [New `switch_to_compounding_validator`](#new-switch_to_compounding_validator) - [New `switch_to_compounding_validator`](#new-switch_to_compounding_validator)
@ -616,6 +617,27 @@ def get_attesting_indices(state: BeaconState, attestation: Attestation) -> Set[V
return output return output
``` ```
#### `get_activation_churn_consumption`
```python
def get_activation_churn_consumption(state: BeaconState, pending_deposit: PendingDeposit) -> Gwei:
"""
Return amount of activation churn consumed by the ``pending_deposit``.
"""
validator_pubkeys = [v.pubkey for v in state.validators]
if pending_deposit.pubkey not in validator_pubkeys:
return pending_deposit.amount
else:
validator_index = ValidatorIndex(validator_pubkeys.index(deposit.pubkey))
validator = state.validators[validator_index]
# Validator is exiting, do not consume the churn
if validator.exit_epoch < FAR_FUTURE_EPOCH:
return Gwei(0)
else:
return pending_deposit.amount
```
### Beacon state mutators ### Beacon state mutators
#### Updated `initiate_validator_exit` #### Updated `initiate_validator_exit`
@ -824,12 +846,17 @@ def process_pending_deposits(state: BeaconState) -> None:
deposits_to_postpone = [] deposits_to_postpone = []
for deposit in state.pending_deposits: for deposit in state.pending_deposits:
# If deposit does not fit in the churn, do no more deposit processing in this epoch.
churn_consumption = get_activation_churn_consumption(state, deposit)
if processed_amount + churn_consumption > available_for_processing:
break
# Consume churn and process deposit
processed_amount += churn_consumption
validator_pubkeys = [v.pubkey for v in state.validators] validator_pubkeys = [v.pubkey for v in state.validators]
if deposit.pubkey not in validator_pubkeys: if deposit.pubkey not in validator_pubkeys:
# Deposit does not fit in the churn, no more deposit processing in this epoch.
if processed_amount + deposit.amount > available_for_processing:
break
# Verify the deposit signature (proof of possession) which is not checked by the deposit contract # Verify the deposit signature (proof of possession) which is not checked by the deposit contract
if is_valid_deposit_signature( if is_valid_deposit_signature(
deposit.pubkey, deposit.pubkey,
@ -838,8 +865,6 @@ def process_pending_deposits(state: BeaconState) -> None:
deposit.signature deposit.signature
): ):
add_validator_to_registry(state, deposit.pubkey, deposit.withdrawal_credentials, deposit.amount) add_validator_to_registry(state, deposit.pubkey, deposit.withdrawal_credentials, deposit.amount)
# Consume churn only if signature is valid.
processed_amount += deposit.amount
else: else:
validator_index = ValidatorIndex(validator_pubkeys.index(deposit.pubkey)) validator_index = ValidatorIndex(validator_pubkeys.index(deposit.pubkey))
validator = state.validators[validator_index] validator = state.validators[validator_index]
@ -852,25 +877,20 @@ def process_pending_deposits(state: BeaconState) -> None:
increase_balance(state, validator_index, deposit.amount) increase_balance(state, validator_index, deposit.amount)
# Validator is not exiting, attempt to process deposit # Validator is not exiting, attempt to process deposit
else: else:
# Deposit does not fit in the churn, no more deposit processing in this epoch. # Increase balance
if processed_amount + deposit.amount > available_for_processing: increase_balance(state, validator_index, deposit.amount)
break # Check if valid deposit switch to compounding credentials.
# Deposit fits in the churn, process it. Increase balance and consume churn. if (
else: is_compounding_withdrawal_credential(deposit.withdrawal_credentials)
increase_balance(state, validator_index, deposit.amount) and has_eth1_withdrawal_credential(validator)
processed_amount += deposit.amount and is_valid_deposit_signature(
# Check if valid deposit switch to compounding credentials deposit.pubkey,
if ( deposit.withdrawal_credentials,
is_compounding_withdrawal_credential(deposit.withdrawal_credentials) deposit.amount,
and has_eth1_withdrawal_credential(validator) deposit.signature
and is_valid_deposit_signature( )
deposit.pubkey, ):
deposit.withdrawal_credentials, switch_to_compounding_validator(state, validator_index)
deposit.amount,
deposit.signature
)
):
switch_to_compounding_validator(state, validator_index)
# Regardless of how the deposit was handled, we move on in the queue. # Regardless of how the deposit was handled, we move on in the queue.
next_deposit_index += 1 next_deposit_index += 1