From e5cd35aad0fc209bcb0c9beac1a94f8c0f123274 Mon Sep 17 00:00:00 2001 From: utsl42 Date: Tue, 12 Jul 2016 15:45:17 -0400 Subject: [PATCH] XL: GetObjectInfo() store and retrieve user-defined object metadata. (#2189) --- api-headers.go | 6 ++++++ object-datatypes.go | 3 +++ object-handlers.go | 4 ++-- xl-v1-object.go | 1 + 4 files changed, 12 insertions(+), 2 deletions(-) diff --git a/api-headers.go b/api-headers.go index 5e0743d8a..e3a295ad3 100644 --- a/api-headers.go +++ b/api-headers.go @@ -23,6 +23,7 @@ import ( "net/http" "runtime" "strconv" + "strings" ) //// helpers @@ -72,6 +73,11 @@ func setObjectHeaders(w http.ResponseWriter, objInfo ObjectInfo, contentRange *h } w.Header().Set("Content-Length", strconv.FormatInt(objInfo.Size, 10)) + for k, v := range objInfo.UserDefined { + if strings.HasPrefix(k, "X-Amz-Meta-") { + w.Header().Set(k, v) + } + } // for providing ranged content if contentRange != nil && contentRange.offsetBegin > -1 { diff --git a/object-datatypes.go b/object-datatypes.go index 4a08c5e5f..a4f9fc6b1 100644 --- a/object-datatypes.go +++ b/object-datatypes.go @@ -62,6 +62,9 @@ type ObjectInfo struct { // what decoding mechanisms must be applied to obtain the object referenced // by the Content-Type header field. ContentEncoding string + + // User-Defined metadata + UserDefined map[string]string } // ListPartsInfo - represents list of all parts. diff --git a/object-handlers.go b/object-handlers.go index 24f6160f7..453a881a4 100644 --- a/object-handlers.go +++ b/object-handlers.go @@ -397,9 +397,9 @@ func (api objectAPIHandlers) PutObjectHandler(w http.ResponseWriter, r *http.Req metadata["content-encoding"] = r.Header.Get("Content-Encoding") for key := range r.Header { cKey := http.CanonicalHeaderKey(key) - if strings.HasPrefix(cKey, "x-amz-meta-") { + if strings.HasPrefix(cKey, "X-Amz-Meta-") { 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) } } diff --git a/xl-v1-object.go b/xl-v1-object.go index cfc23cd3d..8e75535d4 100644 --- a/xl-v1-object.go +++ b/xl-v1-object.go @@ -226,6 +226,7 @@ func (xl xlObjects) getObjectInfo(bucket, object string) (objInfo ObjectInfo, er MD5Sum: xlMeta.Meta["md5Sum"], ContentType: xlMeta.Meta["content-type"], ContentEncoding: xlMeta.Meta["content-encoding"], + UserDefined: xlMeta.Meta, } return objInfo, nil }