encoding.go 7.0 KB

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