crypt.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package kcp
  2. import (
  3. "hash/fnv"
  4. "v2ray.com/core/common/alloc"
  5. "v2ray.com/core/common/serial"
  6. "v2ray.com/core/transport/internet"
  7. )
  8. type SimpleAuthenticator struct{}
  9. func NewSimpleAuthenticator() internet.Authenticator {
  10. return &SimpleAuthenticator{}
  11. }
  12. func (this *SimpleAuthenticator) Overhead() int {
  13. return 6
  14. }
  15. func (this *SimpleAuthenticator) Seal(buffer *alloc.Buffer) {
  16. buffer.PrependUint16(uint16(buffer.Len()))
  17. fnvHash := fnv.New32a()
  18. fnvHash.Write(buffer.Value)
  19. buffer.PrependHash(fnvHash)
  20. len := buffer.Len()
  21. xtra := 4 - len%4
  22. if xtra != 0 {
  23. buffer.Slice(0, len+xtra)
  24. }
  25. xorfwd(buffer.Value)
  26. if xtra != 0 {
  27. buffer.Slice(0, len)
  28. }
  29. }
  30. func (this *SimpleAuthenticator) Open(buffer *alloc.Buffer) bool {
  31. len := buffer.Len()
  32. xtra := 4 - len%4
  33. if xtra != 0 {
  34. buffer.Slice(0, len+xtra)
  35. }
  36. xorbkd(buffer.Value)
  37. if xtra != 0 {
  38. buffer.Slice(0, len)
  39. }
  40. fnvHash := fnv.New32a()
  41. fnvHash.Write(buffer.Value[4:])
  42. if serial.BytesToUint32(buffer.Value[:4]) != fnvHash.Sum32() {
  43. return false
  44. }
  45. length := serial.BytesToUint16(buffer.Value[4:6])
  46. if buffer.Len()-6 != int(length) {
  47. return false
  48. }
  49. buffer.SliceFrom(6)
  50. return true
  51. }