16 lines
345 B
Go
Raw Normal View History

2020-11-25 19:01:53 +08:00
package kcp
import (
"crypto/aes"
"crypto/cipher"
"crypto/sha256"
2020-12-04 09:36:16 +08:00
"github.com/xtls/xray-core/common"
2020-11-25 19:01:53 +08:00
)
func NewAEADAESGCMBasedOnSeed(seed string) cipher.AEAD {
hashedSeed := sha256.Sum256([]byte(seed))
aesBlock := common.Must2(aes.NewCipher(hashedSeed[:16])).(cipher.Block)
return common.Must2(cipher.NewGCM(aesBlock)).(cipher.AEAD)
}