Skip to content

Commit

Permalink
http: Fix proxying websocket
Browse files Browse the repository at this point in the history
  • Loading branch information
nekohasekai committed Nov 13, 2024
1 parent cc7e630 commit 8937752
Showing 1 changed file with 50 additions and 11 deletions.
61 changes: 50 additions & 11 deletions protocol/http/handshake.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
std_bufio "bufio"
"context"
"encoding/base64"
"io"
"net"
"net/http"
"strings"
Expand Down Expand Up @@ -37,7 +38,6 @@ func HandleConnectionEx(ctx context.Context, conn net.Conn, reader *std_bufio.Re
if err != nil {
return E.Cause(err, "read http request")
}

if authenticator != nil {
var (
username string
Expand Down Expand Up @@ -81,11 +81,15 @@ func HandleConnectionEx(ctx context.Context, conn net.Conn, reader *std_bufio.Re
}

if request.Method == "CONNECT" {
portStr := request.URL.Port()
if portStr == "" {
portStr = "80"
destination := M.ParseSocksaddrHostPortStr(request.URL.Hostname(), request.URL.Port())
if destination.Port == 0 {
switch request.URL.Scheme {
case "https", "wss":
destination.Port = 443
default:
destination.Port = 80
}
}
destination := M.ParseSocksaddrHostPortStr(request.URL.Hostname(), portStr)
_, err = conn.Write([]byte(F.ToString("HTTP/", request.ProtoMajor, ".", request.ProtoMinor, " 200 Connection established\r\n\r\n")))
if err != nil {
return E.Cause(err, "write http response")
Expand All @@ -108,11 +112,47 @@ func HandleConnectionEx(ctx context.Context, conn net.Conn, reader *std_bufio.Re
handlerEx.NewConnectionEx(ctx, requestConn, source, destination, onClose)
return nil
}
}

err = handleHTTPConnection(ctx, handler, handlerEx, conn, request, source)
if err != nil {
return err
} else if strings.ToLower(request.Header.Get("Connection")) == "upgrade" {
destination := M.ParseSocksaddrHostPortStr(request.URL.Hostname(), request.URL.Port())
if destination.Port == 0 {
switch request.URL.Scheme {
case "https", "wss":
destination.Port = 443
default:
destination.Port = 80
}
}
serverConn, clientConn := pipe.Pipe()
go func() {
if handler != nil {
err := handler.NewConnection(ctx, clientConn, M.Metadata{Protocol: "http", Source: source, Destination: destination})

Check failure on line 128 in protocol/http/handshake.go

View workflow job for this annotation

GitHub Actions / Build

SA1019: M.Metadata is deprecated: wtf is this? (staticcheck)
if err != nil {
common.Close(serverConn, clientConn)
}
} else {
handlerEx.NewConnectionEx(ctx, clientConn, source, destination, func(it error) {
if it != nil {
common.Close(serverConn, clientConn)
}
})
}
}()
err = request.Write(serverConn)
if err != nil {
return E.Cause(err, "http: write upgrade request")
}
if reader.Buffered() > 0 {
_, err = io.CopyN(serverConn, reader, int64(reader.Buffered()))
if err != nil {
return err
}
}
return bufio.CopyConn(ctx, conn, serverConn)
} else {
err = handleHTTPConnection(ctx, handler, handlerEx, conn, request, source)
if err != nil {
return err
}
}
}
}
Expand Down Expand Up @@ -198,7 +238,6 @@ func handleHTTPConnection(
if !keepAlive {
return conn.Close()
}

return nil
}

Expand Down

0 comments on commit 8937752

Please sign in to comment.