now with websockets

This commit is contained in:
Para Dox
2025-05-01 14:20:31 +07:00
parent 25502ae1a1
commit f2b642c20d

View File

@@ -492,12 +492,33 @@ func handleWebSocketRequest(w http.ResponseWriter, r *http.Request, backends []B
backendURL := strings.Replace(b.URL, "http://", "ws://", 1) backendURL := strings.Replace(b.URL, "http://", "ws://", 1)
backendURL = strings.Replace(backendURL, "https://", "wss://", 1) backendURL = strings.Replace(backendURL, "https://", "wss://", 1)
// Copy headers for the dialer // Create a clean header map for the dialer
// Instead of copying all headers which can cause duplicates
header := http.Header{} header := http.Header{}
for name, values := range r.Header {
for _, value := range values { // Only copy specific headers needed for the WebSocket connection
header.Add(name, value) // and avoid the problematic ones like "Connection" and "Upgrade"
if host := r.Header.Get("Host"); host != "" {
header.Set("Host", host)
} }
if origin := r.Header.Get("Origin"); origin != "" {
header.Set("Origin", origin)
}
if secWebSocketKey := r.Header.Get("Sec-WebSocket-Key"); secWebSocketKey != "" {
header.Set("Sec-WebSocket-Key", secWebSocketKey)
}
if secWebSocketVersion := r.Header.Get("Sec-WebSocket-Version"); secWebSocketVersion != "" {
header.Set("Sec-WebSocket-Version", secWebSocketVersion)
}
if secWebSocketProtocol := r.Header.Get("Sec-WebSocket-Protocol"); secWebSocketProtocol != "" {
header.Set("Sec-WebSocket-Protocol", secWebSocketProtocol)
}
if secWebSocketExtensions := r.Header.Get("Sec-WebSocket-Extensions"); secWebSocketExtensions != "" {
header.Set("Sec-WebSocket-Extensions", secWebSocketExtensions)
}
// Add user-agent if present
if userAgent := r.Header.Get("User-Agent"); userAgent != "" {
header.Set("User-Agent", userAgent)
} }
startTime := time.Now() startTime := time.Now()