mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-23 10:45:49 +03:00
Merge pull request #1356 from mholt/fix_hijack
proxy: Fixed #1352: invalid use of the HTTP hijacker
This commit is contained in:
commit
696b46f075
1 changed files with 18 additions and 3 deletions
|
@ -238,7 +238,7 @@ func (rp *ReverseProxy) ServeHTTP(rw http.ResponseWriter, outreq *http.Request,
|
||||||
panic(httpserver.NonHijackerError{Underlying: rw})
|
panic(httpserver.NonHijackerError{Underlying: rw})
|
||||||
}
|
}
|
||||||
|
|
||||||
conn, _, err := hj.Hijack()
|
conn, brw, err := hj.Hijack()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -260,8 +260,23 @@ func (rp *ReverseProxy) ServeHTTP(rw http.ResponseWriter, outreq *http.Request,
|
||||||
}
|
}
|
||||||
defer backendConn.Close()
|
defer backendConn.Close()
|
||||||
|
|
||||||
go pooledIoCopy(backendConn, conn) // write tcp stream to backend
|
// Proxy backend -> frontend.
|
||||||
pooledIoCopy(conn, backendConn) // read tcp stream from backend
|
go pooledIoCopy(conn, backendConn)
|
||||||
|
|
||||||
|
// Proxy frontend -> backend.
|
||||||
|
//
|
||||||
|
// NOTE: Hijack() sometimes returns buffered up bytes in brw which
|
||||||
|
// would be lost if we didn't read them out manually below.
|
||||||
|
if brw != nil {
|
||||||
|
if n := brw.Reader.Buffered(); n > 0 {
|
||||||
|
rbuf, err := brw.Reader.Peek(n)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
backendConn.Write(rbuf)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pooledIoCopy(backendConn, conn)
|
||||||
} else {
|
} else {
|
||||||
copyHeader(rw.Header(), res.Header)
|
copyHeader(rw.Header(), res.Header)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue