2019-02-25 22:44:14 +00:00
|
|
|
package hash
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/sha256"
|
|
|
|
"io"
|
|
|
|
|
|
|
|
"github.com/CityOfZion/neo-go/pkg/wire/util"
|
|
|
|
"golang.org/x/crypto/ripemd160"
|
|
|
|
)
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
// Sha256 hashes the byte slice using sha256
|
2019-02-25 22:44:14 +00:00
|
|
|
func Sha256(data []byte) (util.Uint256, error) {
|
|
|
|
var hash util.Uint256
|
|
|
|
hasher := sha256.New()
|
|
|
|
hasher.Reset()
|
|
|
|
_, err := hasher.Write(data)
|
|
|
|
|
|
|
|
hash, err = util.Uint256DecodeBytes(hasher.Sum(nil))
|
|
|
|
if err != nil {
|
|
|
|
return hash, err
|
|
|
|
}
|
|
|
|
return hash, nil
|
|
|
|
}
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
// DoubleSha256 hashes the underlying data twice using sha256
|
2019-02-25 22:44:14 +00:00
|
|
|
func DoubleSha256(data []byte) (util.Uint256, error) {
|
|
|
|
var hash util.Uint256
|
|
|
|
|
|
|
|
h1, err := Sha256(data)
|
|
|
|
if err != nil {
|
|
|
|
return hash, err
|
|
|
|
}
|
|
|
|
|
|
|
|
hash, err = Sha256(h1.Bytes())
|
|
|
|
if err != nil {
|
|
|
|
return hash, err
|
|
|
|
}
|
|
|
|
return hash, nil
|
|
|
|
}
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
// RipeMD160 hashes the underlying data using ripemd160
|
2019-02-25 22:44:14 +00:00
|
|
|
func RipeMD160(data []byte) (util.Uint160, error) {
|
|
|
|
var hash util.Uint160
|
|
|
|
hasher := ripemd160.New()
|
|
|
|
hasher.Reset()
|
|
|
|
_, err := io.WriteString(hasher, string(data))
|
|
|
|
|
|
|
|
hash, err = util.Uint160DecodeBytes(hasher.Sum(nil))
|
|
|
|
if err != nil {
|
|
|
|
return hash, err
|
|
|
|
}
|
|
|
|
return hash, nil
|
|
|
|
}
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
//Hash160 hashes the underlying data using sha256 then ripemd160
|
2019-02-25 22:44:14 +00:00
|
|
|
func Hash160(data []byte) (util.Uint160, error) {
|
|
|
|
var hash util.Uint160
|
|
|
|
h1, err := Sha256(data)
|
|
|
|
|
|
|
|
h2, err := RipeMD160(h1.Bytes())
|
|
|
|
|
|
|
|
hash, err = util.Uint160DecodeBytes(h2.Bytes())
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return hash, err
|
|
|
|
}
|
|
|
|
return hash, nil
|
|
|
|
}
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
// Checksum calculates the checksum of the byte slice using sha256
|
2019-02-25 22:44:14 +00:00
|
|
|
func Checksum(data []byte) ([]byte, error) {
|
|
|
|
hash, err := Sum(data)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return hash[:4], nil
|
|
|
|
}
|
|
|
|
|
2019-03-17 18:26:35 +00:00
|
|
|
// Sum calculates the Sum of the data by using double sha256
|
2019-02-25 22:44:14 +00:00
|
|
|
func Sum(b []byte) (util.Uint256, error) {
|
|
|
|
hash, err := DoubleSha256((b))
|
|
|
|
return hash, err
|
|
|
|
}
|