Re-add missing writeheader call in flush
Co-authored-by: Kevin Pollet <pollet.kevin@gmail.com>
This commit is contained in:
parent
0ecd85cc66
commit
55addfefc8
1 changed files with 9 additions and 19 deletions
|
@ -138,7 +138,6 @@ type codeCatcher struct {
|
||||||
headerMap http.Header
|
headerMap http.Header
|
||||||
code int
|
code int
|
||||||
httpCodeRanges types.HTTPCodeRanges
|
httpCodeRanges types.HTTPCodeRanges
|
||||||
firstWrite bool
|
|
||||||
caughtFilteredCode bool
|
caughtFilteredCode bool
|
||||||
responseWriter http.ResponseWriter
|
responseWriter http.ResponseWriter
|
||||||
headersSent bool
|
headersSent bool
|
||||||
|
@ -160,7 +159,6 @@ func newCodeCatcher(rw http.ResponseWriter, httpCodeRanges types.HTTPCodeRanges)
|
||||||
code: http.StatusOK, // If backend does not call WriteHeader on us, we consider it's a 200.
|
code: http.StatusOK, // If backend does not call WriteHeader on us, we consider it's a 200.
|
||||||
responseWriter: rw,
|
responseWriter: rw,
|
||||||
httpCodeRanges: httpCodeRanges,
|
httpCodeRanges: httpCodeRanges,
|
||||||
firstWrite: true,
|
|
||||||
}
|
}
|
||||||
if _, ok := rw.(http.CloseNotifier); ok {
|
if _, ok := rw.(http.CloseNotifier); ok {
|
||||||
return &codeCatcherWithCloseNotify{catcher}
|
return &codeCatcherWithCloseNotify{catcher}
|
||||||
|
@ -187,22 +185,14 @@ func (cc *codeCatcher) isFilteredCode() bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (cc *codeCatcher) Write(buf []byte) (int, error) {
|
func (cc *codeCatcher) Write(buf []byte) (int, error) {
|
||||||
if !cc.firstWrite {
|
|
||||||
if cc.caughtFilteredCode {
|
|
||||||
// We don't care about the contents of the response,
|
|
||||||
// since we want to serve the ones from the error page,
|
|
||||||
// so we just drop them.
|
|
||||||
return len(buf), nil
|
|
||||||
}
|
|
||||||
return cc.responseWriter.Write(buf)
|
|
||||||
}
|
|
||||||
cc.firstWrite = false
|
|
||||||
|
|
||||||
// If WriteHeader was already called from the caller, this is a NOOP.
|
// If WriteHeader was already called from the caller, this is a NOOP.
|
||||||
// Otherwise, cc.code is actually a 200 here.
|
// Otherwise, cc.code is actually a 200 here.
|
||||||
cc.WriteHeader(cc.code)
|
cc.WriteHeader(cc.code)
|
||||||
|
|
||||||
if cc.caughtFilteredCode {
|
if cc.caughtFilteredCode {
|
||||||
|
// We don't care about the contents of the response,
|
||||||
|
// since we want to serve the ones from the error page,
|
||||||
|
// so we just drop them.
|
||||||
return len(buf), nil
|
return len(buf), nil
|
||||||
}
|
}
|
||||||
return cc.responseWriter.Write(buf)
|
return cc.responseWriter.Write(buf)
|
||||||
|
@ -217,14 +207,12 @@ func (cc *codeCatcher) WriteHeader(code int) {
|
||||||
for _, block := range cc.httpCodeRanges {
|
for _, block := range cc.httpCodeRanges {
|
||||||
if cc.code >= block[0] && cc.code <= block[1] {
|
if cc.code >= block[0] && cc.code <= block[1] {
|
||||||
cc.caughtFilteredCode = true
|
cc.caughtFilteredCode = true
|
||||||
break
|
// it will be up to the caller to send the headers,
|
||||||
}
|
|
||||||
}
|
|
||||||
// it will be up to the other response recorder to send the headers,
|
|
||||||
// so it is out of our hands now.
|
// so it is out of our hands now.
|
||||||
if cc.caughtFilteredCode {
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
utils.CopyHeaders(cc.responseWriter.Header(), cc.Header())
|
utils.CopyHeaders(cc.responseWriter.Header(), cc.Header())
|
||||||
cc.responseWriter.WriteHeader(cc.code)
|
cc.responseWriter.WriteHeader(cc.code)
|
||||||
cc.headersSent = true
|
cc.headersSent = true
|
||||||
|
@ -328,6 +316,8 @@ func (r *codeModifierWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter,
|
||||||
|
|
||||||
// Flush sends any buffered data to the client.
|
// Flush sends any buffered data to the client.
|
||||||
func (r *codeModifierWithoutCloseNotify) Flush() {
|
func (r *codeModifierWithoutCloseNotify) Flush() {
|
||||||
|
r.WriteHeader(r.code)
|
||||||
|
|
||||||
if flusher, ok := r.responseWriter.(http.Flusher); ok {
|
if flusher, ok := r.responseWriter.(http.Flusher); ok {
|
||||||
flusher.Flush()
|
flusher.Flush()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue