mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-17 23:38:46 +00:00
d5ddd012bc
* Enforce error handling and checking type assertions * Reference issue #5404 in the TODO message * doc description * Merge branch 'master' into errcheck * fix tests and address @nisdas feedbacK * gaz * fix docker image
91 lines
2.8 KiB
Go
91 lines
2.8 KiB
Go
package helpers
|
|
|
|
import (
|
|
stateTrie "github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
)
|
|
|
|
// TotalBalance returns the total amount at stake in Gwei
|
|
// of input validators.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_total_balance(state: BeaconState, indices: Set[ValidatorIndex]) -> Gwei:
|
|
// """
|
|
// Return the combined effective balance of the ``indices``. (1 Gwei minimum to avoid divisions by zero.)
|
|
// """
|
|
// return Gwei(max(1, sum([state.validators[index].effective_balance for index in indices])))
|
|
func TotalBalance(state *stateTrie.BeaconState, indices []uint64) uint64 {
|
|
total := uint64(0)
|
|
|
|
for _, idx := range indices {
|
|
val, err := state.ValidatorAtIndexReadOnly(idx)
|
|
if err != nil {
|
|
continue
|
|
}
|
|
total += val.EffectiveBalance()
|
|
}
|
|
|
|
// Return 1 Gwei minimum to avoid divisions by zero
|
|
if total == 0 {
|
|
return 1
|
|
}
|
|
|
|
return total
|
|
}
|
|
|
|
// TotalActiveBalance returns the total amount at stake in Gwei
|
|
// of active validators.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_total_active_balance(state: BeaconState) -> Gwei:
|
|
// """
|
|
// Return the combined effective balance of the active validators.
|
|
// """
|
|
// return get_total_balance(state, set(get_active_validator_indices(state, get_current_epoch(state))))
|
|
func TotalActiveBalance(state *stateTrie.BeaconState) (uint64, error) {
|
|
total := uint64(0)
|
|
if err := state.ReadFromEveryValidator(func(idx int, val *stateTrie.ReadOnlyValidator) error {
|
|
if IsActiveValidatorUsingTrie(val, SlotToEpoch(state.Slot())) {
|
|
total += val.EffectiveBalance()
|
|
}
|
|
return nil
|
|
}); err != nil {
|
|
return 0, err
|
|
}
|
|
return total, nil
|
|
}
|
|
|
|
// IncreaseBalance increases validator with the given 'index' balance by 'delta' in Gwei.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def increase_balance(state: BeaconState, index: ValidatorIndex, delta: Gwei) -> None:
|
|
// """
|
|
// Increase the validator balance at index ``index`` by ``delta``.
|
|
// """
|
|
// state.balances[index] += delta
|
|
func IncreaseBalance(state *stateTrie.BeaconState, idx uint64, delta uint64) error {
|
|
balAtIdx, err := state.BalanceAtIndex(idx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return state.UpdateBalancesAtIndex(idx, balAtIdx+delta)
|
|
}
|
|
|
|
// DecreaseBalance decreases validator with the given 'index' balance by 'delta' in Gwei.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def decrease_balance(state: BeaconState, index: ValidatorIndex, delta: Gwei) -> None:
|
|
// """
|
|
// Decrease the validator balance at index ``index`` by ``delta``, with underflow protection.
|
|
// """
|
|
// state.balances[index] = 0 if delta > state.balances[index] else state.balances[index] - delta
|
|
func DecreaseBalance(state *stateTrie.BeaconState, idx uint64, delta uint64) error {
|
|
balAtIdx, err := state.BalanceAtIndex(idx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if delta > balAtIdx {
|
|
return state.UpdateBalancesAtIndex(idx, 0)
|
|
}
|
|
return state.UpdateBalancesAtIndex(idx, balAtIdx-delta)
|
|
}
|