Merge pull request #44 from harshavardhana/pr_out_get_bucket_list_objects_compliance_maxkeys_to_1000_rename_content_struct_to_item_for_cosmetic_reasons_for_xml_decoding_on_client_side

master
Harshavardhana 10 years ago
commit 32abe927d0
  1. 10
      pkg/webapi/minioapi/definitions.go
  2. 9
      pkg/webapi/minioapi/minioapi.go

@ -20,13 +20,17 @@ import (
"encoding/xml"
)
const (
MAX_OBJECT_LIST = 1000
)
type ObjectListResponse struct {
XMLName xml.Name `xml:"ListBucketResult"`
Name string `xml:"Name"`
Name string
Marker string
MaxKeys int
IsTruncated bool
Contents []Content `xml:"Contents",innerxml`
Contents []*Item `xml:"Contents",innerxml`
}
type BucketListResponse struct {
@ -42,7 +46,7 @@ type Bucket struct {
CreationDate string
}
type Content struct {
type Item struct {
Key string
LastModified string
ETag string

@ -157,7 +157,6 @@ func (server *minioApi) listObjectsHandler(w http.ResponseWriter, req *http.Requ
}
contentType := "xml"
if _, ok := req.Header["Accept"]; ok {
if req.Header["Accept"][0] == "application/json" {
contentType = "json"
@ -176,8 +175,8 @@ func (server *minioApi) listObjectsHandler(w http.ResponseWriter, req *http.Requ
w.Header().Set("Content-Type", `xml version="1.0" encoding="UTF-8"`)
encoder = xml.NewEncoder(&bytesBuffer)
}
encoder.Encode(response)
encoder.Encode(response)
w.Write(bytesBuffer.Bytes())
}
@ -228,7 +227,7 @@ func generateBucketsListResult(buckets []mstorage.BucketMetadata) (data BucketLi
}
func generateObjectsListResult(bucket string, objects []mstorage.ObjectMetadata) (data ObjectListResponse) {
contents := []Content{}
var contents []*Item
owner := Owner{
ID: "minio",
@ -236,7 +235,7 @@ func generateObjectsListResult(bucket string, objects []mstorage.ObjectMetadata)
}
for _, object := range objects {
content := Content{
content := &Item{
Key: object.Key,
LastModified: formatDate(object.Created),
ETag: object.ETag,
@ -249,7 +248,7 @@ func generateObjectsListResult(bucket string, objects []mstorage.ObjectMetadata)
data = ObjectListResponse{
Name: bucket,
Contents: contents,
MaxKeys: len(objects),
MaxKeys: MAX_OBJECT_LIST,
IsTruncated: false,
}
return

Loading…
Cancel
Save