mirror of https://github.com/minio/minio.git
				
				
				
			
		
			
				
	
	
		
			144 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Go
		
	
	
	
/*
 | 
						|
 * MinIO Cloud Storage, (C) 2016-2020 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 cmd
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"io"
 | 
						|
	"net/http"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/minio/minio-go/v7/pkg/encrypt"
 | 
						|
	"github.com/minio/minio-go/v7/pkg/tags"
 | 
						|
	"github.com/minio/minio/pkg/bucket/policy"
 | 
						|
	"github.com/minio/minio/pkg/madmin"
 | 
						|
)
 | 
						|
 | 
						|
// CheckCopyPreconditionFn returns true if copy precondition check failed.
 | 
						|
type CheckCopyPreconditionFn func(o ObjectInfo, encETag string) bool
 | 
						|
 | 
						|
// GetObjectInfoFn is the signature of GetObjectInfo function.
 | 
						|
type GetObjectInfoFn func(ctx context.Context, bucket, object string, opts ObjectOptions) (ObjectInfo, error)
 | 
						|
 | 
						|
// ObjectOptions represents object options for ObjectLayer object operations
 | 
						|
type ObjectOptions struct {
 | 
						|
	ServerSideEncryption encrypt.ServerSide
 | 
						|
	Versioned            bool                    // indicates if the bucket is versioned
 | 
						|
	WalkVersions         bool                    // indicates if the we are interested in walking versions
 | 
						|
	VersionID            string                  // Specifies the versionID which needs to be overwritten or read
 | 
						|
	MTime                time.Time               // Is only set in POST/PUT operations
 | 
						|
	UserDefined          map[string]string       // only set in case of POST/PUT operations
 | 
						|
	PartNumber           int                     // only useful in case of GetObject/HeadObject
 | 
						|
	CheckCopyPrecondFn   CheckCopyPreconditionFn // only set during CopyObject preconditional valuation
 | 
						|
}
 | 
						|
 | 
						|
// BucketOptions represents bucket options for ObjectLayer bucket operations
 | 
						|
type BucketOptions struct {
 | 
						|
	Location          string
 | 
						|
	LockEnabled       bool
 | 
						|
	VersioningEnabled bool
 | 
						|
}
 | 
						|
 | 
						|
// LockType represents required locking for ObjectLayer operations
 | 
						|
type LockType int
 | 
						|
 | 
						|
const (
 | 
						|
	noLock LockType = iota
 | 
						|
	readLock
 | 
						|
	writeLock
 | 
						|
)
 | 
						|
 | 
						|
// ObjectLayer implements primitives for object API layer.
 | 
						|
type ObjectLayer interface {
 | 
						|
	// Locking operations on object.
 | 
						|
	NewNSLock(ctx context.Context, bucket string, objects ...string) RWLocker
 | 
						|
 | 
						|
	// Storage operations.
 | 
						|
	Shutdown(context.Context) error
 | 
						|
	CrawlAndGetDataUsage(ctx context.Context, bf *bloomFilter, updates chan<- DataUsageInfo) error
 | 
						|
	StorageInfo(ctx context.Context, local bool) (StorageInfo, []error) // local queries only local disks
 | 
						|
 | 
						|
	// Bucket operations.
 | 
						|
	MakeBucketWithLocation(ctx context.Context, bucket string, opts BucketOptions) error
 | 
						|
	GetBucketInfo(ctx context.Context, bucket string) (bucketInfo BucketInfo, err error)
 | 
						|
	ListBuckets(ctx context.Context) (buckets []BucketInfo, err error)
 | 
						|
	DeleteBucket(ctx context.Context, bucket string, forceDelete bool) error
 | 
						|
	ListObjects(ctx context.Context, bucket, prefix, marker, delimiter string, maxKeys int) (result ListObjectsInfo, err error)
 | 
						|
	ListObjectsV2(ctx context.Context, bucket, prefix, continuationToken, delimiter string, maxKeys int, fetchOwner bool, startAfter string) (result ListObjectsV2Info, err error)
 | 
						|
	ListObjectVersions(ctx context.Context, bucket, prefix, marker, versionMarker, delimiter string, maxKeys int) (result ListObjectVersionsInfo, err error)
 | 
						|
	// Walk lists all objects including versions, delete markers.
 | 
						|
	Walk(ctx context.Context, bucket, prefix string, results chan<- ObjectInfo, opts ObjectOptions) error
 | 
						|
 | 
						|
	// Object operations.
 | 
						|
 | 
						|
	// GetObjectNInfo returns a GetObjectReader that satisfies the
 | 
						|
	// ReadCloser interface. The Close method unlocks the object
 | 
						|
	// after reading, so it must always be called after usage.
 | 
						|
	//
 | 
						|
	// IMPORTANTLY, when implementations return err != nil, this
 | 
						|
	// function MUST NOT return a non-nil ReadCloser.
 | 
						|
	GetObjectNInfo(ctx context.Context, bucket, object string, rs *HTTPRangeSpec, h http.Header, lockType LockType, opts ObjectOptions) (reader *GetObjectReader, err error)
 | 
						|
	GetObject(ctx context.Context, bucket, object string, startOffset int64, length int64, writer io.Writer, etag string, opts ObjectOptions) (err error)
 | 
						|
	GetObjectInfo(ctx context.Context, bucket, object string, opts ObjectOptions) (objInfo ObjectInfo, err error)
 | 
						|
	PutObject(ctx context.Context, bucket, object string, data *PutObjReader, opts ObjectOptions) (objInfo ObjectInfo, err error)
 | 
						|
	CopyObject(ctx context.Context, srcBucket, srcObject, destBucket, destObject string, srcInfo ObjectInfo, srcOpts, dstOpts ObjectOptions) (objInfo ObjectInfo, err error)
 | 
						|
	DeleteObject(ctx context.Context, bucket, object string, opts ObjectOptions) (ObjectInfo, error)
 | 
						|
	DeleteObjects(ctx context.Context, bucket string, objects []ObjectToDelete, opts ObjectOptions) ([]DeletedObject, []error)
 | 
						|
 | 
						|
	// Multipart operations.
 | 
						|
	ListMultipartUploads(ctx context.Context, bucket, prefix, keyMarker, uploadIDMarker, delimiter string, maxUploads int) (result ListMultipartsInfo, err error)
 | 
						|
	NewMultipartUpload(ctx context.Context, bucket, object string, opts ObjectOptions) (uploadID string, err error)
 | 
						|
	CopyObjectPart(ctx context.Context, srcBucket, srcObject, destBucket, destObject string, uploadID string, partID int,
 | 
						|
		startOffset int64, length int64, srcInfo ObjectInfo, srcOpts, dstOpts ObjectOptions) (info PartInfo, err error)
 | 
						|
	PutObjectPart(ctx context.Context, bucket, object, uploadID string, partID int, data *PutObjReader, opts ObjectOptions) (info PartInfo, err error)
 | 
						|
	GetMultipartInfo(ctx context.Context, bucket, object, uploadID string, opts ObjectOptions) (info MultipartInfo, err error)
 | 
						|
	ListObjectParts(ctx context.Context, bucket, object, uploadID string, partNumberMarker int, maxParts int, opts ObjectOptions) (result ListPartsInfo, err error)
 | 
						|
	AbortMultipartUpload(ctx context.Context, bucket, object, uploadID string) error
 | 
						|
	CompleteMultipartUpload(ctx context.Context, bucket, object, uploadID string, uploadedParts []CompletePart, opts ObjectOptions) (objInfo ObjectInfo, err error)
 | 
						|
 | 
						|
	// Healing operations.
 | 
						|
	ReloadFormat(ctx context.Context, dryRun bool) error
 | 
						|
	HealFormat(ctx context.Context, dryRun bool) (madmin.HealResultItem, error)
 | 
						|
	HealBucket(ctx context.Context, bucket string, dryRun, remove bool) (madmin.HealResultItem, error)
 | 
						|
	HealObject(ctx context.Context, bucket, object, versionID string, opts madmin.HealOpts) (madmin.HealResultItem, error)
 | 
						|
	HealObjects(ctx context.Context, bucket, prefix string, opts madmin.HealOpts, fn HealObjectFn) error
 | 
						|
	ListBucketsHeal(ctx context.Context) (buckets []BucketInfo, err error)
 | 
						|
 | 
						|
	// Policy operations
 | 
						|
	SetBucketPolicy(context.Context, string, *policy.Policy) error
 | 
						|
	GetBucketPolicy(context.Context, string) (*policy.Policy, error)
 | 
						|
	DeleteBucketPolicy(context.Context, string) error
 | 
						|
 | 
						|
	// Supported operations check
 | 
						|
	IsNotificationSupported() bool
 | 
						|
	IsListenBucketSupported() bool
 | 
						|
	IsEncryptionSupported() bool
 | 
						|
	IsTaggingSupported() bool
 | 
						|
	IsCompressionSupported() bool
 | 
						|
 | 
						|
	// Backend related metrics
 | 
						|
	GetMetrics(ctx context.Context) (*Metrics, error)
 | 
						|
 | 
						|
	// Check Readiness
 | 
						|
	IsReady(ctx context.Context) bool
 | 
						|
 | 
						|
	// ObjectTagging operations
 | 
						|
	PutObjectTags(context.Context, string, string, string, ObjectOptions) error
 | 
						|
	GetObjectTags(context.Context, string, string, ObjectOptions) (*tags.Tags, error)
 | 
						|
	DeleteObjectTags(context.Context, string, string, ObjectOptions) error
 | 
						|
}
 |