| 
									
										
										
										
											2016-03-28 03:37:21 +08:00
										 |  |  | /* | 
					
						
							|  |  |  |  * Minio Cloud Storage, (C) 2016 Minio, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												fs: Break fs package to top-level and introduce ObjectAPI interface.
ObjectAPI interface brings in changes needed for XL ObjectAPI layer.
The new interface for any ObjectAPI layer is as below
```
// ObjectAPI interface.
type ObjectAPI interface {
        // Bucket resource API.
        DeleteBucket(bucket string) *probe.Error
        ListBuckets() ([]BucketInfo, *probe.Error)
        MakeBucket(bucket string) *probe.Error
        GetBucketInfo(bucket string) (BucketInfo, *probe.Error)
        // Bucket query API.
        ListObjects(bucket, prefix, marker, delimiter string, maxKeys int) (ListObjectsResult, *probe.Error)
        ListMultipartUploads(bucket string, resources BucketMultipartResourcesMetadata) (BucketMultipartResourcesMetadata, *probe.Error)
        // Object resource API.
        GetObject(bucket, object string, startOffset int64) (io.ReadCloser, *probe.Error)
        GetObjectInfo(bucket, object string) (ObjectInfo, *probe.Error)
        PutObject(bucket string, object string, size int64, data io.Reader, metadata map[string]string) (ObjectInfo, *probe.Error)
        DeleteObject(bucket, object string) *probe.Error
        // Object query API.
        NewMultipartUpload(bucket, object string) (string, *probe.Error)
        PutObjectPart(bucket, object, uploadID string, partID int, size int64, data io.Reader, md5Hex string) (string, *probe.Error)
        ListObjectParts(bucket, object string, resources ObjectResourcesMetadata) (ObjectResourcesMetadata, *probe.Error)
        CompleteMultipartUpload(bucket string, object string, uploadID string, parts []CompletePart) (ObjectInfo, *probe.Error)
        AbortMultipartUpload(bucket, object, uploadID string) *probe.Error
}
```
											
										 
											2016-03-31 07:15:28 +08:00
										 |  |  | import router "github.com/gorilla/mux" | 
					
						
							| 
									
										
										
										
											2016-03-28 03:37:21 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-13 03:45:15 +08:00
										 |  |  | // objectAPIHandler implements and provides http handlers for S3 API.
 | 
					
						
							|  |  |  | type objectAPIHandlers struct { | 
					
						
							| 
									
										
										
										
											2016-04-30 05:24:10 +08:00
										 |  |  | 	ObjectAPI ObjectLayer | 
					
						
							| 
									
										
										
										
											2016-03-28 03:37:21 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // registerAPIRouter - registers S3 compatible APIs.
 | 
					
						
							| 
									
										
										
										
											2016-04-13 03:45:15 +08:00
										 |  |  | func registerAPIRouter(mux *router.Router, api objectAPIHandlers) { | 
					
						
							| 
									
										
										
										
											2016-03-28 03:37:21 +08:00
										 |  |  | 	// API Router
 | 
					
						
							|  |  |  | 	apiRouter := mux.NewRoute().PathPrefix("/").Subrouter() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Bucket router
 | 
					
						
							|  |  |  | 	bucket := apiRouter.PathPrefix("/{bucket}").Subrouter() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/// Object operations
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// HeadObject
 | 
					
						
							|  |  |  | 	bucket.Methods("HEAD").Path("/{object:.+}").HandlerFunc(api.HeadObjectHandler) | 
					
						
							|  |  |  | 	// PutObjectPart
 | 
					
						
							|  |  |  | 	bucket.Methods("PUT").Path("/{object:.+}").HandlerFunc(api.PutObjectPartHandler).Queries("partNumber", "{partNumber:[0-9]+}", "uploadId", "{uploadId:.*}") | 
					
						
							|  |  |  | 	// ListObjectPxarts
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").Path("/{object:.+}").HandlerFunc(api.ListObjectPartsHandler).Queries("uploadId", "{uploadId:.*}") | 
					
						
							|  |  |  | 	// CompleteMultipartUpload
 | 
					
						
							|  |  |  | 	bucket.Methods("POST").Path("/{object:.+}").HandlerFunc(api.CompleteMultipartUploadHandler).Queries("uploadId", "{uploadId:.*}") | 
					
						
							|  |  |  | 	// NewMultipartUpload
 | 
					
						
							|  |  |  | 	bucket.Methods("POST").Path("/{object:.+}").HandlerFunc(api.NewMultipartUploadHandler).Queries("uploads", "") | 
					
						
							|  |  |  | 	// AbortMultipartUpload
 | 
					
						
							|  |  |  | 	bucket.Methods("DELETE").Path("/{object:.+}").HandlerFunc(api.AbortMultipartUploadHandler).Queries("uploadId", "{uploadId:.*}") | 
					
						
							|  |  |  | 	// GetObject
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").Path("/{object:.+}").HandlerFunc(api.GetObjectHandler) | 
					
						
							|  |  |  | 	// CopyObject
 | 
					
						
							|  |  |  | 	bucket.Methods("PUT").Path("/{object:.+}").HeadersRegexp("X-Amz-Copy-Source", ".*?(\\/).*?").HandlerFunc(api.CopyObjectHandler) | 
					
						
							|  |  |  | 	// PutObject
 | 
					
						
							|  |  |  | 	bucket.Methods("PUT").Path("/{object:.+}").HandlerFunc(api.PutObjectHandler) | 
					
						
							|  |  |  | 	// DeleteObject
 | 
					
						
							|  |  |  | 	bucket.Methods("DELETE").Path("/{object:.+}").HandlerFunc(api.DeleteObjectHandler) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/// Bucket operations
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// GetBucketLocation
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").HandlerFunc(api.GetBucketLocationHandler).Queries("location", "") | 
					
						
							|  |  |  | 	// GetBucketPolicy
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").HandlerFunc(api.GetBucketPolicyHandler).Queries("policy", "") | 
					
						
							|  |  |  | 	// ListMultipartUploads
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").HandlerFunc(api.ListMultipartUploadsHandler).Queries("uploads", "") | 
					
						
							|  |  |  | 	// ListObjects
 | 
					
						
							|  |  |  | 	bucket.Methods("GET").HandlerFunc(api.ListObjectsHandler) | 
					
						
							|  |  |  | 	// PutBucketPolicy
 | 
					
						
							|  |  |  | 	bucket.Methods("PUT").HandlerFunc(api.PutBucketPolicyHandler).Queries("policy", "") | 
					
						
							|  |  |  | 	// PutBucket
 | 
					
						
							|  |  |  | 	bucket.Methods("PUT").HandlerFunc(api.PutBucketHandler) | 
					
						
							|  |  |  | 	// HeadBucket
 | 
					
						
							|  |  |  | 	bucket.Methods("HEAD").HandlerFunc(api.HeadBucketHandler) | 
					
						
							|  |  |  | 	// PostPolicy
 | 
					
						
							|  |  |  | 	bucket.Methods("POST").HeadersRegexp("Content-Type", "multipart/form-data*").HandlerFunc(api.PostPolicyBucketHandler) | 
					
						
							|  |  |  | 	// DeleteMultipleObjects
 | 
					
						
							|  |  |  | 	bucket.Methods("POST").HandlerFunc(api.DeleteMultipleObjectsHandler) | 
					
						
							|  |  |  | 	// DeleteBucketPolicy
 | 
					
						
							|  |  |  | 	bucket.Methods("DELETE").HandlerFunc(api.DeleteBucketPolicyHandler).Queries("policy", "") | 
					
						
							|  |  |  | 	// DeleteBucket
 | 
					
						
							|  |  |  | 	bucket.Methods("DELETE").HandlerFunc(api.DeleteBucketHandler) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/// Root operation
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// ListBuckets
 | 
					
						
							|  |  |  | 	apiRouter.Methods("GET").HandlerFunc(api.ListBucketsHandler) | 
					
						
							|  |  |  | } |