reader.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package mux
  2. import (
  3. "io"
  4. "v2ray.com/core/common/buf"
  5. "v2ray.com/core/common/crypto"
  6. "v2ray.com/core/common/serial"
  7. )
  8. // ReadMetadata reads FrameMetadata from the given reader.
  9. func ReadMetadata(reader io.Reader) (*FrameMetadata, error) {
  10. metaLen, err := serial.ReadUint16(reader)
  11. if err != nil {
  12. return nil, err
  13. }
  14. if metaLen > 512 {
  15. return nil, newError("invalid metalen ", metaLen).AtError()
  16. }
  17. b := buf.New()
  18. defer b.Release()
  19. if err := b.Reset(buf.ReadFullFrom(reader, int32(metaLen))); err != nil {
  20. return nil, err
  21. }
  22. return ReadFrameFrom(b)
  23. }
  24. // PacketReader is an io.Reader that reads whole chunk of Mux frames every time.
  25. type PacketReader struct {
  26. reader io.Reader
  27. eof bool
  28. }
  29. // NewPacketReader creates a new PacketReader.
  30. func NewPacketReader(reader io.Reader) *PacketReader {
  31. return &PacketReader{
  32. reader: reader,
  33. eof: false,
  34. }
  35. }
  36. // ReadMultiBuffer implements buf.Reader.
  37. func (r *PacketReader) ReadMultiBuffer() (buf.MultiBuffer, error) {
  38. if r.eof {
  39. return nil, io.EOF
  40. }
  41. size, err := serial.ReadUint16(r.reader)
  42. if err != nil {
  43. return nil, err
  44. }
  45. if size > buf.Size {
  46. return nil, newError("packet size too large: ", size)
  47. }
  48. b := buf.New()
  49. if err := b.Reset(buf.ReadFullFrom(r.reader, int32(size))); err != nil {
  50. b.Release()
  51. return nil, err
  52. }
  53. r.eof = true
  54. return buf.NewMultiBufferValue(b), nil
  55. }
  56. // NewStreamReader creates a new StreamReader.
  57. func NewStreamReader(reader *buf.BufferedReader) buf.Reader {
  58. return crypto.NewChunkStreamReaderWithChunkCount(crypto.PlainChunkSizeParser{}, reader, 1)
  59. }