kdf_blake3.go 924 B

12345678910111213141516171819202122232425262728293031
  1. package shadowsocks2022
  2. import (
  3. "github.com/v2fly/v2ray-core/v5/common/buf"
  4. "lukechampine.com/blake3"
  5. )
  6. func newBLAKE3KeyDerivation() *BLAKE3KeyDerivation {
  7. return &BLAKE3KeyDerivation{}
  8. }
  9. type BLAKE3KeyDerivation struct {
  10. }
  11. func (B BLAKE3KeyDerivation) GetSessionSubKey(effectivePsk, Salt []byte, OutKey []byte) error {
  12. keyingMaterialBuffer := buf.New()
  13. keyingMaterialBuffer.Write(effectivePsk)
  14. keyingMaterialBuffer.Write(Salt)
  15. blake3.DeriveKey(OutKey, "shadowsocks 2022 session subkey", keyingMaterialBuffer.Bytes())
  16. keyingMaterialBuffer.Release()
  17. return nil
  18. }
  19. func (B BLAKE3KeyDerivation) GetIdentitySubKey(effectivePsk, Salt []byte, OutKey []byte) error {
  20. keyingMaterialBuffer := buf.New()
  21. keyingMaterialBuffer.Write(effectivePsk)
  22. keyingMaterialBuffer.Write(Salt)
  23. blake3.DeriveKey(OutKey, "shadowsocks 2022 identity subkey", keyingMaterialBuffer.Bytes())
  24. keyingMaterialBuffer.Release()
  25. return nil
  26. }