1
0

encoding.go 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. package encoding
  2. import (
  3. "context"
  4. "io"
  5. "github.com/xtls/xray-core/common/buf"
  6. "github.com/xtls/xray-core/common/errors"
  7. "github.com/xtls/xray-core/common/net"
  8. "github.com/xtls/xray-core/common/protocol"
  9. "github.com/xtls/xray-core/common/session"
  10. "github.com/xtls/xray-core/common/signal"
  11. "github.com/xtls/xray-core/proxy"
  12. "github.com/xtls/xray-core/proxy/vless"
  13. )
  14. const (
  15. Version = byte(0)
  16. )
  17. var addrParser = protocol.NewAddressParser(
  18. protocol.AddressFamilyByte(byte(protocol.AddressTypeIPv4), net.AddressFamilyIPv4),
  19. protocol.AddressFamilyByte(byte(protocol.AddressTypeDomain), net.AddressFamilyDomain),
  20. protocol.AddressFamilyByte(byte(protocol.AddressTypeIPv6), net.AddressFamilyIPv6),
  21. protocol.PortThenAddress(),
  22. )
  23. // EncodeRequestHeader writes encoded request header into the given writer.
  24. func EncodeRequestHeader(writer io.Writer, request *protocol.RequestHeader, requestAddons *Addons) error {
  25. buffer := buf.StackNew()
  26. defer buffer.Release()
  27. if err := buffer.WriteByte(request.Version); err != nil {
  28. return errors.New("failed to write request version").Base(err)
  29. }
  30. if _, err := buffer.Write(request.User.Account.(*vless.MemoryAccount).ID.Bytes()); err != nil {
  31. return errors.New("failed to write request user id").Base(err)
  32. }
  33. if err := EncodeHeaderAddons(&buffer, requestAddons); err != nil {
  34. return errors.New("failed to encode request header addons").Base(err)
  35. }
  36. if err := buffer.WriteByte(byte(request.Command)); err != nil {
  37. return errors.New("failed to write request command").Base(err)
  38. }
  39. if request.Command != protocol.RequestCommandMux && request.Command != protocol.RequestCommandRvs {
  40. if err := addrParser.WriteAddressPort(&buffer, request.Address, request.Port); err != nil {
  41. return errors.New("failed to write request address and port").Base(err)
  42. }
  43. }
  44. if _, err := writer.Write(buffer.Bytes()); err != nil {
  45. return errors.New("failed to write request header").Base(err)
  46. }
  47. return nil
  48. }
  49. // DecodeRequestHeader decodes and returns (if successful) a RequestHeader from an input stream.
  50. func DecodeRequestHeader(isfb bool, first *buf.Buffer, reader io.Reader, validator vless.Validator) ([]byte, *protocol.RequestHeader, *Addons, bool, error) {
  51. buffer := buf.StackNew()
  52. defer buffer.Release()
  53. request := new(protocol.RequestHeader)
  54. if isfb {
  55. request.Version = first.Byte(0)
  56. } else {
  57. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  58. return nil, nil, nil, false, errors.New("failed to read request version").Base(err)
  59. }
  60. request.Version = buffer.Byte(0)
  61. }
  62. switch request.Version {
  63. case 0:
  64. var id [16]byte
  65. if isfb {
  66. copy(id[:], first.BytesRange(1, 17))
  67. } else {
  68. buffer.Clear()
  69. if _, err := buffer.ReadFullFrom(reader, 16); err != nil {
  70. return nil, nil, nil, false, errors.New("failed to read request user id").Base(err)
  71. }
  72. copy(id[:], buffer.Bytes())
  73. }
  74. if request.User = validator.Get(id); request.User == nil {
  75. return nil, nil, nil, isfb, errors.New("invalid request user id")
  76. }
  77. if isfb {
  78. first.Advance(17)
  79. }
  80. requestAddons, err := DecodeHeaderAddons(&buffer, reader)
  81. if err != nil {
  82. return nil, nil, nil, false, errors.New("failed to decode request header addons").Base(err)
  83. }
  84. buffer.Clear()
  85. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  86. return nil, nil, nil, false, errors.New("failed to read request command").Base(err)
  87. }
  88. request.Command = protocol.RequestCommand(buffer.Byte(0))
  89. switch request.Command {
  90. case protocol.RequestCommandMux:
  91. request.Address = net.DomainAddress("v1.mux.cool")
  92. case protocol.RequestCommandRvs:
  93. request.Address = net.DomainAddress("v1.rvs.cool")
  94. case protocol.RequestCommandTCP, protocol.RequestCommandUDP:
  95. if addr, port, err := addrParser.ReadAddressPort(&buffer, reader); err == nil {
  96. request.Address = addr
  97. request.Port = port
  98. }
  99. }
  100. if request.Address == nil {
  101. return nil, nil, nil, false, errors.New("invalid request address")
  102. }
  103. return id[:], request, requestAddons, false, nil
  104. default:
  105. return nil, nil, nil, isfb, errors.New("invalid request version")
  106. }
  107. }
  108. // EncodeResponseHeader writes encoded response header into the given writer.
  109. func EncodeResponseHeader(writer io.Writer, request *protocol.RequestHeader, responseAddons *Addons) error {
  110. buffer := buf.StackNew()
  111. defer buffer.Release()
  112. if err := buffer.WriteByte(request.Version); err != nil {
  113. return errors.New("failed to write response version").Base(err)
  114. }
  115. if err := EncodeHeaderAddons(&buffer, responseAddons); err != nil {
  116. return errors.New("failed to encode response header addons").Base(err)
  117. }
  118. if _, err := writer.Write(buffer.Bytes()); err != nil {
  119. return errors.New("failed to write response header").Base(err)
  120. }
  121. return nil
  122. }
  123. // DecodeResponseHeader decodes and returns (if successful) a ResponseHeader from an input stream.
  124. func DecodeResponseHeader(reader io.Reader, request *protocol.RequestHeader) (*Addons, error) {
  125. buffer := buf.StackNew()
  126. defer buffer.Release()
  127. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  128. return nil, errors.New("failed to read response version").Base(err)
  129. }
  130. if buffer.Byte(0) != request.Version {
  131. return nil, errors.New("unexpected response version. Expecting ", int(request.Version), " but actually ", int(buffer.Byte(0)))
  132. }
  133. responseAddons, err := DecodeHeaderAddons(&buffer, reader)
  134. if err != nil {
  135. return nil, errors.New("failed to decode response header addons").Base(err)
  136. }
  137. return responseAddons, nil
  138. }
  139. // XtlsRead can switch to splice copy
  140. func XtlsRead(reader buf.Reader, writer buf.Writer, timer *signal.ActivityTimer, conn net.Conn, trafficState *proxy.TrafficState, isUplink bool, ctx context.Context) error {
  141. err := func() error {
  142. for {
  143. if isUplink && trafficState.Inbound.UplinkReaderDirectCopy || !isUplink && trafficState.Outbound.DownlinkReaderDirectCopy {
  144. var writerConn net.Conn
  145. var inTimer *signal.ActivityTimer
  146. if inbound := session.InboundFromContext(ctx); inbound != nil && inbound.Conn != nil {
  147. writerConn = inbound.Conn
  148. inTimer = inbound.Timer
  149. }
  150. return proxy.CopyRawConnIfExist(ctx, conn, writerConn, writer, timer, inTimer)
  151. }
  152. buffer, err := reader.ReadMultiBuffer()
  153. if !buffer.IsEmpty() {
  154. timer.Update()
  155. if werr := writer.WriteMultiBuffer(buffer); werr != nil {
  156. return werr
  157. }
  158. }
  159. if err != nil {
  160. return err
  161. }
  162. }
  163. }()
  164. if err != nil && errors.Cause(err) != io.EOF {
  165. return err
  166. }
  167. return nil
  168. }