| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | 
							- package mux
 
- import (
 
- 	"v2ray.com/core/common/buf"
 
- 	"v2ray.com/core/common/net"
 
- 	"v2ray.com/core/common/serial"
 
- )
 
- type Writer struct {
 
- 	id       uint16
 
- 	dest     net.Destination
 
- 	writer   buf.Writer
 
- 	followup bool
 
- }
 
- func NewWriter(id uint16, dest net.Destination, writer buf.Writer) *Writer {
 
- 	return &Writer{
 
- 		id:     id,
 
- 		dest:   dest,
 
- 		writer: writer,
 
- 	}
 
- }
 
- func NewResponseWriter(id uint16, writer buf.Writer) *Writer {
 
- 	return &Writer{
 
- 		id:       id,
 
- 		writer:   writer,
 
- 		followup: true,
 
- 	}
 
- }
 
- func (w *Writer) Write(mb buf.MultiBuffer) error {
 
- 	meta := FrameMetadata{
 
- 		SessionID: w.id,
 
- 		Target:    w.dest,
 
- 	}
 
- 	if w.followup {
 
- 		meta.SessionStatus = SessionStatusKeep
 
- 	} else {
 
- 		w.followup = true
 
- 		meta.SessionStatus = SessionStatusNew
 
- 	}
 
- 	if mb.Len() > 0 {
 
- 		meta.Option.Add(OptionData)
 
- 	}
 
- 	frame := buf.New()
 
- 	frame.AppendSupplier(meta.AsSupplier())
 
- 	mb2 := buf.NewMultiBuffer()
 
- 	mb2.Append(frame)
 
- 	if mb.Len() > 0 {
 
- 		frame.AppendSupplier(serial.WriteUint16(uint16(mb.Len())))
 
- 		mb2.AppendMulti(mb)
 
- 	}
 
- 	return w.writer.Write(mb2)
 
- }
 
- func (w *Writer) Close() {
 
- 	meta := FrameMetadata{
 
- 		SessionID:     w.id,
 
- 		SessionStatus: SessionStatusEnd,
 
- 	}
 
- 	frame := buf.New()
 
- 	frame.AppendSupplier(meta.AsSupplier())
 
- 	w.writer.Write(buf.NewMultiBufferValue(frame))
 
- }
 
 
  |