2021-11-30 00:30:17 +08:00
|
|
|
package stateutil
|
2021-11-17 01:04:49 -08:00
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/pkg/errors"
|
2024-02-14 21:46:47 -08:00
|
|
|
"github.com/prysmaticlabs/prysm/v5/encoding/ssz"
|
2021-11-17 01:04:49 -08:00
|
|
|
)
|
|
|
|
|
2022-05-09 15:02:34 +02:00
|
|
|
func ArraysRoot(input [][]byte, length uint64) ([32]byte, error) {
|
2021-11-17 01:04:49 -08:00
|
|
|
leaves := make([][32]byte, length)
|
|
|
|
for i, chunk := range input {
|
|
|
|
copy(leaves[i][:], chunk)
|
|
|
|
}
|
2023-03-17 19:41:02 +08:00
|
|
|
res, err := merkleize(leaves, length)
|
2021-11-17 01:04:49 -08:00
|
|
|
if err != nil {
|
|
|
|
return [32]byte{}, err
|
|
|
|
}
|
|
|
|
|
2022-02-22 17:27:51 +08:00
|
|
|
return res, nil
|
2021-11-17 01:04:49 -08:00
|
|
|
}
|
|
|
|
|
2023-03-17 19:41:02 +08:00
|
|
|
func merkleize(leaves [][32]byte, length uint64) ([32]byte, error) {
|
2021-11-17 01:04:49 -08:00
|
|
|
if len(leaves) == 0 {
|
|
|
|
return [32]byte{}, errors.New("zero leaves provided")
|
|
|
|
}
|
|
|
|
if len(leaves) == 1 {
|
|
|
|
return leaves[0], nil
|
|
|
|
}
|
|
|
|
hashLayer := leaves
|
|
|
|
layers := make([][][32]byte, ssz.Depth(length)+1)
|
|
|
|
layers[0] = hashLayer
|
|
|
|
var err error
|
2023-03-17 19:41:02 +08:00
|
|
|
_, hashLayer, err = MerkleizeTrieLeaves(layers, hashLayer)
|
2021-11-17 01:04:49 -08:00
|
|
|
if err != nil {
|
|
|
|
return [32]byte{}, err
|
|
|
|
}
|
|
|
|
root := hashLayer[0]
|
|
|
|
return root, nil
|
|
|
|
}
|