mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-24 09:37:03 +01:00
Refactored browse middleware to return errors
This commit is contained in:
parent
058ff94828
commit
843f6e83a9
1 changed files with 14 additions and 16 deletions
|
@ -20,7 +20,7 @@ import (
|
||||||
// Browse is an http.Handler that can show a file listing when
|
// Browse is an http.Handler that can show a file listing when
|
||||||
// directories in the given paths are specified.
|
// directories in the given paths are specified.
|
||||||
type Browse struct {
|
type Browse struct {
|
||||||
Next http.HandlerFunc
|
Next middleware.HandlerFunc
|
||||||
Root string
|
Root string
|
||||||
Configs []BrowseConfig
|
Configs []BrowseConfig
|
||||||
}
|
}
|
||||||
|
@ -83,26 +83,23 @@ func New(c middleware.Controller) (middleware.Middleware, error) {
|
||||||
Configs: configs,
|
Configs: configs,
|
||||||
}
|
}
|
||||||
|
|
||||||
return func(next http.HandlerFunc) http.HandlerFunc {
|
return func(next middleware.HandlerFunc) middleware.HandlerFunc {
|
||||||
browse.Next = next
|
browse.Next = next
|
||||||
return browse.ServeHTTP
|
return browse.ServeHTTP
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ServeHTTP implements the http.Handler interface.
|
// ServeHTTP implements the middleware.Handler interface.
|
||||||
func (b Browse) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (b Browse) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||||
filename := b.Root + r.URL.Path
|
filename := b.Root + r.URL.Path
|
||||||
|
|
||||||
info, err := os.Stat(filename)
|
info, err := os.Stat(filename)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// TODO: 404 Not Found
|
return b.Next(w, r)
|
||||||
b.Next(w, r)
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if !info.IsDir() {
|
if !info.IsDir() {
|
||||||
b.Next(w, r)
|
return b.Next(w, r)
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// See if there's a browse configuration to match the path
|
// See if there's a browse configuration to match the path
|
||||||
|
@ -115,21 +112,21 @@ func (b Browse) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
// that doesn't end in "/" (which it should, anyway)
|
// that doesn't end in "/" (which it should, anyway)
|
||||||
if r.URL.Path[len(r.URL.Path)-1] != '/' {
|
if r.URL.Path[len(r.URL.Path)-1] != '/' {
|
||||||
http.Redirect(w, r, r.URL.Path+"/", http.StatusTemporaryRedirect)
|
http.Redirect(w, r, r.URL.Path+"/", http.StatusTemporaryRedirect)
|
||||||
return
|
return 0, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load directory contents
|
// Load directory contents
|
||||||
file, err := os.Open(b.Root + r.URL.Path)
|
file, err := os.Open(b.Root + r.URL.Path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err) // TODO
|
return http.StatusForbidden, err
|
||||||
}
|
}
|
||||||
defer file.Close()
|
defer file.Close()
|
||||||
|
|
||||||
w.Header().Set("Content-Type", "text/html; charset=utf-8")
|
w.Header().Set("Content-Type", "text/html; charset=utf-8")
|
||||||
|
|
||||||
files, err := file.Readdir(-1)
|
files, err := file.Readdir(-1)
|
||||||
if err != nil || len(files) == 0 {
|
if err != nil {
|
||||||
// TODO - second condition may not be necessary? See docs...
|
return http.StatusForbidden, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// Assemble listing of directory contents
|
// Assemble listing of directory contents
|
||||||
|
@ -185,16 +182,17 @@ func (b Browse) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
Items: fileinfos,
|
Items: fileinfos,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: Don't write to w until we know there wasn't an error
|
||||||
err = bc.Template.Execute(w, listing)
|
err = bc.Template.Execute(w, listing)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err) // TODO
|
return http.StatusInternalServerError, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return http.StatusOK, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Didn't qualify; pass-thru
|
// Didn't qualify; pass-thru
|
||||||
b.Next(w, r)
|
return b.Next(w, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse returns a list of browsing configurations
|
// parse returns a list of browsing configurations
|
||||||
|
|
Loading…
Reference in a new issue