mirror of
https://github.com/minio/minio.git
synced 2025-01-12 07:23:23 -05:00
api: Set content-encoding properly if set. (#2245)
Additionally don't set content-type if not present, golang http server automaticaly handles this and sets it automatically.
This commit is contained in:
parent
18728a0b59
commit
c1e953b368
@ -107,6 +107,7 @@ const (
|
|||||||
|
|
||||||
// S3 extended errors.
|
// S3 extended errors.
|
||||||
ErrContentSHA256Mismatch
|
ErrContentSHA256Mismatch
|
||||||
|
|
||||||
// Add new extended error codes here.
|
// Add new extended error codes here.
|
||||||
|
|
||||||
// Minio extended errors.
|
// Minio extended errors.
|
||||||
|
@ -23,7 +23,6 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"runtime"
|
"runtime"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
//// helpers
|
//// helpers
|
||||||
@ -67,17 +66,19 @@ func setObjectHeaders(w http.ResponseWriter, objInfo ObjectInfo, contentRange *h
|
|||||||
lastModified := objInfo.ModTime.UTC().Format(http.TimeFormat)
|
lastModified := objInfo.ModTime.UTC().Format(http.TimeFormat)
|
||||||
w.Header().Set("Last-Modified", lastModified)
|
w.Header().Set("Last-Modified", lastModified)
|
||||||
|
|
||||||
|
if objInfo.ContentType != "" {
|
||||||
w.Header().Set("Content-Type", objInfo.ContentType)
|
w.Header().Set("Content-Type", objInfo.ContentType)
|
||||||
|
}
|
||||||
if objInfo.MD5Sum != "" {
|
if objInfo.MD5Sum != "" {
|
||||||
w.Header().Set("ETag", "\""+objInfo.MD5Sum+"\"")
|
w.Header().Set("ETag", "\""+objInfo.MD5Sum+"\"")
|
||||||
}
|
}
|
||||||
|
if objInfo.ContentEncoding != "" {
|
||||||
|
w.Header().Set("Content-Encoding", objInfo.ContentEncoding)
|
||||||
|
}
|
||||||
w.Header().Set("Content-Length", strconv.FormatInt(objInfo.Size, 10))
|
w.Header().Set("Content-Length", strconv.FormatInt(objInfo.Size, 10))
|
||||||
for k, v := range objInfo.UserDefined {
|
for k, v := range objInfo.UserDefined {
|
||||||
if strings.HasPrefix(k, "X-Amz-Meta-") {
|
|
||||||
w.Header().Set(k, v)
|
w.Header().Set(k, v)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// for providing ranged content
|
// for providing ranged content
|
||||||
if contentRange != nil && contentRange.offsetBegin > -1 {
|
if contentRange != nil && contentRange.offsetBegin > -1 {
|
||||||
|
1
fs-v1.go
1
fs-v1.go
@ -584,6 +584,7 @@ func (fs fsObjects) listObjects(bucket, prefix, marker, delimiter string, maxKey
|
|||||||
Name: fileInfo.Name,
|
Name: fileInfo.Name,
|
||||||
ModTime: fileInfo.ModTime,
|
ModTime: fileInfo.ModTime,
|
||||||
Size: fileInfo.Size,
|
Size: fileInfo.Size,
|
||||||
|
MD5Sum: fileInfo.MD5Sum,
|
||||||
IsDir: false,
|
IsDir: false,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -325,8 +325,12 @@ func (api objectAPIHandlers) CopyObjectHandler(w http.ResponseWriter, r *http.Re
|
|||||||
// Save metadata.
|
// Save metadata.
|
||||||
metadata := make(map[string]string)
|
metadata := make(map[string]string)
|
||||||
// Save other metadata if available.
|
// Save other metadata if available.
|
||||||
|
if objInfo.ContentType != "" {
|
||||||
metadata["content-type"] = objInfo.ContentType
|
metadata["content-type"] = objInfo.ContentType
|
||||||
|
}
|
||||||
|
if objInfo.ContentEncoding != "" {
|
||||||
metadata["content-encoding"] = objInfo.ContentEncoding
|
metadata["content-encoding"] = objInfo.ContentEncoding
|
||||||
|
}
|
||||||
// Do not set `md5sum` as CopyObject will not keep the
|
// Do not set `md5sum` as CopyObject will not keep the
|
||||||
// same md5sum as the source.
|
// same md5sum as the source.
|
||||||
|
|
||||||
@ -393,8 +397,14 @@ func (api objectAPIHandlers) PutObjectHandler(w http.ResponseWriter, r *http.Req
|
|||||||
// Make sure we hex encode md5sum here.
|
// Make sure we hex encode md5sum here.
|
||||||
metadata["md5Sum"] = hex.EncodeToString(md5Bytes)
|
metadata["md5Sum"] = hex.EncodeToString(md5Bytes)
|
||||||
// Save other metadata if available.
|
// Save other metadata if available.
|
||||||
metadata["content-type"] = r.Header.Get("Content-Type")
|
contentType := r.Header.Get("Content-Type")
|
||||||
metadata["content-encoding"] = r.Header.Get("Content-Encoding")
|
if contentType != "" {
|
||||||
|
metadata["content-type"] = contentType
|
||||||
|
}
|
||||||
|
contentEncoding := r.Header.Get("Content-Encoding")
|
||||||
|
if contentEncoding != "" {
|
||||||
|
metadata["content-encoding"] = contentEncoding
|
||||||
|
}
|
||||||
for key := range r.Header {
|
for key := range r.Header {
|
||||||
cKey := http.CanonicalHeaderKey(key)
|
cKey := http.CanonicalHeaderKey(key)
|
||||||
if strings.HasPrefix(cKey, "X-Amz-Meta-") {
|
if strings.HasPrefix(cKey, "X-Amz-Meta-") {
|
||||||
@ -465,13 +475,19 @@ func (api objectAPIHandlers) NewMultipartUploadHandler(w http.ResponseWriter, r
|
|||||||
// Save metadata.
|
// Save metadata.
|
||||||
metadata := make(map[string]string)
|
metadata := make(map[string]string)
|
||||||
// Save other metadata if available.
|
// Save other metadata if available.
|
||||||
metadata["content-type"] = r.Header.Get("Content-Type")
|
contentType := r.Header.Get("Content-Type")
|
||||||
metadata["content-encoding"] = r.Header.Get("Content-Encoding")
|
if contentType != "" {
|
||||||
|
metadata["content-type"] = contentType
|
||||||
|
}
|
||||||
|
contentEncoding := r.Header.Get("Content-Encoding")
|
||||||
|
if contentEncoding != "" {
|
||||||
|
metadata["content-encoding"] = contentEncoding
|
||||||
|
}
|
||||||
for key := range r.Header {
|
for key := range r.Header {
|
||||||
cKey := http.CanonicalHeaderKey(key)
|
cKey := http.CanonicalHeaderKey(key)
|
||||||
if strings.HasPrefix(cKey, "x-amz-meta-") {
|
if strings.HasPrefix(cKey, "X-Amz-Meta-") {
|
||||||
metadata[cKey] = r.Header.Get(cKey)
|
metadata[cKey] = r.Header.Get(cKey)
|
||||||
} else if strings.HasPrefix(key, "x-minio-meta-") {
|
} else if strings.HasPrefix(key, "X-Minio-Meta-") {
|
||||||
metadata[cKey] = r.Header.Get(cKey)
|
metadata[cKey] = r.Header.Get(cKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,6 +97,7 @@ func (xl xlObjects) listObjects(bucket, prefix, marker, delimiter string, maxKey
|
|||||||
Name: objInfo.Name,
|
Name: objInfo.Name,
|
||||||
ModTime: objInfo.ModTime,
|
ModTime: objInfo.ModTime,
|
||||||
Size: objInfo.Size,
|
Size: objInfo.Size,
|
||||||
|
MD5Sum: objInfo.MD5Sum,
|
||||||
IsDir: false,
|
IsDir: false,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user