2022-05-07 20:08:51 +05:30
|
|
|
package destination
|
2021-02-22 17:27:13 +05:30
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/md5"
|
|
|
|
"crypto/sha1"
|
|
|
|
"crypto/sha256"
|
|
|
|
"crypto/sha512"
|
|
|
|
"encoding/hex"
|
|
|
|
"hash"
|
|
|
|
"io"
|
2022-08-13 15:12:31 +05:30
|
|
|
"os"
|
|
|
|
|
|
|
|
"gitlab.com/gitlab-org/labkit/fips"
|
2021-02-22 17:27:13 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
var hashFactories = map[string](func() hash.Hash){
|
|
|
|
"md5": md5.New,
|
|
|
|
"sha1": sha1.New,
|
|
|
|
"sha256": sha256.New,
|
|
|
|
"sha512": sha512.New,
|
|
|
|
}
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
var fipsHashFactories = map[string](func() hash.Hash){
|
|
|
|
"sha1": sha1.New,
|
|
|
|
"sha256": sha256.New,
|
|
|
|
"sha512": sha512.New,
|
|
|
|
}
|
|
|
|
|
|
|
|
func factories() map[string](func() hash.Hash) {
|
|
|
|
if FIPSEnabled() {
|
|
|
|
return fipsHashFactories
|
|
|
|
}
|
|
|
|
|
|
|
|
return hashFactories
|
|
|
|
}
|
|
|
|
|
|
|
|
func FIPSEnabled() bool {
|
|
|
|
if fips.Enabled() {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return os.Getenv("WORKHORSE_TEST_FIPS_ENABLED") == "1"
|
|
|
|
}
|
|
|
|
|
2021-02-22 17:27:13 +05:30
|
|
|
type multiHash struct {
|
|
|
|
io.Writer
|
|
|
|
hashes map[string]hash.Hash
|
|
|
|
}
|
|
|
|
|
|
|
|
func newMultiHash() (m *multiHash) {
|
|
|
|
m = &multiHash{}
|
|
|
|
m.hashes = make(map[string]hash.Hash)
|
|
|
|
|
|
|
|
var writers []io.Writer
|
2022-08-13 15:12:31 +05:30
|
|
|
for hash, hashFactory := range factories() {
|
2021-02-22 17:27:13 +05:30
|
|
|
writer := hashFactory()
|
|
|
|
|
|
|
|
m.hashes[hash] = writer
|
|
|
|
writers = append(writers, writer)
|
|
|
|
}
|
|
|
|
|
|
|
|
m.Writer = io.MultiWriter(writers...)
|
|
|
|
return m
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *multiHash) finish() map[string]string {
|
|
|
|
h := make(map[string]string)
|
|
|
|
for hashName, hash := range m.hashes {
|
|
|
|
checksum := hash.Sum(nil)
|
|
|
|
h[hashName] = hex.EncodeToString(checksum)
|
|
|
|
}
|
|
|
|
return h
|
|
|
|
}
|