summaryrefslogtreecommitdiff
path: root/modules/caddyhttp
diff options
context:
space:
mode:
authorMatthew Holt <mholt@users.noreply.github.com>2021-06-14 09:03:56 -0600
committerMatthew Holt <mholt@users.noreply.github.com>2021-06-14 09:04:30 -0600
commit8848df9c5d372a559d01512b7a4ef00e38867b55 (patch)
tree6c3d33b403b7f015204fea708582d331d7e51d01 /modules/caddyhttp
parent89aa3a5ef3e0da58d8a165ffe4c073fda52994db (diff)
Revert "fileserver: Redirect within the original URL (#4179)"
This reverts commit f9b54454a19e2b070159ce8d2af76d819658244e. /cc @diamondburned (see #4205)
Diffstat (limited to 'modules/caddyhttp')
-rw-r--r--modules/caddyhttp/fileserver/browse.go9
-rw-r--r--modules/caddyhttp/fileserver/staticfiles.go14
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])
}
}