From 14500d8204c806edc69daa1725df7c68aa6f6347 Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Wed, 2 Nov 2016 08:13:05 -0600 Subject: [PATCH] header: Implement Flusher and CloseNotifier --- caddyhttp/header/header.go | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/caddyhttp/header/header.go b/caddyhttp/header/header.go index 7207c52e..28f95d45 100644 --- a/caddyhttp/header/header.go +++ b/caddyhttp/header/header.go @@ -115,3 +115,23 @@ func (rww *responseWriterWrapper) Hijack() (net.Conn, *bufio.ReadWriter, error) } return nil, nil, httpserver.NonHijackerError{Underlying: rww.w} } + +// Flush implements http.Flusher. It simply wraps the underlying +// ResponseWriter's Flush method if there is one, or panics. +func (rww *responseWriterWrapper) Flush() { + if f, ok := rww.w.(http.Flusher); ok { + f.Flush() + } else { + panic(httpserver.NonFlusherError{Underlying: rww.w}) // should be recovered at the beginning of middleware stack + } +} + +// CloseNotify implements http.CloseNotifier. +// It just inherits the underlying ResponseWriter's CloseNotify method. +// It panics if the underlying ResponseWriter is not a CloseNotifier. +func (rww *responseWriterWrapper) CloseNotify() <-chan bool { + if cn, ok := rww.w.(http.CloseNotifier); ok { + return cn.CloseNotify() + } + panic(httpserver.NonCloseNotifierError{Underlying: rww.w}) +}