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:
Harshavardhana 2016-07-20 12:40:20 -07:00 committed by GitHub
parent 18728a0b59
commit c1e953b368
5 changed files with 34 additions and 14 deletions

View File

@ -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.

View File

@ -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 {

View File

@ -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,
}) })
} }

View File

@ -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)
} }
} }

View File

@ -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,
}) })
} }