2023-01-07 11:25:28 +00:00
|
|
|
package merkle_tree
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
|
2023-01-13 18:12:18 +00:00
|
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
2023-01-07 11:25:28 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Uint64Root retrieves the root hash of a uint64 value by converting it to a byte array and returning it as a hash.
|
2023-01-13 18:12:18 +00:00
|
|
|
func Uint64Root(val uint64) libcommon.Hash {
|
|
|
|
var root libcommon.Hash
|
2023-01-07 11:25:28 +00:00
|
|
|
binary.LittleEndian.PutUint64(root[:], val)
|
|
|
|
return root
|
|
|
|
}
|
|
|
|
|
2023-01-13 18:12:18 +00:00
|
|
|
func SignatureRoot(signature [96]byte) (libcommon.Hash, error) {
|
2023-01-07 11:25:28 +00:00
|
|
|
return ArraysRoot([][32]byte{
|
2023-01-13 18:12:18 +00:00
|
|
|
libcommon.BytesToHash(signature[0:32]),
|
|
|
|
libcommon.BytesToHash(signature[32:64]),
|
|
|
|
libcommon.BytesToHash(signature[64:]),
|
2023-01-07 11:25:28 +00:00
|
|
|
}, 4)
|
|
|
|
}
|
2023-01-09 00:04:05 +00:00
|
|
|
|
2023-01-13 18:12:18 +00:00
|
|
|
func PublicKeyRoot(key [48]byte) (libcommon.Hash, error) {
|
2023-01-09 00:04:05 +00:00
|
|
|
var lastByte [32]byte
|
|
|
|
copy(lastByte[:], key[32:])
|
|
|
|
return ArraysRoot([][32]byte{
|
2023-01-13 18:12:18 +00:00
|
|
|
libcommon.BytesToHash(key[:32]),
|
2023-01-09 00:04:05 +00:00
|
|
|
lastByte,
|
|
|
|
}, 2)
|
|
|
|
}
|