1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2024-11-10 14:26:26 -05:00
v2fly/proxy/vmess/aead/kdf.go
2021-02-19 13:24:19 +08:00

24 lines
414 B
Go

package aead
import (
"crypto/hmac"
"crypto/sha256"
"hash"
)
func KDF(key []byte, path ...string) []byte {
var hmacf hash.Hash
for _, v := range path {
hmacf = hmac.New(func() hash.Hash {
return hmac.New(sha256.New, []byte(KDFSaltConstVMessAEADKDF))
}, []byte(v))
}
hmacf.Write(key)
return hmacf.Sum(nil)
}
func KDF16(key []byte, path ...string) []byte {
r := KDF(key, path...)
return r[:16]
}