mirror of
https://github.com/halverneus/static-file-server.git
synced 2025-02-05 15:55:30 +00:00
93 lines
2.7 KiB
Go
93 lines
2.7 KiB
Go
package handle
|
|
|
|
import (
|
|
"log"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
var (
|
|
// These assignments are for unit testing.
|
|
listenAndServe = http.ListenAndServe
|
|
listenAndServeTLS = http.ListenAndServeTLS
|
|
setHandler = http.HandleFunc
|
|
)
|
|
|
|
var (
|
|
server http.Server
|
|
)
|
|
|
|
// ListenerFunc accepts the {hostname:port} binding string required by HTTP
|
|
// listeners and the handler (router) function and returns any errors that
|
|
// occur.
|
|
type ListenerFunc func(string, http.HandlerFunc) error
|
|
|
|
// FileServerFunc is used to serve the file from the local file system to the
|
|
// requesting client.
|
|
type FileServerFunc func(http.ResponseWriter, *http.Request, string)
|
|
|
|
// WithLogging returns a function that logs information about the request prior
|
|
// to serving the requested file.
|
|
func WithLogging(serveFile FileServerFunc) FileServerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request, name string) {
|
|
log.Printf(
|
|
"REQ: %s %s %s%s -> %s\n",
|
|
r.Method,
|
|
r.Proto,
|
|
r.Host,
|
|
r.URL.Path,
|
|
name,
|
|
)
|
|
serveFile(w, r, name)
|
|
}
|
|
}
|
|
|
|
// Basic file handler servers files from the passed folder.
|
|
func Basic(serveFile FileServerFunc, folder string) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
serveFile(w, r, folder+r.URL.Path)
|
|
}
|
|
}
|
|
|
|
// Prefix file handler is an alternative to Basic where a URL prefix is removed
|
|
// prior to serving a file (http://my.machine/prefix/file.txt will serve
|
|
// file.txt from the root of the folder being served (ignoring 'prefix')).
|
|
func Prefix(serveFile FileServerFunc, folder, urlPrefix string) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
if !strings.HasPrefix(r.URL.Path, urlPrefix) {
|
|
http.NotFound(w, r)
|
|
return
|
|
}
|
|
serveFile(w, r, folder+strings.TrimPrefix(r.URL.Path, urlPrefix))
|
|
}
|
|
}
|
|
|
|
// IgnoreIndex wraps an HTTP request. In the event of a folder root request,
|
|
// this function will automatically return 'NOT FOUND' as opposed to default
|
|
// behavior where the index file for that directory is retrieved.
|
|
func IgnoreIndex(serve http.HandlerFunc) http.HandlerFunc {
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
if strings.HasSuffix(r.URL.Path, "/") {
|
|
http.NotFound(w, r)
|
|
return
|
|
}
|
|
serve(w, r)
|
|
}
|
|
}
|
|
|
|
// Listening function for serving the handler function.
|
|
func Listening() ListenerFunc {
|
|
return func(binding string, handler http.HandlerFunc) error {
|
|
setHandler("/", handler)
|
|
return listenAndServe(binding, nil)
|
|
}
|
|
}
|
|
|
|
// TLSListening function for serving the handler function with encryption.
|
|
func TLSListening(tlsCert, tlsKey string) ListenerFunc {
|
|
return func(binding string, handler http.HandlerFunc) error {
|
|
setHandler("/", handler)
|
|
return listenAndServeTLS(binding, tlsCert, tlsKey, nil)
|
|
}
|
|
}
|