minio/api-definitions.go

220 lines
5.8 KiB
Go
Raw Normal View History

2015-01-21 02:16:06 -05:00
/*
* Minio Cloud Storage, (C) 2015 Minio, Inc.
2015-01-21 02:16:06 -05:00
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package main
2015-01-20 19:08:14 -05:00
import "encoding/xml"
2015-01-20 19:08:14 -05:00
2015-02-23 19:46:48 -05:00
// Limit number of objects in a given response
const (
maxObjectList = 1000
)
2015-10-08 14:12:02 -04:00
// AccessControlPolicyResponse - format for get bucket acl response
type AccessControlPolicyResponse struct {
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ AccessControlPolicy" json:"-"`
2015-10-08 14:12:02 -04:00
AccessControlList struct {
Grant []Grant
}
Owner Owner
}
// Grant container for grantee and permission
type Grant struct {
Grantee struct {
ID string
DisplayName string
EmailAddress string
Type string
URI string
}
Permission string
}
// ListObjectsResponse - format for list objects response
type ListObjectsResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ ListBucketResult" json:"-"`
CommonPrefixes []*CommonPrefix
Contents []*Object
Delimiter string
// Encoding type used to encode object keys in the response.
EncodingType string
// A flag that indicates whether or not ListObjects returned all of the results
// that satisfied the search criteria.
IsTruncated bool
Marker string
MaxKeys int
Name string
// When response is truncated (the IsTruncated element value in the response
// is true), you can use the key name in this field as marker in the subsequent
2015-07-24 21:09:53 -04:00
// request to get next set of objects. Server lists objects in alphabetical
// order Note: This element is returned only if you have delimiter request parameter
// specified. If response does not include the NextMaker and it is truncated,
// you can use the value of the last Key in the response as the marker in the
// subsequent request to get the next set of object keys.
NextMarker string
Prefix string
2015-01-21 03:50:23 -05:00
}
// Part container for part metadata
type Part struct {
PartNumber int
ETag string
LastModified string
Size int64
}
2015-05-09 14:41:26 -04:00
// ListPartsResponse - format for list parts response
type ListPartsResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ ListPartsResult" json:"-"`
2015-05-09 14:41:26 -04:00
Bucket string
Key string
UploadID string `xml:"UploadId"`
Initiator Initiator
Owner Owner
// The class of storage used to store the object.
StorageClass string
PartNumberMarker int
NextPartNumberMarker int
MaxParts int
IsTruncated bool
// List of parts
Part []*Part
}
// ListMultipartUploadsResponse - format for list multipart uploads response
type ListMultipartUploadsResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ ListMultipartUploadsResult" json:"-"`
Bucket string
KeyMarker string
UploadIDMarker string `xml:"UploadIdMarker"`
NextKeyMarker string
NextUploadIDMarker string `xml:"NextUploadIdMarker"`
EncodingType string
MaxUploads int
IsTruncated bool
Upload []*Upload
Prefix string
Delimiter string
CommonPrefixes []*CommonPrefix
}
// ListBucketsResponse - format for list buckets response
type ListBucketsResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ ListAllMyBucketsResult" json:"-"`
// Container for one or more buckets.
Buckets struct {
Bucket []*Bucket
2015-03-04 17:24:56 -05:00
} // Buckets are nested
Owner Owner
2015-01-21 03:50:23 -05:00
}
// Upload container for in progress multipart upload
type Upload struct {
Key string
UploadID string `xml:"UploadId"`
Initiator Initiator
Owner Owner
StorageClass string
Initiated string
}
// CommonPrefix container for prefix response in ListObjectsResponse
type CommonPrefix struct {
Prefix string
}
// Bucket container for bucket metadata
2015-01-21 03:50:23 -05:00
type Bucket struct {
Name string
CreationDate string
2015-01-20 19:08:14 -05:00
}
// Object container for object metadata
type Object struct {
ETag string
2015-01-20 19:08:14 -05:00
Key string
LastModified string
Size int64
Owner Owner
// The class of storage used to store the object.
2015-01-20 19:08:14 -05:00
StorageClass string
}
2015-05-09 14:41:26 -04:00
// Initiator inherit from Owner struct, fields are same
type Initiator Owner
2015-03-06 00:07:19 -05:00
// Owner - bucket owner/principal
2015-01-20 19:08:14 -05:00
type Owner struct {
ID string
DisplayName string
}
// InitiateMultipartUploadResponse container for InitiateMultiPartUpload response, provides uploadID to start MultiPart upload
type InitiateMultipartUploadResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ InitiateMultipartUploadResult" json:"-"`
2015-05-07 22:55:30 -04:00
Bucket string
Key string
UploadID string `xml:"UploadId"`
}
// CompleteMultipartUploadResponse container for completed multipart upload response
type CompleteMultipartUploadResponse struct {
2015-07-02 16:14:21 -04:00
XMLName xml.Name `xml:"http://s3.amazonaws.com/doc/2006-03-01/ CompleteMultipartUploadResult" json:"-"`
Location string
Bucket string
Key string
ETag string
}
2015-02-23 19:46:48 -05:00
// List of not implemented bucket queries
var notimplementedBucketResourceNames = map[string]bool{
"policy": true,
"cors": true,
"lifecycle": true,
"logging": true,
"notification": true,
2015-10-08 14:12:02 -04:00
"replication": true,
"tagging": true,
"versions": true,
"requestPayment": true,
"versioning": true,
"website": true,
}
2015-02-23 19:46:48 -05:00
// List of not implemented object queries
var notimplementedObjectResourceNames = map[string]bool{
2015-05-07 22:55:30 -04:00
"torrent": true,
"acl": true,
"policy": true,
}