writer.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package mux
  2. import (
  3. "v2ray.com/core/common/buf"
  4. "v2ray.com/core/common/net"
  5. "v2ray.com/core/common/serial"
  6. )
  7. type Writer struct {
  8. id uint16
  9. dest net.Destination
  10. writer buf.Writer
  11. followup bool
  12. }
  13. func NewWriter(id uint16, dest net.Destination, writer buf.Writer) *Writer {
  14. return &Writer{
  15. id: id,
  16. dest: dest,
  17. writer: writer,
  18. followup: false,
  19. }
  20. }
  21. func NewResponseWriter(id uint16, writer buf.Writer) *Writer {
  22. return &Writer{
  23. id: id,
  24. writer: writer,
  25. followup: true,
  26. }
  27. }
  28. func (w *Writer) writeInternal(mb buf.MultiBuffer) error {
  29. meta := FrameMetadata{
  30. SessionID: w.id,
  31. Target: w.dest,
  32. }
  33. if w.followup {
  34. meta.SessionStatus = SessionStatusKeep
  35. } else {
  36. w.followup = true
  37. meta.SessionStatus = SessionStatusNew
  38. }
  39. if mb.Len() > 0 {
  40. meta.Option.Add(OptionData)
  41. }
  42. frame := buf.New()
  43. frame.AppendSupplier(meta.AsSupplier())
  44. mb2 := buf.NewMultiBuffer()
  45. mb2.Append(frame)
  46. if mb.Len() > 0 {
  47. frame.AppendSupplier(serial.WriteUint16(uint16(mb.Len())))
  48. mb2.AppendMulti(mb)
  49. }
  50. return w.writer.Write(mb2)
  51. }
  52. func (w *Writer) Write(mb buf.MultiBuffer) error {
  53. const chunkSize = 8 * 1024
  54. for !mb.IsEmpty() {
  55. slice := mb.SliceBySize(chunkSize)
  56. if err := w.writeInternal(slice); err != nil {
  57. return err
  58. }
  59. }
  60. return nil
  61. }
  62. func (w *Writer) Close() {
  63. meta := FrameMetadata{
  64. SessionID: w.id,
  65. SessionStatus: SessionStatusEnd,
  66. }
  67. frame := buf.New()
  68. frame.AppendSupplier(meta.AsSupplier())
  69. w.writer.Write(buf.NewMultiBufferValue(frame))
  70. }