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