connection.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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. remoteAddr net.Addr
  19. }
  20. func newConnection(conn *websocket.Conn, remoteAddr net.Addr) *connection {
  21. return &connection{
  22. conn: conn,
  23. remoteAddr: remoteAddr,
  24. }
  25. }
  26. // Read implements net.Conn.Read()
  27. func (c *connection) Read(b []byte) (int, error) {
  28. for {
  29. reader, err := c.getReader()
  30. if err != nil {
  31. return 0, err
  32. }
  33. nBytes, err := reader.Read(b)
  34. if errors.Cause(err) == io.EOF {
  35. c.reader = nil
  36. continue
  37. }
  38. return nBytes, err
  39. }
  40. }
  41. func (c *connection) getReader() (io.Reader, error) {
  42. if c.reader != nil {
  43. return c.reader, nil
  44. }
  45. _, reader, err := c.conn.NextReader()
  46. if err != nil {
  47. return nil, err
  48. }
  49. c.reader = reader
  50. return reader, nil
  51. }
  52. // Write implements io.Writer.
  53. func (c *connection) Write(b []byte) (int, error) {
  54. if err := c.conn.WriteMessage(websocket.BinaryMessage, b); err != nil {
  55. return 0, err
  56. }
  57. return len(b), nil
  58. }
  59. func (c *connection) WriteMultiBuffer(mb buf.MultiBuffer) error {
  60. mb = buf.Compact(mb)
  61. for {
  62. mb2, b := buf.SplitFirst(mb)
  63. mb = mb2
  64. if b == nil {
  65. break
  66. }
  67. if err := buf.WriteAllBytes(c, b.Bytes()); err != nil {
  68. buf.ReleaseMulti(mb)
  69. return err
  70. }
  71. }
  72. return nil
  73. }
  74. func (c *connection) Close() error {
  75. var errors []interface{}
  76. if err := c.conn.WriteControl(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""), time.Now().Add(time.Second*5)); err != nil {
  77. errors = append(errors, err)
  78. }
  79. if err := c.conn.Close(); err != nil {
  80. errors = append(errors, err)
  81. }
  82. if len(errors) > 0 {
  83. return newError("failed to close connection").Base(newError(serial.Concat(errors...)))
  84. }
  85. return nil
  86. }
  87. func (c *connection) LocalAddr() net.Addr {
  88. return c.conn.LocalAddr()
  89. }
  90. func (c *connection) RemoteAddr() net.Addr {
  91. return c.remoteAddr
  92. }
  93. func (c *connection) SetDeadline(t time.Time) error {
  94. if err := c.SetReadDeadline(t); err != nil {
  95. return err
  96. }
  97. return c.SetWriteDeadline(t)
  98. }
  99. func (c *connection) SetReadDeadline(t time.Time) error {
  100. return c.conn.SetReadDeadline(t)
  101. }
  102. func (c *connection) SetWriteDeadline(t time.Time) error {
  103. return c.conn.SetWriteDeadline(t)
  104. }