mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-25 21:07:18 +00:00
a069738c20
* update shared/params * update eth2-types deps * update protobufs * update shared/* * fix testutil/state * update beacon-chain/state * update beacon-chain/db * update tests * fix test * update beacon-chain/core * update beacon-chain/blockchain * update beacon-chain/cache * beacon-chain/forkchoice * update beacon-chain/operations * update beacon-chain/p2p * update beacon-chain/rpc * update sync/initial-sync * update deps * update deps * go fmt * update beacon-chain/sync * update endtoend/ * bazel build //beacon-chain - works w/o issues * update slasher code * udpate tools/ * update validator/ * update fastssz * fix build * fix test building * update tests * update ethereumapis deps * fix tests * update state/stategen * fix build * fix test * add FarFutureSlot * go imports * Radek's suggestions * Ivan's suggestions * type conversions * Nishant's suggestions * add more tests to rpc_send_request * fix test * clean up * fix conflicts Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com> Co-authored-by: nisdas <nishdas93@gmail.com>
51 lines
1.9 KiB
Go
51 lines
1.9 KiB
Go
package helpers
|
|
|
|
import (
|
|
types "github.com/prysmaticlabs/eth2-types"
|
|
stateTrie "github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/shared/hashutil"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
)
|
|
|
|
// Seed returns the randao seed used for shuffling of a given epoch.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_seed(state: BeaconState, epoch: Epoch, domain_type: DomainType) -> Hash:
|
|
// """
|
|
// Return the seed at ``epoch``.
|
|
// """
|
|
// mix = get_randao_mix(state, Epoch(epoch + EPOCHS_PER_HISTORICAL_VECTOR - MIN_SEED_LOOKAHEAD - 1)) # Avoid underflow
|
|
// return hash(domain_type + int_to_bytes(epoch, length=8) + mix)
|
|
func Seed(state *stateTrie.BeaconState, epoch types.Epoch, domain [bls.DomainByteLength]byte) ([32]byte, error) {
|
|
// See https://github.com/ethereum/eth2.0-specs/pull/1296 for
|
|
// rationale on why offset has to look down by 1.
|
|
lookAheadEpoch := epoch + params.BeaconConfig().EpochsPerHistoricalVector -
|
|
params.BeaconConfig().MinSeedLookahead - 1
|
|
|
|
randaoMix, err := RandaoMix(state, lookAheadEpoch)
|
|
if err != nil {
|
|
return [32]byte{}, err
|
|
}
|
|
seed := append(domain[:], bytesutil.Bytes8(uint64(epoch))...)
|
|
seed = append(seed, randaoMix...)
|
|
|
|
seed32 := hashutil.Hash(seed)
|
|
|
|
return seed32, nil
|
|
}
|
|
|
|
// RandaoMix returns the randao mix (xor'ed seed)
|
|
// of a given slot. It is used to shuffle validators.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_randao_mix(state: BeaconState, epoch: Epoch) -> Hash:
|
|
// """
|
|
// Return the randao mix at a recent ``epoch``.
|
|
// """
|
|
// return state.randao_mixes[epoch % EPOCHS_PER_HISTORICAL_VECTOR]
|
|
func RandaoMix(state *stateTrie.BeaconState, epoch types.Epoch) ([]byte, error) {
|
|
return state.RandaoMixAtIndex(uint64(epoch % params.BeaconConfig().EpochsPerHistoricalVector))
|
|
}
|