[tor-commits] [snowflake/master] Implement net.Conn for websocketconn.Conn.
dcf at torproject.org
dcf at torproject.org
Tue Feb 4 22:54:15 UTC 2020
commit 256959ca6594dddd9fe5b012680b4f0235401cd9
Author: David Fifield <david at bamsoftware.com>
Date: Mon Feb 3 13:22:03 2020 -0700
Implement net.Conn for websocketconn.Conn.
We had already implemented Read, Write, and Close. Pass RemoteAddr,
LocalAddr, SetReadDeadline, and SetWriteDeadline through to the
underlying *websocket.Conn. Implement SetDeadline by calling both
SetReadDeadline and SetWriteDeadline.
https://bugs.torproject.org/33144
---
common/websocketconn/websocketconn.go | 25 ++++++++++++++++---------
1 file changed, 16 insertions(+), 9 deletions(-)
diff --git a/common/websocketconn/websocketconn.go b/common/websocketconn/websocketconn.go
index fa2b0da..73c2b25 100644
--- a/common/websocketconn/websocketconn.go
+++ b/common/websocketconn/websocketconn.go
@@ -7,29 +7,36 @@ import (
"github.com/gorilla/websocket"
)
-// An abstraction that makes an underlying WebSocket connection look like an
-// io.ReadWriteCloser.
+// An abstraction that makes an underlying WebSocket connection look like a
+// net.Conn.
type Conn struct {
- ws *websocket.Conn
+ *websocket.Conn
Reader io.Reader
Writer io.Writer
}
-// Implements io.Reader.
func (conn *Conn) Read(b []byte) (n int, err error) {
return conn.Reader.Read(b)
}
-// Implements io.Writer.
func (conn *Conn) Write(b []byte) (n int, err error) {
return conn.Writer.Write(b)
}
-// Implements io.Closer.
func (conn *Conn) Close() error {
// Ignore any error in trying to write a Close frame.
- _ = conn.ws.WriteControl(websocket.CloseMessage, []byte{}, time.Now().Add(time.Second))
- return conn.ws.Close()
+ _ = conn.Conn.WriteControl(websocket.CloseMessage, []byte{}, time.Now().Add(time.Second))
+ return conn.Conn.Close()
+}
+
+func (conn *Conn) SetDeadline(t time.Time) error {
+ errRead := conn.Conn.SetReadDeadline(t)
+ errWrite := conn.Conn.SetWriteDeadline(t)
+ err := errRead
+ if err == nil {
+ err = errWrite
+ }
+ return err
}
func readLoop(w io.Writer, ws *websocket.Conn) error {
@@ -105,7 +112,7 @@ func New(ws *websocket.Conn) *Conn {
pr2.CloseWithError(closeErrorToEOF(writeLoop(ws, pr2)))
}()
return &Conn{
- ws: ws,
+ Conn: ws,
Reader: pr1,
Writer: pw2,
}
More information about the tor-commits
mailing list