refactor websocket

pull/432/head
Darien Raymond 2017-02-16 16:53:31 +01:00
parent 020b436827
commit 935620104d
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
3 changed files with 15 additions and 13 deletions

View File

@ -85,7 +85,7 @@ func wsDial(ctx context.Context, dest v2net.Destination) (net.Conn, error) {
return nil, errors.Base(err).Message("WebSocket|Dialer: Failed to dial to (", uri, "): ", reason) return nil, errors.Base(err).Message("WebSocket|Dialer: Failed to dial to (", uri, "): ", reason)
} }
return &wsconn{ return &connection{
wsc: conn, wsc: conn,
}, nil }, nil
} }

View File

@ -115,7 +115,7 @@ func (ln *Listener) listenws(address v2net.Address, port v2net.Port) error {
return nil return nil
} }
func converttovws(w http.ResponseWriter, r *http.Request) (*wsconn, error) { func converttovws(w http.ResponseWriter, r *http.Request) (*connection, error) {
var upgrader = websocket.Upgrader{ var upgrader = websocket.Upgrader{
ReadBufferSize: 32 * 1024, ReadBufferSize: 32 * 1024,
WriteBufferSize: 32 * 1024, WriteBufferSize: 32 * 1024,
@ -126,7 +126,7 @@ func converttovws(w http.ResponseWriter, r *http.Request) (*wsconn, error) {
return nil, err return nil, err
} }
return &wsconn{wsc: conn}, nil return &connection{wsc: conn}, nil
} }
func (ln *Listener) Accept() (internet.Connection, error) { func (ln *Listener) Accept() (internet.Connection, error) {

View File

@ -9,12 +9,14 @@ import (
"v2ray.com/core/common/errors" "v2ray.com/core/common/errors"
) )
type wsconn struct { // connection is a wrapper for net.Conn over WebSocket connection.
type connection struct {
wsc *websocket.Conn wsc *websocket.Conn
reader io.Reader reader io.Reader
} }
func (c *wsconn) Read(b []byte) (int, error) { // Read implements net.Conn.Read()
func (c *connection) Read(b []byte) (int, error) {
for { for {
reader, err := c.getReader() reader, err := c.getReader()
if err != nil { if err != nil {
@ -30,7 +32,7 @@ func (c *wsconn) Read(b []byte) (int, error) {
} }
} }
func (c *wsconn) getReader() (io.Reader, error) { func (c *connection) getReader() (io.Reader, error) {
if c.reader != nil { if c.reader != nil {
return c.reader, nil return c.reader, nil
} }
@ -43,37 +45,37 @@ func (c *wsconn) getReader() (io.Reader, error) {
return reader, nil return reader, nil
} }
func (c *wsconn) Write(b []byte) (int, error) { func (c *connection) Write(b []byte) (int, error) {
if err := c.wsc.WriteMessage(websocket.BinaryMessage, b); err != nil { if err := c.wsc.WriteMessage(websocket.BinaryMessage, b); err != nil {
return 0, err return 0, err
} }
return len(b), nil return len(b), nil
} }
func (c *wsconn) Close() error { func (c *connection) Close() error {
c.wsc.WriteControl(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""), time.Now().Add(time.Second*5)) c.wsc.WriteControl(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, ""), time.Now().Add(time.Second*5))
return c.wsc.Close() return c.wsc.Close()
} }
func (c *wsconn) LocalAddr() net.Addr { func (c *connection) LocalAddr() net.Addr {
return c.wsc.LocalAddr() return c.wsc.LocalAddr()
} }
func (c *wsconn) RemoteAddr() net.Addr { func (c *connection) RemoteAddr() net.Addr {
return c.wsc.RemoteAddr() return c.wsc.RemoteAddr()
} }
func (c *wsconn) SetDeadline(t time.Time) error { func (c *connection) SetDeadline(t time.Time) error {
if err := c.SetReadDeadline(t); err != nil { if err := c.SetReadDeadline(t); err != nil {
return err return err
} }
return c.SetWriteDeadline(t) return c.SetWriteDeadline(t)
} }
func (c *wsconn) SetReadDeadline(t time.Time) error { func (c *connection) SetReadDeadline(t time.Time) error {
return c.wsc.SetReadDeadline(t) return c.wsc.SetReadDeadline(t)
} }
func (c *wsconn) SetWriteDeadline(t time.Time) error { func (c *connection) SetWriteDeadline(t time.Time) error {
return c.wsc.SetWriteDeadline(t) return c.wsc.SetWriteDeadline(t)
} }