2021-03-18 23:29:06 +00:00
|
|
|
package stateutil
|
2021-03-16 18:14:26 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
|
2021-09-15 22:55:11 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/crypto/hash"
|
2021-09-21 15:02:48 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/encoding/ssz"
|
2021-07-21 21:34:07 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
2021-03-16 18:14:26 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
|
|
)
|
|
|
|
|
2021-03-18 23:29:06 +00:00
|
|
|
// BlockHeaderRoot computes the HashTreeRoot Merkleization of
|
2021-06-26 19:00:33 +00:00
|
|
|
// a BeaconBlockHeader struct according to the Ethereum
|
2021-03-16 18:14:26 +00:00
|
|
|
// Simple Serialize specification.
|
2021-03-18 23:29:06 +00:00
|
|
|
func BlockHeaderRoot(header *ethpb.BeaconBlockHeader) ([32]byte, error) {
|
2021-03-16 18:14:26 +00:00
|
|
|
fieldRoots := make([][]byte, 5)
|
|
|
|
if header != nil {
|
|
|
|
headerSlotBuf := make([]byte, 8)
|
|
|
|
binary.LittleEndian.PutUint64(headerSlotBuf, uint64(header.Slot))
|
|
|
|
headerSlotRoot := bytesutil.ToBytes32(headerSlotBuf)
|
|
|
|
fieldRoots[0] = headerSlotRoot[:]
|
|
|
|
proposerIdxBuf := make([]byte, 8)
|
|
|
|
binary.LittleEndian.PutUint64(proposerIdxBuf, uint64(header.ProposerIndex))
|
|
|
|
proposerIndexRoot := bytesutil.ToBytes32(proposerIdxBuf)
|
|
|
|
fieldRoots[1] = proposerIndexRoot[:]
|
|
|
|
parentRoot := bytesutil.ToBytes32(header.ParentRoot)
|
|
|
|
fieldRoots[2] = parentRoot[:]
|
|
|
|
stateRoot := bytesutil.ToBytes32(header.StateRoot)
|
|
|
|
fieldRoots[3] = stateRoot[:]
|
|
|
|
bodyRoot := bytesutil.ToBytes32(header.BodyRoot)
|
|
|
|
fieldRoots[4] = bodyRoot[:]
|
|
|
|
}
|
2021-09-21 15:02:48 +00:00
|
|
|
return ssz.BitwiseMerkleize(hash.CustomSHA256Hasher(), fieldRoots, uint64(len(fieldRoots)), uint64(len(fieldRoots)))
|
2021-03-16 18:14:26 +00:00
|
|
|
}
|