2015-09-30 19:37:10 +02:00
|
|
|
package mime
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
2016-03-16 07:11:19 +01:00
|
|
|
"path"
|
2015-09-30 19:37:10 +02:00
|
|
|
|
|
|
|
"github.com/mholt/caddy/middleware"
|
|
|
|
)
|
|
|
|
|
2016-03-16 07:11:19 +01:00
|
|
|
// Config represent a mime config. Map from extension to mime-type.
|
|
|
|
// Note, this should be safe with concurrent read access, as this is
|
|
|
|
// not modified concurrently.
|
|
|
|
type Config map[string]string
|
2015-09-30 19:37:10 +02:00
|
|
|
|
|
|
|
// Mime sets Content-Type header of requests based on configurations.
|
|
|
|
type Mime struct {
|
|
|
|
Next middleware.Handler
|
2016-03-16 07:11:19 +01:00
|
|
|
Configs Config
|
2015-09-30 19:37:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ServeHTTP implements the middleware.Handler interface.
|
|
|
|
func (e Mime) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) {
|
2016-03-16 07:11:19 +01:00
|
|
|
|
|
|
|
// Get a clean /-path, grab the extension
|
|
|
|
ext := path.Ext(path.Clean(r.URL.Path))
|
|
|
|
|
|
|
|
if contentType, ok := e.Configs[ext]; ok {
|
|
|
|
w.Header().Set("Content-Type", contentType)
|
2015-09-30 19:37:10 +02:00
|
|
|
}
|
2016-03-16 07:11:19 +01:00
|
|
|
|
2015-09-30 19:37:10 +02:00
|
|
|
return e.Next.ServeHTTP(w, r)
|
|
|
|
}
|