generalizing websocket connection to reader/writer.
This commit is contained in:
parent
7b2523630a
commit
a6a0f287dc
@ -1,6 +1,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
@ -8,46 +9,49 @@ import (
|
|||||||
"github.com/gorilla/websocket"
|
"github.com/gorilla/websocket"
|
||||||
)
|
)
|
||||||
|
|
||||||
func handleConnection(conn net.Conn, wsURL string) {
|
func handleConnection(tcpConn net.Conn, wsURL string) {
|
||||||
defer conn.Close()
|
defer tcpConn.Close()
|
||||||
|
|
||||||
wsConn, _, err := websocket.DefaultDialer.Dial(wsURL, nil)
|
conn, _, err := websocket.DefaultDialer.Dial(wsURL, nil)
|
||||||
|
wsConn := NewWebSocketConn(conn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("WebSocket connection error:", err)
|
log.Println("WebSocket connection error:", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer wsConn.Close()
|
defer wsConn.Close()
|
||||||
|
|
||||||
|
waitChannel := make(chan bool)
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
for {
|
defer func() {
|
||||||
_, message, err := wsConn.ReadMessage()
|
waitChannel <- true
|
||||||
if err != nil {
|
}()
|
||||||
log.Println("WebSocket read error:", err)
|
_, _ = io.Copy(tcpConn, wsConn)
|
||||||
return
|
// TODO print error
|
||||||
}
|
|
||||||
_, err = conn.Write(message)
|
|
||||||
if err != nil {
|
|
||||||
log.Println("TCP write error:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
defer func() {
|
||||||
|
waitChannel <- true
|
||||||
|
}()
|
||||||
for {
|
for {
|
||||||
buffer := make([]byte, 1024)
|
buffer := make([]byte, 1024)
|
||||||
n, err := conn.Read(buffer)
|
n, err := tcpConn.Read(buffer)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err != io.EOF {
|
if err != io.EOF {
|
||||||
log.Println("TCP read error:", err)
|
log.Println("TCP read error:", err)
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
err = wsConn.WriteMessage(websocket.BinaryMessage, buffer[:n])
|
err = conn.WriteMessage(websocket.BinaryMessage, buffer[:n])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("WebSocket write error:", err)
|
log.Println("WebSocket write error:", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
<-waitChannel
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@ -72,3 +76,41 @@ func main() {
|
|||||||
go handleConnection(conn, wsURL)
|
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()
|
||||||
|
}
|
||||||
|
@ -2,11 +2,10 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/gorilla/websocket"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/gorilla/websocket"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var upgrader = websocket.Upgrader{
|
var upgrader = websocket.Upgrader{
|
||||||
@ -14,26 +13,25 @@ var upgrader = websocket.Upgrader{
|
|||||||
WriteBufferSize: 1024,
|
WriteBufferSize: 1024,
|
||||||
}
|
}
|
||||||
|
|
||||||
var tcpConn net.Conn
|
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
// Connect to TCP server
|
// Connect to TCP server
|
||||||
var err error
|
|
||||||
tcpConn, err = net.Dial("tcp", "localhost:2222") // Replace with your TCP server address
|
// Set up WebSocket handler
|
||||||
|
http.HandleFunc("/ws", func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
tcpConn, err := net.Dial("tcp", "localhost:2222") // Replace with your TCP server address
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal("Error connecting to TCP server:", err)
|
log.Fatal("Error connecting to TCP server:", err)
|
||||||
}
|
}
|
||||||
defer tcpConn.Close()
|
defer tcpConn.Close()
|
||||||
|
handleWebSocket(w, r, tcpConn)
|
||||||
// Set up WebSocket handler
|
})
|
||||||
http.HandleFunc("/ws", handleWebSocket)
|
|
||||||
|
|
||||||
// Start HTTP server
|
// Start HTTP server
|
||||||
fmt.Println("WebSocket server listening on :8000")
|
fmt.Println("WebSocket server listening on :8000")
|
||||||
log.Fatal(http.ListenAndServe(":8000", nil))
|
log.Fatal(http.ListenAndServe(":8000", nil))
|
||||||
}
|
}
|
||||||
|
|
||||||
func handleWebSocket(w http.ResponseWriter, r *http.Request) {
|
func handleWebSocket(w http.ResponseWriter, r *http.Request, tcpConn net.Conn) {
|
||||||
conn, err := upgrader.Upgrade(w, r, nil)
|
conn, err := upgrader.Upgrade(w, r, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Error upgrading to WebSocket:", err)
|
log.Println("Error upgrading to WebSocket:", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user