mirror of
https://github.com/caddyserver/caddy.git
synced 2025-10-19 07:43:17 +00:00
Merge 8aa487da88
into d115cd1042
This commit is contained in:
commit
df23024565
1 changed files with 11 additions and 0 deletions
|
@ -42,6 +42,9 @@ func init() {
|
|||
caddy.RegisterModule(FileServer{})
|
||||
}
|
||||
|
||||
const FileServerFilenameVarKey = "fileserver_filename"
|
||||
const FileServerFileinfoVarKey = "fileserver_fileinfo"
|
||||
|
||||
// FileServer implements a handler that serves static files.
|
||||
//
|
||||
// The path of the file to serve is constructed by joining the site root
|
||||
|
@ -570,6 +573,14 @@ func (fsrv *FileServer) ServeHTTP(w http.ResponseWriter, r *http.Request, next c
|
|||
w = statusOverrideResponseWriter{ResponseWriter: w, code: statusCodeOverride}
|
||||
}
|
||||
|
||||
// add filename and file info to the request context vars so that other middlewares
|
||||
// can find out what static file has been served by the fileserver.
|
||||
// middlewares can access the vars as follows:
|
||||
// caddyhttp.GetVar(r.Context(), fileserver.FileServerFilenameVarKey).(string)
|
||||
// caddyhttp.GetVar(r.Context(), fileserver.FileServerFileinfoVarKey).(fs.FileInfo)
|
||||
caddyhttp.SetVar(r.Context(), FileServerFilenameVarKey, filename)
|
||||
caddyhttp.SetVar(r.Context(), FileServerFileinfoVarKey, info)
|
||||
|
||||
// let the standard library do what it does best; note, however,
|
||||
// that errors generated by ServeContent are written immediately
|
||||
// to the response, so we cannot handle them (but errors there
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue