encoding.go 7.9 KB

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