From 8848df9c5d372a559d01512b7a4ef00e38867b55 Mon Sep 17 00:00:00 2001 From: Matthew Holt Date: Mon, 14 Jun 2021 09:03:56 -0600 Subject: Revert "fileserver: Redirect within the original URL (#4179)" This reverts commit f9b54454a19e2b070159ce8d2af76d819658244e. /cc @diamondburned (see #4205) --- modules/caddyhttp/fileserver/browse.go | 9 ++++----- modules/caddyhttp/fileserver/staticfiles.go | 14 ++++++-------- 2 files changed, 10 insertions(+), 13 deletions(-) diff --git a/modules/caddyhttp/fileserver/browse.go b/modules/caddyhttp/fileserver/browse.go index fa6da68..fc8bddb 100644 --- a/modules/caddyhttp/fileserver/browse.go +++ b/modules/caddyhttp/fileserver/browse.go @@ -47,11 +47,10 @@ func (fsrv *FileServer) serveBrowse(root, dirPath string, w http.ResponseWriter, // URL doesn't end in a trailing slash because hrefs like // "/b/c" on a path like "/a" end up going to "/b/c" instead // of "/a/b/c" - so we have to redirect in this case - oldReq := r.Context().Value(caddyhttp.OriginalRequestCtxKey).(http.Request) - if !strings.HasSuffix(oldReq.URL.Path, "/") { - fsrv.logger.Debug("redirecting to trailing slash to preserve hrefs", zap.String("request_path", oldReq.URL.Path)) - oldReq.URL.Path += "/" - http.Redirect(w, r, oldReq.URL.String(), http.StatusMovedPermanently) + if !strings.HasSuffix(r.URL.Path, "/") { + fsrv.logger.Debug("redirecting to trailing slash to preserve hrefs", zap.String("request_path", r.URL.Path)) + r.URL.Path += "/" + http.Redirect(w, r, r.URL.String(), http.StatusMovedPermanently) return nil } diff --git a/modules/caddyhttp/fileserver/staticfiles.go b/modules/caddyhttp/fileserver/staticfiles.go index 87e0a77..f2320aa 100644 --- a/modules/caddyhttp/fileserver/staticfiles.go +++ b/modules/caddyhttp/fileserver/staticfiles.go @@ -243,14 +243,12 @@ func (fsrv *FileServer) ServeHTTP(w http.ResponseWriter, r *http.Request, next c // trailing slash - not enforcing this can break relative hrefs // in HTML (see https://github.com/caddyserver/caddy/issues/2741) if fsrv.CanonicalURIs == nil || *fsrv.CanonicalURIs { - oldReq := r.Context().Value(caddyhttp.OriginalRequestCtxKey).(http.Request) - - if implicitIndexFile && !strings.HasSuffix(oldReq.URL.Path, "/") { - fsrv.logger.Debug("redirecting to canonical URI (adding trailing slash for directory)", zap.String("path", oldReq.URL.Path)) - return redirect(w, r, oldReq.URL.Path+"/") - } else if !implicitIndexFile && strings.HasSuffix(oldReq.URL.Path, "/") { - fsrv.logger.Debug("redirecting to canonical URI (removing trailing slash for file)", zap.String("path", oldReq.URL.Path)) - return redirect(w, r, oldReq.URL.Path[:len(oldReq.URL.Path)-1]) + if implicitIndexFile && !strings.HasSuffix(r.URL.Path, "/") { + fsrv.logger.Debug("redirecting to canonical URI (adding trailing slash for directory)", zap.String("path", r.URL.Path)) + return redirect(w, r, r.URL.Path+"/") + } else if !implicitIndexFile && strings.HasSuffix(r.URL.Path, "/") { + fsrv.logger.Debug("redirecting to canonical URI (removing trailing slash for file)", zap.String("path", r.URL.Path)) + return redirect(w, r, r.URL.Path[:len(r.URL.Path)-1]) } } -- cgit v1.2.3