encoding.go 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. package encoding
  2. //go:generate go run github.com/xtls/xray-core/common/errors/errorgen
  3. import (
  4. "bytes"
  5. "context"
  6. "io"
  7. "github.com/xtls/xray-core/common/buf"
  8. "github.com/xtls/xray-core/common/errors"
  9. "github.com/xtls/xray-core/common/net"
  10. "github.com/xtls/xray-core/common/protocol"
  11. "github.com/xtls/xray-core/common/session"
  12. "github.com/xtls/xray-core/common/signal"
  13. "github.com/xtls/xray-core/features/stats"
  14. "github.com/xtls/xray-core/proxy"
  15. "github.com/xtls/xray-core/proxy/vless"
  16. )
  17. const (
  18. Version = byte(0)
  19. )
  20. var addrParser = protocol.NewAddressParser(
  21. protocol.AddressFamilyByte(byte(protocol.AddressTypeIPv4), net.AddressFamilyIPv4),
  22. protocol.AddressFamilyByte(byte(protocol.AddressTypeDomain), net.AddressFamilyDomain),
  23. protocol.AddressFamilyByte(byte(protocol.AddressTypeIPv6), net.AddressFamilyIPv6),
  24. protocol.PortThenAddress(),
  25. )
  26. // EncodeRequestHeader writes encoded request header into the given writer.
  27. func EncodeRequestHeader(writer io.Writer, request *protocol.RequestHeader, requestAddons *Addons) error {
  28. buffer := buf.StackNew()
  29. defer buffer.Release()
  30. if err := buffer.WriteByte(request.Version); err != nil {
  31. return newError("failed to write request version").Base(err)
  32. }
  33. if _, err := buffer.Write(request.User.Account.(*vless.MemoryAccount).ID.Bytes()); err != nil {
  34. return newError("failed to write request user id").Base(err)
  35. }
  36. if err := EncodeHeaderAddons(&buffer, requestAddons); err != nil {
  37. return newError("failed to encode request header addons").Base(err)
  38. }
  39. if err := buffer.WriteByte(byte(request.Command)); err != nil {
  40. return newError("failed to write request command").Base(err)
  41. }
  42. if request.Command != protocol.RequestCommandMux {
  43. if err := addrParser.WriteAddressPort(&buffer, request.Address, request.Port); err != nil {
  44. return newError("failed to write request address and port").Base(err)
  45. }
  46. }
  47. if _, err := writer.Write(buffer.Bytes()); err != nil {
  48. return newError("failed to write request header").Base(err)
  49. }
  50. return nil
  51. }
  52. // DecodeRequestHeader decodes and returns (if successful) a RequestHeader from an input stream.
  53. func DecodeRequestHeader(isfb bool, first *buf.Buffer, reader io.Reader, validator *vless.Validator) (*protocol.RequestHeader, *Addons, bool, error) {
  54. buffer := buf.StackNew()
  55. defer buffer.Release()
  56. request := new(protocol.RequestHeader)
  57. if isfb {
  58. request.Version = first.Byte(0)
  59. } else {
  60. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  61. return nil, nil, false, newError("failed to read request version").Base(err)
  62. }
  63. request.Version = buffer.Byte(0)
  64. }
  65. switch request.Version {
  66. case 0:
  67. var id [16]byte
  68. if isfb {
  69. copy(id[:], first.BytesRange(1, 17))
  70. } else {
  71. buffer.Clear()
  72. if _, err := buffer.ReadFullFrom(reader, 16); err != nil {
  73. return nil, nil, false, newError("failed to read request user id").Base(err)
  74. }
  75. copy(id[:], buffer.Bytes())
  76. }
  77. if request.User = validator.Get(id); request.User == nil {
  78. return nil, nil, isfb, newError("invalid request user id")
  79. }
  80. if isfb {
  81. first.Advance(17)
  82. }
  83. requestAddons, err := DecodeHeaderAddons(&buffer, reader)
  84. if err != nil {
  85. return nil, nil, false, newError("failed to decode request header addons").Base(err)
  86. }
  87. buffer.Clear()
  88. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  89. return nil, nil, false, newError("failed to read request command").Base(err)
  90. }
  91. request.Command = protocol.RequestCommand(buffer.Byte(0))
  92. switch request.Command {
  93. case protocol.RequestCommandMux:
  94. request.Address = net.DomainAddress("v1.mux.cool")
  95. request.Port = 0
  96. case protocol.RequestCommandTCP, protocol.RequestCommandUDP:
  97. if addr, port, err := addrParser.ReadAddressPort(&buffer, reader); err == nil {
  98. request.Address = addr
  99. request.Port = port
  100. }
  101. }
  102. if request.Address == nil {
  103. return nil, nil, false, newError("invalid request address")
  104. }
  105. return request, requestAddons, false, nil
  106. default:
  107. return nil, nil, isfb, newError("invalid request version")
  108. }
  109. }
  110. // EncodeResponseHeader writes encoded response header into the given writer.
  111. func EncodeResponseHeader(writer io.Writer, request *protocol.RequestHeader, responseAddons *Addons) error {
  112. buffer := buf.StackNew()
  113. defer buffer.Release()
  114. if err := buffer.WriteByte(request.Version); err != nil {
  115. return newError("failed to write response version").Base(err)
  116. }
  117. if err := EncodeHeaderAddons(&buffer, responseAddons); err != nil {
  118. return newError("failed to encode response header addons").Base(err)
  119. }
  120. if _, err := writer.Write(buffer.Bytes()); err != nil {
  121. return newError("failed to write response header").Base(err)
  122. }
  123. return nil
  124. }
  125. // DecodeResponseHeader decodes and returns (if successful) a ResponseHeader from an input stream.
  126. func DecodeResponseHeader(reader io.Reader, request *protocol.RequestHeader) (*Addons, error) {
  127. buffer := buf.StackNew()
  128. defer buffer.Release()
  129. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  130. return nil, newError("failed to read response version").Base(err)
  131. }
  132. if buffer.Byte(0) != request.Version {
  133. return nil, newError("unexpected response version. Expecting ", int(request.Version), " but actually ", int(buffer.Byte(0)))
  134. }
  135. responseAddons, err := DecodeHeaderAddons(&buffer, reader)
  136. if err != nil {
  137. return nil, newError("failed to decode response header addons").Base(err)
  138. }
  139. return responseAddons, nil
  140. }
  141. // XtlsRead filter and read xtls protocol
  142. func XtlsRead(reader buf.Reader, writer buf.Writer, timer signal.ActivityUpdater, conn net.Conn, input *bytes.Reader, rawInput *bytes.Buffer, trafficState *proxy.TrafficState, ctx context.Context) error {
  143. err := func() error {
  144. visionReader := proxy.NewVisionReader(reader, trafficState, ctx)
  145. for {
  146. if trafficState.ReaderSwitchToDirectCopy {
  147. var writerConn net.Conn
  148. if inbound := session.InboundFromContext(ctx); inbound != nil && inbound.Conn != nil {
  149. writerConn = inbound.Conn
  150. if inbound.CanSpliceCopy == 2 {
  151. inbound.CanSpliceCopy = 1 // force the value to 1, don't use setter
  152. }
  153. }
  154. return proxy.CopyRawConnIfExist(ctx, conn, writerConn, writer, timer)
  155. }
  156. buffer, err := visionReader.ReadMultiBuffer()
  157. if !buffer.IsEmpty() {
  158. timer.Update()
  159. if trafficState.ReaderSwitchToDirectCopy {
  160. // XTLS Vision processes struct TLS Conn's input and rawInput
  161. if inputBuffer, err := buf.ReadFrom(input); err == nil {
  162. if !inputBuffer.IsEmpty() {
  163. buffer, _ = buf.MergeMulti(buffer, inputBuffer)
  164. }
  165. }
  166. if rawInputBuffer, err := buf.ReadFrom(rawInput); err == nil {
  167. if !rawInputBuffer.IsEmpty() {
  168. buffer, _ = buf.MergeMulti(buffer, rawInputBuffer)
  169. }
  170. }
  171. }
  172. if werr := writer.WriteMultiBuffer(buffer); werr != nil {
  173. return werr
  174. }
  175. }
  176. if err != nil {
  177. return err
  178. }
  179. }
  180. }()
  181. if err != nil && errors.Cause(err) != io.EOF {
  182. return err
  183. }
  184. return nil
  185. }
  186. // XtlsWrite filter and write xtls protocol
  187. func XtlsWrite(reader buf.Reader, writer buf.Writer, timer signal.ActivityUpdater, conn net.Conn, trafficState *proxy.TrafficState, ctx context.Context) error {
  188. err := func() error {
  189. var ct stats.Counter
  190. for {
  191. buffer, err := reader.ReadMultiBuffer()
  192. if !buffer.IsEmpty() {
  193. if ct != nil {
  194. ct.Add(int64(buffer.Len()))
  195. }
  196. timer.Update()
  197. if werr := writer.WriteMultiBuffer(buffer); werr != nil {
  198. return werr
  199. }
  200. if trafficState.WriterSwitchToDirectCopy {
  201. rawConn, _, writerCounter := proxy.UnwrapRawConn(conn)
  202. writer = buf.NewWriter(rawConn)
  203. ct = writerCounter
  204. trafficState.WriterSwitchToDirectCopy = false
  205. if inbound := session.InboundFromContext(ctx); inbound != nil && inbound.CanSpliceCopy == 2 {
  206. inbound.CanSpliceCopy = 1 // force the value to 1, don't use setter
  207. }
  208. }
  209. }
  210. if err != nil {
  211. return err
  212. }
  213. }
  214. }()
  215. if err != nil && errors.Cause(err) != io.EOF {
  216. return err
  217. }
  218. return nil
  219. }