mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 12:40:05 +00:00
2f10b1c7b1
* Remove gogoproto compiler * Remove more gogoproto * Improvements * Fix gengo * More scripts * Gazelle, fix deps * Fix version and errors * Fix gocast for arrays * Fix ethapis * Fixes * Fix compile errors * fix go.mod * //proto/... builds * Update for protov2 * temp fix compilation to move on * Change everything to emptypb.empty * Add grpc to proto/slashings * Fix almost all build failures * Oher build problems * FIX THIS FUCKING THING * gaz literally every .bazel * Final touches * Final final touches * Fix proto * Begin moving proto.Marshal to native * Fix site_data * Fixes * Fix duplicate gateway * Fix gateway target * Fix ethapis * Fixes from review * Update * Fix * Fix status test * Fix fuzz * Add isprotoslice to fun * Change DeepEqual to DeepSSZEqual for proto arrays * Fix build * Fix gaz * Update go * Fixes * Fixes * Add case for nil validators after copy * Fix cast * Fix test * Fix imports * Go mod * Only use extension where needed * Fixes * Split gateway from gengo * gaz * go mod * Add back hydrated state * fix hydrate * Fix proto.clone * Fies * Revert "Split gateway from gengo" This reverts commit 7298bb2054d446e427d9af97e13b8fabe8695085. * Revert "gaz" This reverts commit ca952565701a88727e22302d6c8d60ac48d97255. * Merge all gateway into one target * go mod * Gaz * Add generate v1_gateway files * run pb again * goimports * gaz * Fix comments * Fix protos * Fix PR * Fix protos * Update grpc-gateway and ethapis * Update ethapis and gen-go-cast * Go tidy * Reorder * Fix ethapis * fix spec tests * Fix script * Remove unused import * Fix fuzz * Fix gomod * Update version * Error if the cloned result is nil * Handle optional slots * ADd more empty checks to clone * Undo fuzz changes * Fix build.bazel * Gaz * Redo fuzz changes * Undo some eth1data changes * Update go.mod Co-authored-by: Preston Van Loon <preston@prysmaticlabs.com> * Undo clone beacon state * Remove gogo proto more and unused v1_gateway * Add manual fix for nil vals * Fix gaz * tidy * Tidy again * Add detailed error * Revert "Add detailed error" This reverts commit 59bc053dcd59569a54c95b07739d5a379665ec5d. * Undo varint changes * Fix nil validators in deposit test * Commit * Undo Co-authored-by: Preston Van Loon <preston@prysmaticlabs.com> Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: Nishant Das <nishdas93@gmail.com> Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>
136 lines
3.6 KiB
Go
136 lines
3.6 KiB
Go
// Package hashutil includes all hash-function related helpers for Prysm.
|
|
package hashutil
|
|
|
|
import (
|
|
"errors"
|
|
"hash"
|
|
"reflect"
|
|
"sync"
|
|
|
|
fastssz "github.com/ferranbt/fastssz"
|
|
"github.com/minio/highwayhash"
|
|
"github.com/minio/sha256-simd"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"golang.org/x/crypto/sha3"
|
|
"google.golang.org/protobuf/proto"
|
|
)
|
|
|
|
// ErrNilProto can occur when attempting to hash a protobuf message that is nil
|
|
// or has nil objects within lists.
|
|
var ErrNilProto = errors.New("cannot hash a nil protobuf message")
|
|
|
|
var sha256Pool = sync.Pool{New: func() interface{} {
|
|
return sha256.New()
|
|
}}
|
|
|
|
// Hash defines a function that returns the sha256 checksum of the data passed in.
|
|
// https://github.com/ethereum/eth2.0-specs/blob/v0.9.3/specs/core/0_beacon-chain.md#hash
|
|
func Hash(data []byte) [32]byte {
|
|
h, ok := sha256Pool.Get().(hash.Hash)
|
|
if !ok {
|
|
h = sha256.New()
|
|
}
|
|
defer sha256Pool.Put(h)
|
|
h.Reset()
|
|
|
|
var b [32]byte
|
|
|
|
// The hash interface never returns an error, for that reason
|
|
// we are not handling the error below. For reference, it is
|
|
// stated here https://golang.org/pkg/hash/#Hash
|
|
|
|
// #nosec G104
|
|
h.Write(data)
|
|
h.Sum(b[:0])
|
|
|
|
return b
|
|
}
|
|
|
|
// CustomSHA256Hasher returns a hash function that uses
|
|
// an enclosed hasher. This is not safe for concurrent
|
|
// use as the same hasher is being called throughout.
|
|
//
|
|
// Note: that this method is only more performant over
|
|
// hashutil.Hash if the callback is used more than 5 times.
|
|
func CustomSHA256Hasher() func([]byte) [32]byte {
|
|
hasher, ok := sha256Pool.Get().(hash.Hash)
|
|
if !ok {
|
|
hasher = sha256.New()
|
|
} else {
|
|
hasher.Reset()
|
|
}
|
|
var h [32]byte
|
|
|
|
return func(data []byte) [32]byte {
|
|
// The hash interface never returns an error, for that reason
|
|
// we are not handling the error below. For reference, it is
|
|
// stated here https://golang.org/pkg/hash/#Hash
|
|
|
|
// #nosec G104
|
|
hasher.Write(data)
|
|
hasher.Sum(h[:0])
|
|
hasher.Reset()
|
|
|
|
return h
|
|
}
|
|
}
|
|
|
|
var keccak256Pool = sync.Pool{New: func() interface{} {
|
|
return sha3.NewLegacyKeccak256()
|
|
}}
|
|
|
|
// HashKeccak256 defines a function which returns the Keccak-256/SHA3
|
|
// hash of the data passed in.
|
|
func HashKeccak256(data []byte) [32]byte {
|
|
var b [32]byte
|
|
|
|
h, ok := keccak256Pool.Get().(hash.Hash)
|
|
if !ok {
|
|
h = sha3.NewLegacyKeccak256()
|
|
}
|
|
defer keccak256Pool.Put(h)
|
|
h.Reset()
|
|
|
|
// The hash interface never returns an error, for that reason
|
|
// we are not handling the error below. For reference, it is
|
|
// stated here https://golang.org/pkg/hash/#Hash
|
|
|
|
// #nosec G104
|
|
h.Write(data)
|
|
h.Sum(b[:0])
|
|
|
|
return b
|
|
}
|
|
|
|
// HashProto hashes a protocol buffer message using sha256.
|
|
func HashProto(msg proto.Message) (result [32]byte, err error) {
|
|
if msg == nil || reflect.ValueOf(msg).IsNil() {
|
|
return [32]byte{}, ErrNilProto
|
|
}
|
|
var data []byte
|
|
if m, ok := msg.(fastssz.Marshaler); ok {
|
|
data, err = m.MarshalSSZ()
|
|
} else {
|
|
data, err = proto.Marshal(msg)
|
|
}
|
|
if err != nil {
|
|
return [32]byte{}, err
|
|
}
|
|
return Hash(data), nil
|
|
}
|
|
|
|
// Key used for FastSum64
|
|
var fastSumHashKey = bytesutil.ToBytes32([]byte("hash_fast_sum64_key"))
|
|
|
|
// FastSum64 returns a hash sum of the input data using highwayhash. This method is not secure, but
|
|
// may be used as a quick identifier for objects where collisions are acceptable.
|
|
func FastSum64(data []byte) uint64 {
|
|
return highwayhash.Sum64(data, fastSumHashKey[:])
|
|
}
|
|
|
|
// FastSum256 returns a hash sum of the input data using highwayhash. This method is not secure, but
|
|
// may be used as a quick identifier for objects where collisions are acceptable.
|
|
func FastSum256(data []byte) [32]byte {
|
|
return highwayhash.Sum(data, fastSumHashKey[:])
|
|
}
|