2020-01-12 13:00:56 +00:00
|
|
|
package fs
|
2019-12-15 16:19:16 +00:00
|
|
|
|
|
|
|
import (
|
2022-09-14 22:43:08 +00:00
|
|
|
"path/filepath"
|
2022-10-07 14:37:47 +00:00
|
|
|
"strings"
|
2020-07-21 12:43:45 +00:00
|
|
|
|
2022-10-07 14:37:47 +00:00
|
|
|
"github.com/gabriel-vasile/mimetype"
|
2019-12-15 16:19:16 +00:00
|
|
|
)
|
|
|
|
|
2020-04-07 08:42:42 +00:00
|
|
|
const (
|
2022-10-07 14:37:47 +00:00
|
|
|
MimeTypeUnknown = ""
|
|
|
|
MimeTypeJpeg = "image/jpeg"
|
|
|
|
MimeTypePng = "image/png"
|
|
|
|
MimeTypeGif = "image/gif"
|
|
|
|
MimeTypeBitmap = "image/bmp"
|
|
|
|
MimeTypeTiff = "image/tiff"
|
|
|
|
MimeTypeDNG = "image/dng"
|
|
|
|
MimeTypeAVIF = "image/avif"
|
|
|
|
MimeTypeHEIC = "image/heic"
|
|
|
|
MimeTypeWebP = "image/webp"
|
|
|
|
MimeTypeXML = "text/xml"
|
|
|
|
MimeTypeJSON = "application/json"
|
2020-04-07 08:42:42 +00:00
|
|
|
)
|
|
|
|
|
2022-10-07 14:37:47 +00:00
|
|
|
// Set mime detection read limit.
|
|
|
|
func init() {
|
|
|
|
mimetype.SetLimit(1024)
|
|
|
|
}
|
2019-12-15 16:19:16 +00:00
|
|
|
|
2022-10-07 14:37:47 +00:00
|
|
|
// MimeType returns the mime type of a file, or an empty string if it could not be detected.
|
|
|
|
func MimeType(filename string) (mimeType string) {
|
|
|
|
// Workaround, since "image/dng" cannot be recognized yet.
|
|
|
|
if ext := strings.ToLower(filepath.Ext(filename)); ext == "" {
|
|
|
|
// Continue.
|
|
|
|
} else if Extensions[ext] == ImageDNG {
|
|
|
|
return MimeTypeDNG
|
|
|
|
} else if Extensions[ext] == ImageAVIF {
|
|
|
|
return MimeTypeAVIF
|
2019-12-15 16:19:16 +00:00
|
|
|
}
|
|
|
|
|
2022-10-07 14:37:47 +00:00
|
|
|
if t, err := mimetype.DetectFile(filename); err != nil {
|
|
|
|
return MimeTypeUnknown
|
2020-09-20 13:12:45 +00:00
|
|
|
} else {
|
2022-10-07 14:37:47 +00:00
|
|
|
mimeType, _, _ = strings.Cut(t.String(), ";")
|
2019-12-15 16:19:16 +00:00
|
|
|
}
|
2022-10-07 14:37:47 +00:00
|
|
|
|
|
|
|
return mimeType
|
2019-12-15 16:19:16 +00:00
|
|
|
}
|