1
0
mirror of https://github.com/minio/mc.git synced 2025-11-26 20:03:05 +03:00
Files
mc/cmd/client.go
2020-08-07 08:15:27 -07:00

201 lines
6.5 KiB
Go

/*
* MinIO Client (C) 2015 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"
"os"
"time"
"github.com/minio/mc/pkg/probe"
minio "github.com/minio/minio-go/v7"
"github.com/minio/minio-go/v7/pkg/encrypt"
"github.com/minio/minio-go/v7/pkg/lifecycle"
"github.com/minio/minio-go/v7/pkg/replication"
)
// DirOpt - list directory option.
type DirOpt int8
const (
// DirNone - do not include directories in the list.
DirNone DirOpt = iota
// DirFirst - include directories before objects in the list.
DirFirst
// DirLast - include directories after objects in the list.
DirLast
)
// Default number of multipart workers for a Put operation.
const defaultMultipartThreadsNum = 4
// GetOptions holds options of the GET operation
type GetOptions struct {
sse encrypt.ServerSide
versionID string
}
// StatOptions holds options of the HEAD operation
type StatOptions struct {
incomplete bool
preserve bool
sse encrypt.ServerSide
timeRef time.Time
versionID string
}
// ListOptions holds options for listing operation
type ListOptions struct {
isRecursive bool
isIncomplete bool
isFetchMeta bool
withOlderVersions bool
withDeleteMarkers bool
timeRef time.Time
showDir DirOpt
}
// CopyOptions holds options for copying operation
type CopyOptions struct {
versionID string
size int64
srcSSE, tgtSSE encrypt.ServerSide
metadata map[string]string
disableMultipart bool
isPreserve bool
}
// Client - client interface
type Client interface {
// Common operations
Stat(ctx context.Context, opts StatOptions) (content *ClientContent, err *probe.Error)
List(ctx context.Context, opts ListOptions) <-chan *ClientContent
// Bucket operations
MakeBucket(ctx context.Context, region string, ignoreExisting, withLock bool) *probe.Error
// Object lock config
SetObjectLockConfig(ctx context.Context, mode minio.RetentionMode, validity uint64, unit minio.ValidityUnit) *probe.Error
GetObjectLockConfig(ctx context.Context) (mode minio.RetentionMode, validity uint64, unit minio.ValidityUnit, perr *probe.Error)
// Access policy operations.
GetAccess(ctx context.Context) (access string, policyJSON string, error *probe.Error)
GetAccessRules(ctx context.Context) (policyRules map[string]string, error *probe.Error)
SetAccess(ctx context.Context, access string, isJSON bool) *probe.Error
// I/O operations
Copy(ctx context.Context, source string, opts CopyOptions, progress io.Reader) *probe.Error
// Runs select expression on object storage on specific files.
Select(ctx context.Context, expression string, sse encrypt.ServerSide, opts SelectObjectOpts) (io.ReadCloser, *probe.Error)
// I/O operations with metadata.
Get(ctx context.Context, opts GetOptions) (reader io.ReadCloser, err *probe.Error)
Put(ctx context.Context, reader io.Reader, size int64, metadata map[string]string, progress io.Reader, sse encrypt.ServerSide, md5, disableMultipart, isPreserve bool) (n int64, err *probe.Error)
// Object Locking related API
PutObjectRetention(ctx context.Context, mode minio.RetentionMode, retainUntilDate time.Time, bypassGovernance bool) *probe.Error
PutObjectLegalHold(ctx context.Context, hold minio.LegalHoldStatus) *probe.Error
// I/O operations with expiration
ShareDownload(ctx context.Context, expires time.Duration) (string, *probe.Error)
ShareUpload(context.Context, bool, time.Duration, string) (string, map[string]string, *probe.Error)
// Watch events
Watch(ctx context.Context, options WatchOptions) (*WatchObject, *probe.Error)
// Delete operations
Remove(ctx context.Context, isIncomplete, isRemoveBucket, isBypass bool, contentCh <-chan *ClientContent) (errorCh <-chan *probe.Error)
// GetURL returns back internal url
GetURL() ClientURL
AddUserAgent(app, version string)
// Tagging operations
GetTags(ctx context.Context) (map[string]string, *probe.Error)
SetTags(ctx context.Context, tags string) *probe.Error
DeleteTags(ctx context.Context) *probe.Error
// Lifecycle operations
GetLifecycle(ctx context.Context) (*lifecycle.Configuration, *probe.Error)
SetLifecycle(ctx context.Context, config *lifecycle.Configuration) *probe.Error
// Versioning operations
GetVersioning(ctx context.Context) (minio.BucketVersioningConfiguration, *probe.Error)
SetVersioning(ctx context.Context, status string) *probe.Error
// Replication operations
GetReplication(ctx context.Context) (replication.Config, *probe.Error)
SetReplication(ctx context.Context, cfg *replication.Config, opts replication.Options) *probe.Error
RemoveReplication(ctx context.Context) *probe.Error
// Encryption operations
GetEncryption(ctx context.Context) (string, string, *probe.Error)
SetEncryption(ctx context.Context, algorithm, kmsKeyID string) *probe.Error
DeleteEncryption(ctx context.Context) *probe.Error
}
// ClientContent - Content container for content metadata
type ClientContent struct {
URL ClientURL
Time time.Time
Size int64
Type os.FileMode
StorageClass string
Metadata map[string]string
UserMetadata map[string]string
ETag string
Expires time.Time
Expiration time.Time
ExpirationRuleID string
RetentionEnabled bool
RetentionMode string
RetentionDuration string
BypassGovernance bool
LegalHoldEnabled bool
LegalHold string
VersionID string
IsDeleteMarker bool
IsLatest bool
Err *probe.Error
}
// Config - see http://docs.amazonwebservices.com/AmazonS3/latest/dev/index.html?RESTAuthentication.html
type Config struct {
AccessKey string
SecretKey string
SessionToken string
Signature string
HostURL string
AppName string
AppVersion string
AppComments []string
Debug bool
Insecure bool
Lookup minio.BucketLookupType
}
// SelectObjectOpts - opts entered for select API
type SelectObjectOpts struct {
InputSerOpts map[string]map[string]string
OutputSerOpts map[string]map[string]string
CompressionType minio.SelectCompressionType
}