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 (
|
2023-02-22 15:33:33 +00:00
|
|
|
MimeTypeUnknown = ""
|
|
|
|
MimeTypeJPEG = "image/jpeg"
|
|
|
|
MimeTypeJPEGXL = "image/jxl"
|
|
|
|
MimeTypePNG = "image/png"
|
|
|
|
MimeTypeAPNG = "image/vnd.mozilla.apng"
|
|
|
|
MimeTypeGIF = "image/gif"
|
|
|
|
MimeTypeBMP = "image/bmp"
|
|
|
|
MimeTypeTIFF = "image/tiff"
|
|
|
|
MimeTypeDNG = "image/dng"
|
|
|
|
MimeTypeAVIF = "image/avif"
|
|
|
|
MimeTypeAVIFS = "image/avif-sequence"
|
|
|
|
MimeTypeHEIC = "image/heic"
|
|
|
|
MimeTypeHEICS = "image/heic-sequence"
|
|
|
|
MimeTypeWebP = "image/webp"
|
|
|
|
MimeTypeMP4 = "video/mp4"
|
|
|
|
MimeTypeMOV = "video/quicktime"
|
|
|
|
MimeTypeSVG = "image/svg+xml"
|
|
|
|
MimeTypeAI = "application/vnd.adobe.illustrator"
|
|
|
|
MimeTypePS = "application/ps"
|
|
|
|
MimeTypeEPS = "image/eps"
|
|
|
|
MimeTypeXML = "text/xml"
|
|
|
|
MimeTypeJSON = "application/json"
|
2020-04-07 08:42:42 +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) {
|
2023-02-14 10:37:22 +00:00
|
|
|
if filename == "" {
|
|
|
|
return MimeTypeUnknown
|
|
|
|
}
|
|
|
|
|
2023-02-13 19:02:26 +00:00
|
|
|
// Workaround for types that cannot be reliably detected.
|
|
|
|
switch Extensions[strings.ToLower(filepath.Ext(filename))] {
|
|
|
|
case ImageDNG:
|
2022-10-07 14:37:47 +00:00
|
|
|
return MimeTypeDNG
|
2023-02-21 12:27:45 +00:00
|
|
|
case ImageAVIF:
|
2022-10-07 14:37:47 +00:00
|
|
|
return MimeTypeAVIF
|
2023-02-22 15:33:33 +00:00
|
|
|
case ImageAVIFS:
|
|
|
|
return MimeTypeAVIFS
|
|
|
|
case ImageHEIC:
|
|
|
|
return MimeTypeHEIC
|
|
|
|
case ImageHEICS:
|
|
|
|
return MimeTypeHEICS
|
2023-02-13 19:02:26 +00:00
|
|
|
case VideoMP4:
|
2022-12-23 01:02:47 +00:00
|
|
|
return MimeTypeMP4
|
2023-02-21 12:27:45 +00:00
|
|
|
case VideoMOV:
|
2022-12-23 01:02:47 +00:00
|
|
|
return MimeTypeMOV
|
2023-02-13 19:02:26 +00:00
|
|
|
case VectorSVG:
|
2023-02-11 19:18:04 +00:00
|
|
|
return MimeTypeSVG
|
2023-02-13 19:02:26 +00:00
|
|
|
case VectorAI:
|
|
|
|
return MimeTypeAI
|
|
|
|
case VectorPS:
|
2023-02-11 20:12:39 +00:00
|
|
|
return MimeTypePS
|
2023-02-13 19:02:26 +00:00
|
|
|
case VectorEPS:
|
2023-02-11 19:18:04 +00:00
|
|
|
return MimeTypeEPS
|
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
|
|
|
}
|