2016-04-29 14:24:10 -07: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.
|
|
|
|
*/
|
|
|
|
|
2016-08-18 16:23:42 -07:00
|
|
|
package cmd
|
2016-04-29 14:24:10 -07:00
|
|
|
|
2017-09-19 12:40:27 -07:00
|
|
|
import (
|
|
|
|
"io"
|
2018-01-12 20:34:52 -08:00
|
|
|
"time"
|
2017-09-19 12:40:27 -07:00
|
|
|
|
2018-02-09 15:19:30 -08:00
|
|
|
"github.com/minio/minio-go/pkg/policy"
|
2017-10-21 22:30:34 -07:00
|
|
|
"github.com/minio/minio/pkg/hash"
|
2018-01-22 14:54:55 -08:00
|
|
|
"github.com/minio/minio/pkg/madmin"
|
2017-09-19 12:40:27 -07:00
|
|
|
)
|
2016-04-29 14:24:10 -07:00
|
|
|
|
|
|
|
// ObjectLayer implements primitives for object API layer.
|
|
|
|
type ObjectLayer interface {
|
2016-05-26 14:13:10 -07:00
|
|
|
// Storage operations.
|
2016-08-15 07:55:48 +01:00
|
|
|
Shutdown() error
|
2016-05-26 14:13:10 -07:00
|
|
|
StorageInfo() StorageInfo
|
|
|
|
|
2016-04-29 14:24:10 -07:00
|
|
|
// Bucket operations.
|
2017-06-01 09:43:20 -07:00
|
|
|
MakeBucketWithLocation(bucket string, location string) error
|
2016-04-29 14:24:10 -07:00
|
|
|
GetBucketInfo(bucket string) (bucketInfo BucketInfo, err error)
|
|
|
|
ListBuckets() (buckets []BucketInfo, err error)
|
|
|
|
DeleteBucket(bucket string) error
|
|
|
|
ListObjects(bucket, prefix, marker, delimiter string, maxKeys int) (result ListObjectsInfo, err error)
|
2018-02-09 15:19:30 -08:00
|
|
|
ListObjectsV2(bucket, prefix, continuationToken, delimiter string, maxKeys int, fetchOwner bool, startAfter string) (result ListObjectsV2Info, err error)
|
2016-04-29 14:24:10 -07:00
|
|
|
|
|
|
|
// Object operations.
|
2018-01-12 20:34:52 -08:00
|
|
|
GetObject(bucket, object string, startOffset int64, length int64, writer io.Writer, etag string) (err error)
|
2016-04-29 14:24:10 -07:00
|
|
|
GetObjectInfo(bucket, object string) (objInfo ObjectInfo, err error)
|
2017-10-21 22:30:34 -07:00
|
|
|
PutObject(bucket, object string, data *hash.Reader, metadata map[string]string) (objInfo ObjectInfo, err error)
|
2018-02-21 00:48:47 -08:00
|
|
|
CopyObject(srcBucket, srcObject, destBucket, destObject string, srcInfo ObjectInfo) (objInfo ObjectInfo, err error)
|
2016-04-29 14:24:10 -07:00
|
|
|
DeleteObject(bucket, object string) error
|
|
|
|
|
|
|
|
// Multipart operations.
|
|
|
|
ListMultipartUploads(bucket, prefix, keyMarker, uploadIDMarker, delimiter string, maxUploads int) (result ListMultipartsInfo, err error)
|
2016-05-18 19:54:25 -07:00
|
|
|
NewMultipartUpload(bucket, object string, metadata map[string]string) (uploadID string, err error)
|
2018-02-21 00:48:47 -08:00
|
|
|
CopyObjectPart(srcBucket, srcObject, destBucket, destObject string, uploadID string, partID int,
|
|
|
|
startOffset int64, length int64, srcInfo ObjectInfo) (info PartInfo, err error)
|
2017-10-21 22:30:34 -07:00
|
|
|
PutObjectPart(bucket, object, uploadID string, partID int, data *hash.Reader) (info PartInfo, err error)
|
2016-04-29 14:24:10 -07:00
|
|
|
ListObjectParts(bucket, object, uploadID string, partNumberMarker int, maxParts int) (result ListPartsInfo, err error)
|
|
|
|
AbortMultipartUpload(bucket, object, uploadID string) error
|
2017-11-14 00:25:10 -08:00
|
|
|
CompleteMultipartUpload(bucket, object, uploadID string, uploadedParts []CompletePart) (objInfo ObjectInfo, err error)
|
2016-10-14 19:57:40 -07:00
|
|
|
|
|
|
|
// Healing operations.
|
2018-02-15 17:45:57 -08:00
|
|
|
HealFormat(dryRun bool) (madmin.HealResultItem, error)
|
2018-01-22 14:54:55 -08:00
|
|
|
HealBucket(bucket string, dryRun bool) ([]madmin.HealResultItem, error)
|
|
|
|
HealObject(bucket, object string, dryRun bool) (madmin.HealResultItem, error)
|
2017-01-19 18:34:18 +01:00
|
|
|
ListBucketsHeal() (buckets []BucketInfo, err error)
|
2016-10-14 19:57:40 -07:00
|
|
|
ListObjectsHeal(bucket, prefix, marker, delimiter string, maxKeys int) (ListObjectsInfo, error)
|
2018-01-12 20:34:52 -08:00
|
|
|
|
|
|
|
// Locking operations
|
|
|
|
ListLocks(bucket, prefix string, duration time.Duration) ([]VolumeLockInfo, error)
|
|
|
|
ClearLocks([]VolumeLockInfo) error
|
2018-02-09 15:19:30 -08:00
|
|
|
|
|
|
|
// Policy operations
|
|
|
|
SetBucketPolicy(string, policy.BucketAccessPolicy) error
|
|
|
|
GetBucketPolicy(string) (policy.BucketAccessPolicy, error)
|
|
|
|
RefreshBucketPolicy(string) error
|
|
|
|
DeleteBucketPolicy(string) error
|
|
|
|
|
|
|
|
// Supported operations check
|
|
|
|
IsNotificationSupported() bool
|
|
|
|
IsEncryptionSupported() bool
|
2016-04-29 14:24:10 -07:00
|
|
|
}
|