v2ray-core/proxy/vmess/aead/kdf.go

27 lines
444 B
Go
Raw Normal View History

2020-06-06 09:11:30 +00:00
package aead
import (
"crypto/hmac"
"crypto/sha256"
"hash"
)
func KDF(key []byte, path ...string) []byte {
hmacf := hmac.New(func() hash.Hash {
return sha256.New()
2020-06-08 05:21:59 +00:00
}, []byte(KDFSaltConst_VMessAEADKDF))
2020-06-06 09:11:30 +00:00
for _, v := range path {
hmacf = hmac.New(func() hash.Hash {
return hmacf
}, []byte(v))
}
hmacf.Write(key)
return hmacf.Sum(nil)
}
func KDF16(key []byte, path ...string) []byte {
r := KDF(key, path...)
return r[:16]
}