addons.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. package encoding
  2. import (
  3. "context"
  4. "io"
  5. "github.com/xtls/xray-core/common/buf"
  6. "github.com/xtls/xray-core/common/protocol"
  7. "github.com/xtls/xray-core/proxy"
  8. "github.com/xtls/xray-core/proxy/vless"
  9. "google.golang.org/protobuf/proto"
  10. )
  11. func EncodeHeaderAddons(buffer *buf.Buffer, addons *Addons) error {
  12. switch addons.Flow {
  13. case vless.XRV:
  14. bytes, err := proto.Marshal(addons)
  15. if err != nil {
  16. return newError("failed to marshal addons protobuf value").Base(err)
  17. }
  18. if err := buffer.WriteByte(byte(len(bytes))); err != nil {
  19. return newError("failed to write addons protobuf length").Base(err)
  20. }
  21. if _, err := buffer.Write(bytes); err != nil {
  22. return newError("failed to write addons protobuf value").Base(err)
  23. }
  24. default:
  25. if err := buffer.WriteByte(0); err != nil {
  26. return newError("failed to write addons protobuf length").Base(err)
  27. }
  28. }
  29. return nil
  30. }
  31. func DecodeHeaderAddons(buffer *buf.Buffer, reader io.Reader) (*Addons, error) {
  32. addons := new(Addons)
  33. buffer.Clear()
  34. if _, err := buffer.ReadFullFrom(reader, 1); err != nil {
  35. return nil, newError("failed to read addons protobuf length").Base(err)
  36. }
  37. if length := int32(buffer.Byte(0)); length != 0 {
  38. buffer.Clear()
  39. if _, err := buffer.ReadFullFrom(reader, length); err != nil {
  40. return nil, newError("failed to read addons protobuf value").Base(err)
  41. }
  42. if err := proto.Unmarshal(buffer.Bytes(), addons); err != nil {
  43. return nil, newError("failed to unmarshal addons protobuf value").Base(err)
  44. }
  45. // Verification.
  46. switch addons.Flow {
  47. default:
  48. }
  49. }
  50. return addons, nil
  51. }
  52. // EncodeBodyAddons returns a Writer that auto-encrypt content written by caller.
  53. func EncodeBodyAddons(writer io.Writer, request *protocol.RequestHeader, requestAddons *Addons, state *proxy.TrafficState, context context.Context) buf.Writer {
  54. if request.Command == protocol.RequestCommandUDP {
  55. return NewMultiLengthPacketWriter(writer.(buf.Writer))
  56. }
  57. w := buf.NewWriter(writer)
  58. if requestAddons.Flow == vless.XRV {
  59. w = proxy.NewVisionWriter(w, state, context)
  60. }
  61. return w
  62. }
  63. // DecodeBodyAddons returns a Reader from which caller can fetch decrypted body.
  64. func DecodeBodyAddons(reader io.Reader, request *protocol.RequestHeader, addons *Addons) buf.Reader {
  65. switch addons.Flow {
  66. default:
  67. if request.Command == protocol.RequestCommandUDP {
  68. return NewLengthPacketReader(reader)
  69. }
  70. }
  71. return buf.NewReader(reader)
  72. }
  73. func NewMultiLengthPacketWriter(writer buf.Writer) *MultiLengthPacketWriter {
  74. return &MultiLengthPacketWriter{
  75. Writer: writer,
  76. }
  77. }
  78. type MultiLengthPacketWriter struct {
  79. buf.Writer
  80. }
  81. func (w *MultiLengthPacketWriter) WriteMultiBuffer(mb buf.MultiBuffer) error {
  82. defer buf.ReleaseMulti(mb)
  83. mb2Write := make(buf.MultiBuffer, 0, len(mb)+1)
  84. for _, b := range mb {
  85. length := b.Len()
  86. if length == 0 || length+2 > buf.Size {
  87. continue
  88. }
  89. eb := buf.New()
  90. if err := eb.WriteByte(byte(length >> 8)); err != nil {
  91. eb.Release()
  92. continue
  93. }
  94. if err := eb.WriteByte(byte(length)); err != nil {
  95. eb.Release()
  96. continue
  97. }
  98. if _, err := eb.Write(b.Bytes()); err != nil {
  99. eb.Release()
  100. continue
  101. }
  102. mb2Write = append(mb2Write, eb)
  103. }
  104. if mb2Write.IsEmpty() {
  105. return nil
  106. }
  107. return w.Writer.WriteMultiBuffer(mb2Write)
  108. }
  109. func NewLengthPacketWriter(writer io.Writer) *LengthPacketWriter {
  110. return &LengthPacketWriter{
  111. Writer: writer,
  112. cache: make([]byte, 0, 65536),
  113. }
  114. }
  115. type LengthPacketWriter struct {
  116. io.Writer
  117. cache []byte
  118. }
  119. func (w *LengthPacketWriter) WriteMultiBuffer(mb buf.MultiBuffer) error {
  120. length := mb.Len() // none of mb is nil
  121. // fmt.Println("Write", length)
  122. if length == 0 {
  123. return nil
  124. }
  125. defer func() {
  126. w.cache = w.cache[:0]
  127. }()
  128. w.cache = append(w.cache, byte(length>>8), byte(length))
  129. for i, b := range mb {
  130. w.cache = append(w.cache, b.Bytes()...)
  131. b.Release()
  132. mb[i] = nil
  133. }
  134. if _, err := w.Write(w.cache); err != nil {
  135. return newError("failed to write a packet").Base(err)
  136. }
  137. return nil
  138. }
  139. func NewLengthPacketReader(reader io.Reader) *LengthPacketReader {
  140. return &LengthPacketReader{
  141. Reader: reader,
  142. cache: make([]byte, 2),
  143. }
  144. }
  145. type LengthPacketReader struct {
  146. io.Reader
  147. cache []byte
  148. }
  149. func (r *LengthPacketReader) ReadMultiBuffer() (buf.MultiBuffer, error) {
  150. if _, err := io.ReadFull(r.Reader, r.cache); err != nil { // maybe EOF
  151. return nil, newError("failed to read packet length").Base(err)
  152. }
  153. length := int32(r.cache[0])<<8 | int32(r.cache[1])
  154. // fmt.Println("Read", length)
  155. mb := make(buf.MultiBuffer, 0, length/buf.Size+1)
  156. for length > 0 {
  157. size := length
  158. if size > buf.Size {
  159. size = buf.Size
  160. }
  161. length -= size
  162. b := buf.New()
  163. if _, err := b.ReadFullFrom(r.Reader, size); err != nil {
  164. return nil, newError("failed to read packet payload").Base(err)
  165. }
  166. mb = append(mb, b)
  167. }
  168. return mb, nil
  169. }