diff options
Diffstat (limited to 'modules/caddyhttp/encode')
| -rw-r--r-- | modules/caddyhttp/encode/encode.go | 41 | ||||
| -rw-r--r-- | modules/caddyhttp/encode/gzip/gzip.go | 3 | ||||
| -rw-r--r-- | modules/caddyhttp/encode/zstd/zstd.go | 3 | 
3 files changed, 35 insertions, 12 deletions
| diff --git a/modules/caddyhttp/encode/encode.go b/modules/caddyhttp/encode/encode.go index e3a6267..dc35fa2 100644 --- a/modules/caddyhttp/encode/encode.go +++ b/modules/caddyhttp/encode/encode.go @@ -20,9 +20,11 @@  package encode  import ( +	"bufio"  	"fmt"  	"io"  	"math" +	"net"  	"net/http"  	"sort"  	"strconv" @@ -91,6 +93,7 @@ func (enc *Encode) Provision(ctx caddy.Context) error {  					"application/xhtml+xml*",  					"application/atom+xml*",  					"application/rss+xml*", +					"application/wasm*",  					"image/svg+xml*",  				},  			}, @@ -165,10 +168,10 @@ func (enc *Encode) openResponseWriter(encodingName string, w http.ResponseWriter  // initResponseWriter initializes the responseWriter instance  // allocated in openResponseWriter, enabling mid-stack inlining.  func (enc *Encode) initResponseWriter(rw *responseWriter, encodingName string, wrappedRW http.ResponseWriter) *responseWriter { -	if httpInterfaces, ok := wrappedRW.(caddyhttp.HTTPInterfaces); ok { -		rw.HTTPInterfaces = httpInterfaces +	if rww, ok := wrappedRW.(*caddyhttp.ResponseWriterWrapper); ok { +		rw.ResponseWriter = rww  	} else { -		rw.HTTPInterfaces = &caddyhttp.ResponseWriterWrapper{ResponseWriter: wrappedRW} +		rw.ResponseWriter = &caddyhttp.ResponseWriterWrapper{ResponseWriter: wrappedRW}  	}  	rw.encodingName = encodingName  	rw.config = enc @@ -180,7 +183,7 @@ func (enc *Encode) initResponseWriter(rw *responseWriter, encodingName string, w  // using the encoding represented by encodingName and  // configured by config.  type responseWriter struct { -	caddyhttp.HTTPInterfaces +	http.ResponseWriter  	encodingName string  	w            Encoder  	config       *Encode @@ -209,7 +212,21 @@ func (rw *responseWriter) Flush() {  		// to rw.Write (see bug in #4314)  		return  	} -	rw.HTTPInterfaces.Flush() +	//nolint:bodyclose +	http.NewResponseController(rw.ResponseWriter).Flush() +} + +// Hijack implements http.Hijacker. It will flush status code if set. We don't track actual hijacked +// status assuming http middlewares will track its status. +func (rw *responseWriter) Hijack() (net.Conn, *bufio.ReadWriter, error) { +	if !rw.wroteHeader { +		if rw.statusCode != 0 { +			rw.ResponseWriter.WriteHeader(rw.statusCode) +		} +		rw.wroteHeader = true +	} +	//nolint:bodyclose +	return http.NewResponseController(rw.ResponseWriter).Hijack()  }  // Write writes to the response. If the response qualifies, @@ -246,7 +263,7 @@ func (rw *responseWriter) Write(p []byte) (int, error) {  	// by the standard library  	if !rw.wroteHeader {  		if rw.statusCode != 0 { -			rw.HTTPInterfaces.WriteHeader(rw.statusCode) +			rw.ResponseWriter.WriteHeader(rw.statusCode)  		}  		rw.wroteHeader = true  	} @@ -254,7 +271,7 @@ func (rw *responseWriter) Write(p []byte) (int, error) {  	if rw.w != nil {  		return rw.w.Write(p)  	} else { -		return rw.HTTPInterfaces.Write(p) +		return rw.ResponseWriter.Write(p)  	}  } @@ -270,7 +287,7 @@ func (rw *responseWriter) Close() error {  		// issue #5059, don't write status code if not set explicitly.  		if rw.statusCode != 0 { -			rw.HTTPInterfaces.WriteHeader(rw.statusCode) +			rw.ResponseWriter.WriteHeader(rw.statusCode)  		}  		rw.wroteHeader = true  	} @@ -285,13 +302,18 @@ func (rw *responseWriter) Close() error {  	return err  } +// Unwrap returns the underlying ResponseWriter. +func (rw *responseWriter) Unwrap() http.ResponseWriter { +	return rw.ResponseWriter +} +  // init should be called before we write a response, if rw.buf has contents.  func (rw *responseWriter) init() {  	if rw.Header().Get("Content-Encoding") == "" && isEncodeAllowed(rw.Header()) &&  		rw.config.Match(rw) {  		rw.w = rw.config.writerPools[rw.encodingName].Get().(Encoder) -		rw.w.Reset(rw.HTTPInterfaces) +		rw.w.Reset(rw.ResponseWriter)  		rw.Header().Del("Content-Length") // https://github.com/golang/go/issues/14975  		rw.Header().Set("Content-Encoding", rw.encodingName)  		rw.Header().Add("Vary", "Accept-Encoding") @@ -410,5 +432,4 @@ var (  	_ caddy.Provisioner           = (*Encode)(nil)  	_ caddy.Validator             = (*Encode)(nil)  	_ caddyhttp.MiddlewareHandler = (*Encode)(nil) -	_ caddyhttp.HTTPInterfaces    = (*responseWriter)(nil)  ) diff --git a/modules/caddyhttp/encode/gzip/gzip.go b/modules/caddyhttp/encode/gzip/gzip.go index 0212583..0af38b9 100644 --- a/modules/caddyhttp/encode/gzip/gzip.go +++ b/modules/caddyhttp/encode/gzip/gzip.go @@ -18,10 +18,11 @@ import (  	"fmt"  	"strconv" +	"github.com/klauspost/compress/gzip" +  	"github.com/caddyserver/caddy/v2"  	"github.com/caddyserver/caddy/v2/caddyconfig/caddyfile"  	"github.com/caddyserver/caddy/v2/modules/caddyhttp/encode" -	"github.com/klauspost/compress/gzip"  )  func init() { diff --git a/modules/caddyhttp/encode/zstd/zstd.go b/modules/caddyhttp/encode/zstd/zstd.go index 3da9b13..b5a0299 100644 --- a/modules/caddyhttp/encode/zstd/zstd.go +++ b/modules/caddyhttp/encode/zstd/zstd.go @@ -15,10 +15,11 @@  package caddyzstd  import ( +	"github.com/klauspost/compress/zstd" +  	"github.com/caddyserver/caddy/v2"  	"github.com/caddyserver/caddy/v2/caddyconfig/caddyfile"  	"github.com/caddyserver/caddy/v2/modules/caddyhttp/encode" -	"github.com/klauspost/compress/zstd"  )  func init() { | 
