connection.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package websocket
  2. import (
  3. "io"
  4. "net"
  5. "time"
  6. "github.com/gorilla/websocket"
  7. "v2ray.com/core/common/buf"
  8. "v2ray.com/core/common/errors"
  9. "v2ray.com/core/common/serial"
  10. )
  11. var (
  12. _ buf.Writer = (*connection)(nil)
  13. )
  14. // connection is a wrapper for net.Conn over WebSocket connection.
  15. type connection struct {
  16. conn *websocket.Conn
  17. reader io.Reader
  18. mergingWriter *buf.BufferedWriter
  19. remoteAddr net.Addr
  20. }
  21. func newConnection(conn *websocket.Conn, remoteAddr net.Addr) *connection {
  22. return &connection{
  23. conn: conn,
  24. remoteAddr: remoteAddr,
  25. }
  26. }
  27. // Read implements net.Conn.Read()
  28. func (c *connection) Read(b []byte) (int, error) {
  29. for {
  30. reader, err := c.getReader()
  31. if err != nil {
  32. return 0, err
  33. }
  34. nBytes, err := reader.Read(b)
  35. if errors.Cause(err) == io.EOF {
  36. c.reader = nil
  37. continue
  38. }
  39. return nBytes, err
  40. }
  41. }
  42. func (c *connection) getReader() (io.Reader, error) {
  43. if c.reader != nil {
  44. return c.reader, nil
  45. }
  46. _, reader, err := c.conn.NextReader()
  47. if err != nil {
  48. return nil, err
  49. }
  50. c.reader = reader
  51. return reader, nil
  52. }
  53. // Write implements io.Writer.
  54. func (c *connection) Write(b []byte) (int, error) {
  55. if err := c.conn.WriteMessage(websocket.BinaryMessage, b); err != nil {
  56. return 0, err
  57. }
  58. return len(b), nil
  59. }
  60. func (c *connection) WriteMultiBuffer(mb buf.MultiBuffer) error {
  61. if c.mergingWriter == nil {
  62. c.mergingWriter = buf.NewBufferedWriter(&buf.BufferToBytesWriter{Writer: c})
  63. }
  64. if err := c.mergingWriter.WriteMultiBuffer(mb); err != nil {
  65. return err
  66. }
  67. return c.mergingWriter.Flush()
  68. }
  69. func (c *connection) Close() error {
  70. var errors []interface{}
  71. if err := c.conn.WriteControl(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""), time.Now().Add(time.Second*5)); err != nil {
  72. errors = append(errors, err)
  73. }
  74. if err := c.conn.Close(); err != nil {
  75. errors = append(errors, err)
  76. }
  77. if len(errors) > 0 {
  78. return newError("failed to close connection").Base(newError(serial.Concat(errors...)))
  79. }
  80. return nil
  81. }
  82. func (c *connection) LocalAddr() net.Addr {
  83. return c.conn.LocalAddr()
  84. }
  85. func (c *connection) RemoteAddr() net.Addr {
  86. return c.remoteAddr
  87. }
  88. func (c *connection) SetDeadline(t time.Time) error {
  89. if err := c.SetReadDeadline(t); err != nil {
  90. return err
  91. }
  92. return c.SetWriteDeadline(t)
  93. }
  94. func (c *connection) SetReadDeadline(t time.Time) error {
  95. return c.conn.SetReadDeadline(t)
  96. }
  97. func (c *connection) SetWriteDeadline(t time.Time) error {
  98. return c.conn.SetWriteDeadline(t)
  99. }