2016-08-08 12:05:51 -05:00
|
|
|
// Copyright (c) 2015 The Decred developers
|
2017-01-11 10:00:16 -05:00
|
|
|
// Copyright (c) 2016-2017 The btcsuite developers
|
2016-08-08 12:05:51 -05:00
|
|
|
// Use of this source code is governed by an ISC
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package chainhash
|
|
|
|
|
2018-05-28 19:46:51 -07:00
|
|
|
import (
|
|
|
|
"crypto/sha256"
|
|
|
|
"crypto/sha512"
|
|
|
|
|
|
|
|
"golang.org/x/crypto/ripemd160"
|
|
|
|
)
|
2016-08-08 12:05:51 -05:00
|
|
|
|
|
|
|
// HashB calculates hash(b) and returns the resulting bytes.
|
|
|
|
func HashB(b []byte) []byte {
|
2017-01-11 10:00:16 -05:00
|
|
|
hash := sha256.Sum256(b)
|
2016-08-08 12:05:51 -05:00
|
|
|
return hash[:]
|
|
|
|
}
|
|
|
|
|
|
|
|
// HashH calculates hash(b) and returns the resulting bytes as a Hash.
|
|
|
|
func HashH(b []byte) Hash {
|
2017-01-11 10:00:16 -05:00
|
|
|
return Hash(sha256.Sum256(b))
|
2016-08-08 12:05:51 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// DoubleHashB calculates hash(hash(b)) and returns the resulting bytes.
|
|
|
|
func DoubleHashB(b []byte) []byte {
|
2017-01-11 10:00:16 -05:00
|
|
|
first := sha256.Sum256(b)
|
|
|
|
second := sha256.Sum256(first[:])
|
2016-08-08 12:05:51 -05:00
|
|
|
return second[:]
|
|
|
|
}
|
|
|
|
|
|
|
|
// DoubleHashH calculates hash(hash(b)) and returns the resulting bytes as a
|
|
|
|
// Hash.
|
|
|
|
func DoubleHashH(b []byte) Hash {
|
2017-01-11 10:00:16 -05:00
|
|
|
first := sha256.Sum256(b)
|
|
|
|
return Hash(sha256.Sum256(first[:]))
|
2016-08-08 12:05:51 -05:00
|
|
|
}
|
2018-05-28 19:46:51 -07:00
|
|
|
|
|
|
|
// LbryPoWHashH calculates returns the PoW Hash.
|
|
|
|
//
|
|
|
|
// doubled := SHA256(SHA256(b))
|
|
|
|
// expanded := SHA512(doubled)
|
|
|
|
// left := RIPEMD160(expanded[0:32])
|
|
|
|
// right := RIPEMD160(expanded[32:64])
|
|
|
|
// result := SHA256(SHA256(left||right))
|
|
|
|
func LbryPoWHashH(b []byte) Hash {
|
|
|
|
doubled := DoubleHashB(b)
|
|
|
|
expanded := sha512.Sum512(doubled)
|
|
|
|
|
|
|
|
r := ripemd160.New()
|
|
|
|
r.Reset()
|
|
|
|
r.Write(expanded[:sha256.Size])
|
|
|
|
left := r.Sum(nil)
|
|
|
|
|
|
|
|
r.Reset()
|
|
|
|
r.Write(expanded[sha256.Size:])
|
|
|
|
|
|
|
|
combined := r.Sum(left)
|
|
|
|
return DoubleHashH(combined)
|
|
|
|
}
|