mirror of https://github.com/v2ray/v2ray-core
				
				
				
			refactor websocket
							parent
							
								
									020b436827
								
							
						
					
					
						commit
						935620104d
					
				|  | @ -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 &wsconn{ | ||||
| 	return &connection{ | ||||
| 		wsc: conn, | ||||
| 	}, nil | ||||
| } | ||||
|  |  | |||
|  | @ -115,7 +115,7 @@ func (ln *Listener) listenws(address v2net.Address, port v2net.Port) error { | |||
| 	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{ | ||||
| 		ReadBufferSize:  32 * 1024, | ||||
| 		WriteBufferSize: 32 * 1024, | ||||
|  | @ -126,7 +126,7 @@ func converttovws(w http.ResponseWriter, r *http.Request) (*wsconn, error) { | |||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	return &wsconn{wsc: conn}, nil | ||||
| 	return &connection{wsc: conn}, nil | ||||
| } | ||||
| 
 | ||||
| func (ln *Listener) Accept() (internet.Connection, error) { | ||||
|  |  | |||
|  | @ -9,12 +9,14 @@ import ( | |||
| 	"v2ray.com/core/common/errors" | ||||
| ) | ||||
| 
 | ||||
| type wsconn struct { | ||||
| // connection is a wrapper for net.Conn over WebSocket connection.
 | ||||
| type connection struct { | ||||
| 	wsc    *websocket.Conn | ||||
| 	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 { | ||||
| 		reader, err := c.getReader() | ||||
| 		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 { | ||||
| 		return c.reader, nil | ||||
| 	} | ||||
|  | @ -43,37 +45,37 @@ func (c *wsconn) getReader() (io.Reader, error) { | |||
| 	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 { | ||||
| 		return 0, err | ||||
| 	} | ||||
| 	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)) | ||||
| 	return c.wsc.Close() | ||||
| } | ||||
| 
 | ||||
| func (c *wsconn) LocalAddr() net.Addr { | ||||
| func (c *connection) LocalAddr() net.Addr { | ||||
| 	return c.wsc.LocalAddr() | ||||
| } | ||||
| 
 | ||||
| func (c *wsconn) RemoteAddr() net.Addr { | ||||
| func (c *connection) RemoteAddr() net.Addr { | ||||
| 	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 { | ||||
| 		return err | ||||
| 	} | ||||
| 	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) | ||||
| } | ||||
| 
 | ||||
| func (c *wsconn) SetWriteDeadline(t time.Time) error { | ||||
| func (c *connection) SetWriteDeadline(t time.Time) error { | ||||
| 	return c.wsc.SetWriteDeadline(t) | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Darien Raymond
						Darien Raymond