summaryrefslogtreecommitdiff
path: root/system/api/gzip.go
diff options
context:
space:
mode:
authorSteve Manuel <nilslice@gmail.com>2018-01-14 21:44:32 -0700
committerSteve Manuel <nilslice@gmail.com>2018-01-14 21:44:32 -0700
commit5a52ef78f16deaaad9c62b62a31efde991c18b25 (patch)
treeead620e6cd1aa5b9b5f7736d5116776f40ddbc3b /system/api/gzip.go
parent18e51f8c9a70688560e65f99638d500e60df8264 (diff)
parentacfd3deeb7efc8929dd4001acfa58fcac74203a1 (diff)
Merge branch 'ponzu-dev' of github.com:ponzu-cms/ponzu into ponzu-dev
Diffstat (limited to 'system/api/gzip.go')
-rw-r--r--system/api/gzip.go7
1 files changed, 4 insertions, 3 deletions
diff --git a/system/api/gzip.go b/system/api/gzip.go
index be5a51b..02f1535 100644
--- a/system/api/gzip.go
+++ b/system/api/gzip.go
@@ -20,11 +20,13 @@ func Gzip(next http.HandlerFunc) http.HandlerFunc {
if strings.Contains(req.Header.Get("Accept-Encoding"), "gzip") {
// gzip response data
res.Header().Set("Content-Encoding", "gzip")
+ gzWriter := gzip.NewWriter(res)
+ defer gzWriter.Close()
var gzres gzipResponseWriter
if pusher, ok := res.(http.Pusher); ok {
- gzres = gzipResponseWriter{res, pusher, gzip.NewWriter(res)}
+ gzres = gzipResponseWriter{res, pusher, gzWriter}
} else {
- gzres = gzipResponseWriter{res, nil, gzip.NewWriter(res)}
+ gzres = gzipResponseWriter{res, nil, gzWriter}
}
next.ServeHTTP(gzres, req)
@@ -43,7 +45,6 @@ type gzipResponseWriter struct {
}
func (gzw gzipResponseWriter) Write(p []byte) (int, error) {
- defer gzw.gw.Close()
return gzw.gw.Write(p)
}