From e0d086a8a80b95d82eb12cfabdf41783193bf833 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zolt=C3=A1n=20Papp?= Date: Wed, 10 Jul 2024 10:12:49 +0200 Subject: [PATCH] Implement dummy RemoteAddr on client conn --- relay/client/dialer/ws/addr.go | 12 ++++++++++++ relay/client/dialer/ws/conn.go | 4 ++-- relay/client/dialer/ws/ws.go | 1 + 3 files changed, 15 insertions(+), 2 deletions(-) create mode 100644 relay/client/dialer/ws/addr.go diff --git a/relay/client/dialer/ws/addr.go b/relay/client/dialer/ws/addr.go new file mode 100644 index 000000000..2bdffb864 --- /dev/null +++ b/relay/client/dialer/ws/addr.go @@ -0,0 +1,12 @@ +package ws + +type WebsocketAddr struct { +} + +func (a WebsocketAddr) Network() string { + return "websocket" +} + +func (a WebsocketAddr) String() string { + return "websocket/unknown-addr" +} diff --git a/relay/client/dialer/ws/conn.go b/relay/client/dialer/ws/conn.go index fc07fc3f3..bc8675e8e 100644 --- a/relay/client/dialer/ws/conn.go +++ b/relay/client/dialer/ws/conn.go @@ -40,11 +40,11 @@ func (c *Conn) Write(b []byte) (n int, err error) { } func (c *Conn) RemoteAddr() net.Addr { - panic("RemoteAddr is not implemented") + return WebsocketAddr{} } func (c *Conn) LocalAddr() net.Addr { - panic("LocalAddr is not implemented") + return WebsocketAddr{} } func (c *Conn) SetReadDeadline(t time.Time) error { diff --git a/relay/client/dialer/ws/ws.go b/relay/client/dialer/ws/ws.go index ccdfe2d9c..19ec44a1e 100644 --- a/relay/client/dialer/ws/ws.go +++ b/relay/client/dialer/ws/ws.go @@ -31,6 +31,7 @@ func Dial(address string) (net.Conn, error) { if resp.Body != nil { _ = resp.Body.Close() } + conn := NewConn(wsConn) return conn, nil }