aboutsummaryrefslogtreecommitdiff
path: root/http_server.go
diff options
context:
space:
mode:
Diffstat (limited to 'http_server.go')
-rw-r--r--http_server.go14
1 files changed, 12 insertions, 2 deletions
diff --git a/http_server.go b/http_server.go
index 6531748..73e27f6 100644
--- a/http_server.go
+++ b/http_server.go
@@ -38,7 +38,9 @@ func (router *forgeHTTPRouter) ServeHTTP(writer http.ResponseWriter, request *ht
http.Error(writer, err.Error(), http.StatusBadRequest)
return
}
+ dirMode := false
if segments[len(segments)-1] == "" {
+ dirMode = true
segments = segments[:len(segments)-1]
}
@@ -184,7 +186,11 @@ func (router *forgeHTTPRouter) ServeHTTP(writer http.ResponseWriter, request *ht
errorPage400(writer, params, "Repo tree paths may not contain slashes in any segments")
return
}
- params["rest"] = strings.Join(segments[sepIndex+4:], "/")
+ if dirMode {
+ params["rest"] = strings.Join(segments[sepIndex+4:], "/") + "/"
+ } else {
+ params["rest"] = strings.Join(segments[sepIndex+4:], "/")
+ }
if len(segments) < sepIndex+5 && redirectDir(writer, request) {
return
}
@@ -194,7 +200,11 @@ func (router *forgeHTTPRouter) ServeHTTP(writer http.ResponseWriter, request *ht
errorPage400(writer, params, "Repo tree paths may not contain slashes in any segments")
return
}
- params["rest"] = strings.Join(segments[sepIndex+4:], "/")
+ if dirMode {
+ params["rest"] = strings.Join(segments[sepIndex+4:], "/") + "/"
+ } else {
+ params["rest"] = strings.Join(segments[sepIndex+4:], "/")
+ }
if len(segments) < sepIndex+5 && redirectDir(writer, request) {
return
}