moved websocket wrapper to iowrappers package.
This commit is contained in:
parent
46a7588896
commit
188d949d65
@ -1,19 +1,18 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"cidebug/pkg/iowrappers"
|
||||
"github.com/gorilla/websocket"
|
||||
"io"
|
||||
"log"
|
||||
"net"
|
||||
|
||||
"github.com/gorilla/websocket"
|
||||
)
|
||||
|
||||
func handleConnection(tcpConn net.Conn, wsURL string) {
|
||||
defer tcpConn.Close()
|
||||
|
||||
conn, _, err := websocket.DefaultDialer.Dial(wsURL, nil)
|
||||
wsConn := NewWebSocketConn(conn)
|
||||
wsConn := iowrappers.NewWebSocketConn(conn)
|
||||
if err != nil {
|
||||
log.Println("WebSocket connection error:", err)
|
||||
return
|
||||
@ -26,29 +25,18 @@ func handleConnection(tcpConn net.Conn, wsURL string) {
|
||||
defer func() {
|
||||
waitChannel <- true
|
||||
}()
|
||||
_, _ = io.Copy(tcpConn, wsConn)
|
||||
// TODO print error
|
||||
_, err = io.Copy(tcpConn, wsConn)
|
||||
if err != nil {
|
||||
log.Printf("error %v", err)
|
||||
}
|
||||
}()
|
||||
|
||||
go func() {
|
||||
defer func() {
|
||||
waitChannel <- true
|
||||
}()
|
||||
for {
|
||||
buffer := make([]byte, 1024)
|
||||
n, err := tcpConn.Read(buffer)
|
||||
if err != nil {
|
||||
if err != io.EOF {
|
||||
log.Println("TCP read error:", err)
|
||||
}
|
||||
return
|
||||
}
|
||||
err = conn.WriteMessage(websocket.BinaryMessage, buffer[:n])
|
||||
if err != nil {
|
||||
log.Println("WebSocket write error:", err)
|
||||
return
|
||||
}
|
||||
}
|
||||
_, err = io.Copy(wsConn, tcpConn)
|
||||
log.Printf("Error %v", err)
|
||||
}()
|
||||
|
||||
<-waitChannel
|
||||
@ -76,41 +64,3 @@ func main() {
|
||||
go handleConnection(conn, wsURL)
|
||||
}
|
||||
}
|
||||
|
||||
type WebSocketConn struct {
|
||||
conn *websocket.Conn
|
||||
buf []byte
|
||||
}
|
||||
|
||||
func NewWebSocketConn(conn *websocket.Conn) *WebSocketConn {
|
||||
return &WebSocketConn{conn: conn}
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Read(p []byte) (n int, err error) {
|
||||
if len(websocketConn.buf) == 0 {
|
||||
_, message, err := websocketConn.conn.ReadMessage()
|
||||
fmt.Println("Got message ", message)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
websocketConn.buf = message
|
||||
}
|
||||
|
||||
n = copy(p, websocketConn.buf)
|
||||
websocketConn.buf = websocketConn.buf[n:]
|
||||
|
||||
log.Println("Read ", n, " bytes")
|
||||
return n, err
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Write(p []byte) (n int, err error) {
|
||||
err = websocketConn.conn.WriteMessage(websocket.BinaryMessage, p)
|
||||
if err != nil {
|
||||
n = len(p)
|
||||
}
|
||||
return n, err
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Close() error {
|
||||
return websocketConn.conn.Close()
|
||||
}
|
||||
|
39
pkg/iowrappers/io.go
Normal file
39
pkg/iowrappers/io.go
Normal file
@ -0,0 +1,39 @@
|
||||
package iowrappers
|
||||
|
||||
import "github.com/gorilla/websocket"
|
||||
|
||||
type WebSocketConn struct {
|
||||
conn *websocket.Conn
|
||||
buf []byte
|
||||
}
|
||||
|
||||
func NewWebSocketConn(conn *websocket.Conn) *WebSocketConn {
|
||||
return &WebSocketConn{conn: conn}
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Read(p []byte) (n int, err error) {
|
||||
if len(websocketConn.buf) == 0 {
|
||||
_, message, err := websocketConn.conn.ReadMessage()
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
websocketConn.buf = message
|
||||
}
|
||||
|
||||
n = copy(p, websocketConn.buf)
|
||||
websocketConn.buf = websocketConn.buf[n:]
|
||||
|
||||
return n, err
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Write(p []byte) (n int, err error) {
|
||||
err = websocketConn.conn.WriteMessage(websocket.BinaryMessage, p)
|
||||
if err == nil {
|
||||
n = len(p)
|
||||
}
|
||||
return n, err
|
||||
}
|
||||
|
||||
func (websocketConn *WebSocketConn) Close() error {
|
||||
return websocketConn.conn.Close()
|
||||
}
|
Loading…
Reference in New Issue
Block a user