addons.go 4.6 KB

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