mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 04:30:04 +00:00
798bbbdc82
* coldstart flags for validator * WIP beacon node flags * wip beacon chain, flag fix in validator, arg fix in validator * checkpoint * Added interop service * working on mock chainstart * save the state lol * fix tests * Save genesis validators * gaz * fix validator help flags * WaitForChainStart actually waits for genesis time * cold start fixes * cache * change back * allow for genesis state too * remove logs * increase mmap size * dont process if head doesn't exist * add 10ms tolerance * enable libp2p debug at debug, fix pubsub * works with checkpt * initialize justified and finalized in db * Removed preloadStatePath from blockchain service * Clean up * Write to disk for now post state * revert b466dd536f8eadbdae2264a545a755370223d917 * Builds * Only RPC test fails now * use minimal config, no demo config * clean up branch * Lint * resolve lint * more lint fixes * lint * fix viz * Fixing RPC test * skip before epoch 2 * RPC time out * Fixed ordering * rename * remove some dbg statements * ensure index is correct * fix some panics * getting closer * fix tests * Fix private key * Fixed RPC test * Fixed beacon chain build for docker * Add interop.go to validator go_image * Fixed docker build * handle errors * skip test, skip disconnecting peers * Fixed docker build * tolerance for attestation processing * revert copy * clearer err message parse * fix launching from dep contract
119 lines
4.6 KiB
Go
119 lines
4.6 KiB
Go
package interop
|
|
|
|
import (
|
|
"github.com/pkg/errors"
|
|
"github.com/prysmaticlabs/go-ssz"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/state"
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
|
"github.com/prysmaticlabs/prysm/shared/hashutil"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"github.com/prysmaticlabs/prysm/shared/trieutil"
|
|
)
|
|
|
|
var (
|
|
domainDeposit = [4]byte{3, 0, 0, 0}
|
|
genesisForkVersion = []byte{0, 0, 0, 0}
|
|
|
|
// This is the recommended mock eth1 block hash according to the Eth2 interop guidelines.
|
|
// https://github.com/ethereum/eth2.0-pm/blob/a085c9870f3956d6228ed2a40cd37f0c6580ecd7/interop/mocked_start/README.md
|
|
mockEth1BlockHash = []byte{66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66, 66}
|
|
)
|
|
|
|
// GenerateGenesisState deterministically given a genesis time and number of validators.
|
|
func GenerateGenesisState(genesisTime, numValidators uint64) (*pb.BeaconState, []*ethpb.Deposit, error) {
|
|
privKeys, pubKeys, err := DeterministicallyGenerateKeys(0 /*startIndex*/, numValidators)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrapf(err, "could not deterministically generate keys for %d validators", numValidators)
|
|
}
|
|
depositDataItems, depositDataRoots, err := DepositDataFromKeys(privKeys, pubKeys)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrap(err, "could not generate deposit data from keys")
|
|
}
|
|
trie, err := trieutil.GenerateTrieFromItems(
|
|
depositDataRoots,
|
|
int(params.BeaconConfig().DepositContractTreeDepth),
|
|
)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrap(err, "could not generate Merkle trie for deposit proofs")
|
|
}
|
|
deposits, err := GenerateDepositsFromData(depositDataItems, trie)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrap(err, "could not generate deposits from the deposit data provided")
|
|
}
|
|
root := trie.Root()
|
|
beaconState, err := state.GenesisBeaconState(deposits, genesisTime, ðpb.Eth1Data{
|
|
DepositRoot: root[:],
|
|
DepositCount: uint64(len(deposits)),
|
|
BlockHash: mockEth1BlockHash,
|
|
})
|
|
if err != nil {
|
|
return nil, nil, errors.Wrap(err, "could not generate genesis state")
|
|
}
|
|
return beaconState, deposits, nil
|
|
}
|
|
|
|
// GenerateDepositsFromData a list of deposit items by creating proofs for each of them from a sparse Merkle trie.
|
|
func GenerateDepositsFromData(depositDataItems []*ethpb.Deposit_Data, trie *trieutil.MerkleTrie) ([]*ethpb.Deposit, error) {
|
|
deposits := make([]*ethpb.Deposit, len(depositDataItems))
|
|
for i, item := range depositDataItems {
|
|
proof, err := trie.MerkleProof(i)
|
|
if err != nil {
|
|
return nil, errors.Wrapf(err, "could not generate proof for deposit %d", i)
|
|
}
|
|
deposits[i] = ðpb.Deposit{
|
|
Proof: proof,
|
|
Data: item,
|
|
}
|
|
}
|
|
return deposits, nil
|
|
}
|
|
|
|
// DepositDataFromKeys generates a list of deposit data items from a set of BLS validator keys.
|
|
func DepositDataFromKeys(privKeys []*bls.SecretKey, pubKeys []*bls.PublicKey) ([]*ethpb.Deposit_Data, [][]byte, error) {
|
|
dataRoots := make([][]byte, len(privKeys))
|
|
depositDataItems := make([]*ethpb.Deposit_Data, len(privKeys))
|
|
for i := 0; i < len(privKeys); i++ {
|
|
data, err := createDepositData(privKeys[i], pubKeys[i])
|
|
if err != nil {
|
|
return nil, nil, errors.Wrapf(err, "could not create deposit data for key: %#x", privKeys[i].Marshal())
|
|
}
|
|
hash, err := ssz.HashTreeRoot(data)
|
|
if err != nil {
|
|
return nil, nil, errors.Wrap(err, "could not hash tree root deposit data item")
|
|
}
|
|
dataRoots[i] = hash[:]
|
|
depositDataItems[i] = data
|
|
}
|
|
return depositDataItems, dataRoots, nil
|
|
}
|
|
|
|
// Generates a deposit data item from BLS keys and signs the hash tree root of the data.
|
|
func createDepositData(privKey *bls.SecretKey, pubKey *bls.PublicKey) (*ethpb.Deposit_Data, error) {
|
|
di := ðpb.Deposit_Data{
|
|
PublicKey: pubKey.Marshal(),
|
|
WithdrawalCredentials: withdrawalCredentialsHash(pubKey.Marshal()),
|
|
Amount: params.BeaconConfig().MaxEffectiveBalance,
|
|
}
|
|
sr, err := ssz.SigningRoot(di)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
domain := bls.Domain(domainDeposit[:], genesisForkVersion)
|
|
di.Signature = privKey.Sign(sr[:], domain).Marshal()
|
|
return di, nil
|
|
}
|
|
|
|
// withdrawalCredentialsHash forms a 32 byte hash of the withdrawal public
|
|
// address.
|
|
//
|
|
// The specification is as follows:
|
|
// withdrawal_credentials[:1] == BLS_WITHDRAWAL_PREFIX_BYTE
|
|
// withdrawal_credentials[1:] == hash(withdrawal_pubkey)[1:]
|
|
// where withdrawal_credentials is of type bytes32.
|
|
func withdrawalCredentialsHash(pubKey []byte) []byte {
|
|
h := hashutil.HashKeccak256(pubKey)
|
|
return append([]byte{blsWithdrawalPrefixByte}, h[0:]...)[:32]
|
|
}
|