fileserver: Better fix for Etag of compressed files

This commit is contained in:
Matthew Holt 2022-08-08 13:09:57 -06:00
parent 8c72f34357
commit 7ab61f46f0
No known key found for this signature in database
GPG key ID: 2A349DD577D586A5

View file

@ -351,6 +351,7 @@ func (fsrv *FileServer) ServeHTTP(w http.ResponseWriter, r *http.Request, next c
} }
var file fs.File var file fs.File
var etag string
// check for precompressed files // check for precompressed files
for _, ae := range encode.AcceptedEncodings(r, fsrv.PrecompressedOrder) { for _, ae := range encode.AcceptedEncodings(r, fsrv.PrecompressedOrder) {
@ -371,13 +372,19 @@ func (fsrv *FileServer) ServeHTTP(w http.ResponseWriter, r *http.Request, next c
if caddyErr, ok := err.(caddyhttp.HandlerError); ok && caddyErr.StatusCode == http.StatusServiceUnavailable { if caddyErr, ok := err.(caddyhttp.HandlerError); ok && caddyErr.StatusCode == http.StatusServiceUnavailable {
return err return err
} }
file = nil
continue continue
} }
defer file.Close() defer file.Close()
info = compressedInfo
w.Header().Set("Content-Encoding", ae) w.Header().Set("Content-Encoding", ae)
w.Header().Del("Accept-Ranges") w.Header().Del("Accept-Ranges")
w.Header().Add("Vary", "Accept-Encoding") w.Header().Add("Vary", "Accept-Encoding")
// don't assign info = compressedInfo because sidecars are kind
// of transparent; however we do need to set the Etag:
// https://caddy.community/t/gzipped-sidecar-file-wrong-same-etag/16793
etag = calculateEtag(compressedInfo)
break break
} }
@ -395,11 +402,13 @@ func (fsrv *FileServer) ServeHTTP(w http.ResponseWriter, r *http.Request, next c
return err // error is already structured return err // error is already structured
} }
defer file.Close() defer file.Close()
etag = calculateEtag(info)
} }
// set the ETag - note that a conditional If-None-Match request is handled // set the Etag - note that a conditional If-None-Match request is handled
// by http.ServeContent below, which checks against this ETag value // by http.ServeContent below, which checks against this Etag value
w.Header().Set("Etag", calculateEtag(info)) w.Header().Set("Etag", etag)
if w.Header().Get("Content-Type") == "" { if w.Header().Get("Content-Type") == "" {
mtyp := mime.TypeByExtension(filepath.Ext(filename)) mtyp := mime.TypeByExtension(filepath.Ext(filename))