Documentation ¶
Index ¶
- Constants
- func ConstructBlobServiceURL(storageAccount, domain string, emulatorEnabled bool) (string, error)
- func GetABSCredentialsLastModifiedTime() (time.Time, error)
- func GetBucketImmutabilityTime(s *S3SnapStore) (bool, *int64, error)
- func GetEnvVarOrError(varName string) (string, error)
- func GetEnvVarToBool(varName string) (bool, error)
- func GetGCSCredentialsLastModifiedTime() (time.Time, error)
- func GetOCSCredentialsLastModifiedTime() (time.Time, error)
- func GetOSSCredentialsLastModifiedTime() (time.Time, error)
- func GetS3CredentialsLastModifiedTime() (time.Time, error)
- func GetSnapstore(config *brtypes.SnapstoreConfig) (brtypes.SnapStore, error)
- func GetSnapstoreSecretModifiedTime(snapstoreProvider string) (time.Time, error)
- func GetSwiftCredentialsLastModifiedTime() (time.Time, error)
- func NewSnapshot(kind string, startRevision, lastRevision int64, compressionSuffix string, ...) *brtypes.Snapshot
- func NewSnapstoreConfig() *brtypes.SnapstoreConfig
- func ParseSnapshot(snapPath string) (*brtypes.Snapshot, error)
- type ABSSnapStore
- type AzureBlockBlobClientI
- type AzureContainerClient
- type FailedSnapStore
- type GCSSnapStore
- type LocalSnapStore
- func (s *LocalSnapStore) Delete(snap brtypes.Snapshot) error
- func (s *LocalSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
- func (s *LocalSnapStore) List(_ bool) (brtypes.SnapList, error)
- func (s *LocalSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) error
- func (s *LocalSnapStore) Size(snap brtypes.Snapshot) (int64, error)
- type OSSBucket
- type OSSSnapStore
- type S3SnapStore
- func NewECSSnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
- func NewOCSSnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
- func NewS3FromClient(bucket, prefix, tempDir string, maxParallelChunkUploads uint, ...) *S3SnapStore
- func NewS3SnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
- type SSECredentials
- type SwiftSnapStore
Constants ¶
const (
// AzuriteEndpoint is the environment variable which indicates the endpoint at which the Azurite emulator is hosted
AzuriteEndpoint = "AZURE_STORAGE_API_ENDPOINT"
)
Variables ¶
This section is empty.
Functions ¶
func ConstructBlobServiceURL ¶ added in v0.29.0
ConstructBlobServiceURL constructs the Blob Service URL based on the activation status of the Azurite Emulator. The `domain` must either be the default Azure global blob storage domain, or a specific domain for Azurite (without HTTP scheme).
func GetABSCredentialsLastModifiedTime ¶ added in v0.29.0
GetABSCredentialsLastModifiedTime returns the latest modification timestamp of the ABS credential file(s)
func GetBucketImmutabilityTime ¶ added in v0.33.0
func GetBucketImmutabilityTime(s *S3SnapStore) (bool, *int64, error)
GetBucketImmutabilityTime check objectlock is enabled for given bucket, if it does returns the retention period.
func GetEnvVarOrError ¶
GetEnvVarOrError returns the value of specified environment variable or terminates if it's not defined.
func GetEnvVarToBool ¶ added in v0.29.0
GetEnvVarToBool return corresponding boolen if an environment is set to string true|false
func GetGCSCredentialsLastModifiedTime ¶ added in v0.29.0
GetGCSCredentialsLastModifiedTime returns the latest modification timestamp of the GCS credential file
func GetOCSCredentialsLastModifiedTime ¶ added in v0.29.0
GetOCSCredentialsLastModifiedTime returns the latest modification timestamp of the OCS credential file(s)
func GetOSSCredentialsLastModifiedTime ¶ added in v0.29.0
GetOSSCredentialsLastModifiedTime returns the latest modification timestamp of the OSS credential file(s)
func GetS3CredentialsLastModifiedTime ¶ added in v0.29.0
GetS3CredentialsLastModifiedTime returns the latest modification timestamp of the AWS credential file(s)
func GetSnapstore ¶
func GetSnapstore(config *brtypes.SnapstoreConfig) (brtypes.SnapStore, error)
GetSnapstore returns the snapstore object for give storageProvider with specified container
func GetSnapstoreSecretModifiedTime ¶ added in v0.29.0
GetSnapstoreSecretModifiedTime returns the latest modification timestamp of the access credential files. Returns an error if fetching the timestamp of the access credential files fails.
func GetSwiftCredentialsLastModifiedTime ¶ added in v0.29.0
GetSwiftCredentialsLastModifiedTime returns the latest modification timestamp of the Swift credential file(s)
func NewSnapshot ¶
func NewSnapshot(kind string, startRevision, lastRevision int64, compressionSuffix string, isFinal bool) *brtypes.Snapshot
NewSnapshot returns the snapshot object.
func NewSnapstoreConfig ¶ added in v0.29.0
func NewSnapstoreConfig() *brtypes.SnapstoreConfig
NewSnapstoreConfig returns the snapstore config.
Types ¶
type ABSSnapStore ¶
type ABSSnapStore struct {
// contains filtered or unexported fields
}
ABSSnapStore is an ABS backed snapstore.
func NewABSSnapStore ¶
func NewABSSnapStore(config *brtypes.SnapstoreConfig) (*ABSSnapStore, error)
NewABSSnapStore creates a new ABSSnapStore using a shared configuration and a specified bucket
func NewABSSnapStoreFromClient ¶ added in v0.31.0
func NewABSSnapStoreFromClient(container, prefix, tempDir string, maxParallelChunkUploads uint, minChunkSize int64, client azureContainerClientI) *ABSSnapStore
NewABSSnapStoreFromClient returns a new ABS object for a given container using the supplied storageClient
func (*ABSSnapStore) Delete ¶
func (a *ABSSnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store
func (*ABSSnapStore) Fetch ¶
func (a *ABSSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*ABSSnapStore) List ¶
func (a *ABSSnapStore) List(includeAll bool) (brtypes.SnapList, error)
List will return sorted list with all snapshot files on store.
func (*ABSSnapStore) Save ¶
func (a *ABSSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) (err error)
Save will write the snapshot to store
type AzureBlockBlobClientI ¶ added in v0.31.0
type AzureBlockBlobClientI interface { // DownloadStream reads a range of bytes from a blob. The response also includes the blob's properties and metadata. DownloadStream(context.Context, *blob.DownloadStreamOptions) (blob.DownloadStreamResponse, error) // Delete marks the specified blob or snapshot for deletion. The blob is later deleted during the internal garbage collection of Azure Blob Storage. // Note that deleting a blob also deletes all its snapshots. Delete(context.Context, *blob.DeleteOptions) (blob.DeleteResponse, error) // CommitBlockList writes a blob by specifying the list of block IDs that make up the blob. // In order to be written as part of a blob, a block must have been successfully written // to the server in a prior PutBlock operation. You can call PutBlockList to update a blob // by uploading only those blocks that have changed, then committing the new and existing // blocks together. Any blocks not specified in the block list and permanently deleted. CommitBlockList(context.Context, []string, *blockblob.CommitBlockListOptions) (blockblob.CommitBlockListResponse, error) // StageBlock uploads the specified block to the block blob's "staging area" to be later committed by a call to CommitBlockList. StageBlock(context.Context, string, io.ReadSeekCloser, *blockblob.StageBlockOptions) (blockblob.StageBlockResponse, error) }
AzureBlockBlobClientI defines the methods that are invoked from the Azure Block Blob API.
type AzureContainerClient ¶ added in v0.31.0
AzureContainerClient embeds an azure *container.Client (its methods are overridden in tests).
func (*AzureContainerClient) NewBlockBlobClient ¶ added in v0.31.0
func (a *AzureContainerClient) NewBlockBlobClient(blobName string) AzureBlockBlobClientI
NewBlockBlobClient simply returns the BlockBlobClient that the embeded *azcontainer.Client returns.
type FailedSnapStore ¶ added in v0.29.0
FailedSnapStore is snapstore with fake failed object store as backend
func NewFailedSnapStore ¶ added in v0.29.0
func NewFailedSnapStore() *FailedSnapStore
NewFailedSnapStore create new FailedSnapStore object.
func (*FailedSnapStore) Delete ¶ added in v0.29.0
func (f *FailedSnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store
func (*FailedSnapStore) Fetch ¶ added in v0.29.0
func (f *FailedSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*FailedSnapStore) List ¶ added in v0.29.0
func (f *FailedSnapStore) List(_ bool) (brtypes.SnapList, error)
List will list the snapshots from store
func (*FailedSnapStore) Save ¶ added in v0.29.0
func (f *FailedSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) error
Save will write the snapshot to store
type GCSSnapStore ¶
type GCSSnapStore struct {
// contains filtered or unexported fields
}
GCSSnapStore is snapstore with GCS object store as backend.
func NewGCSSnapStore ¶
func NewGCSSnapStore(config *brtypes.SnapstoreConfig) (*GCSSnapStore, error)
NewGCSSnapStore create new GCSSnapStore from shared configuration with specified bucket.
func NewGCSSnapStoreFromClient ¶
func NewGCSSnapStoreFromClient(bucket, prefix, tempDir string, maxParallelChunkUploads uint, minChunkSize int64, chunkDirSuffix string, cli stiface.Client) *GCSSnapStore
NewGCSSnapStoreFromClient create new GCSSnapStore from shared configuration with specified bucket.
func (*GCSSnapStore) Delete ¶
func (s *GCSSnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store.
func (*GCSSnapStore) Fetch ¶
func (s *GCSSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store.
func (*GCSSnapStore) List ¶
func (s *GCSSnapStore) List(includeAll bool) (brtypes.SnapList, error)
List returns a sorted list of all snapshot files in the object store, excluding those snapshots tagged with `x-ignore-etcd-snapshot-exclude` in their object metadata/tags. To include these tagged snapshots in the List output, pass `true` as the argument.
func (*GCSSnapStore) Save ¶
func (s *GCSSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) (err error)
Save will write the snapshot to store.
type LocalSnapStore ¶
type LocalSnapStore struct {
// contains filtered or unexported fields
}
LocalSnapStore is snapstore with local disk as backend
func NewLocalSnapStore ¶
func NewLocalSnapStore(prefix string) (*LocalSnapStore, error)
NewLocalSnapStore return the new local disk based snapstore
func (*LocalSnapStore) Delete ¶
func (s *LocalSnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store
func (*LocalSnapStore) Fetch ¶
func (s *LocalSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*LocalSnapStore) List ¶
func (s *LocalSnapStore) List(_ bool) (brtypes.SnapList, error)
List will return sorted list with all snapshot files on store.
func (*LocalSnapStore) Save ¶
func (s *LocalSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) error
Save will write the snapshot to store
type OSSBucket ¶
type OSSBucket interface { GetObject(objectKey string, options ...oss.Option) (io.ReadCloser, error) InitiateMultipartUpload(objectKey string, options ...oss.Option) (oss.InitiateMultipartUploadResult, error) CompleteMultipartUpload(imur oss.InitiateMultipartUploadResult, parts []oss.UploadPart, options ...oss.Option) (oss.CompleteMultipartUploadResult, error) ListObjects(options ...oss.Option) (oss.ListObjectsResult, error) DeleteObject(objectKey string, options ...oss.Option) error UploadPart(imur oss.InitiateMultipartUploadResult, reader io.Reader, partSize int64, partNumber int, options ...oss.Option) (oss.UploadPart, error) AbortMultipartUpload(imur oss.InitiateMultipartUploadResult, options ...oss.Option) error }
OSSBucket is an interface for oss.Bucket used in snapstore
type OSSSnapStore ¶
type OSSSnapStore struct {
// contains filtered or unexported fields
}
OSSSnapStore is snapstore with Alicloud OSS object store as backend
func NewOSSFromBucket ¶
func NewOSSFromBucket(prefix, tempDir string, maxParallelChunkUploads uint, minChunkSize int64, bucket OSSBucket) *OSSSnapStore
NewOSSFromBucket will create the new OSS snapstore object from OSS bucket
func NewOSSSnapStore ¶
func NewOSSSnapStore(config *brtypes.SnapstoreConfig) (*OSSSnapStore, error)
NewOSSSnapStore create new OSSSnapStore from shared configuration with specified bucket
func (*OSSSnapStore) Delete ¶
func (s *OSSSnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store
func (*OSSSnapStore) Fetch ¶
func (s *OSSSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*OSSSnapStore) List ¶
func (s *OSSSnapStore) List(_ bool) (brtypes.SnapList, error)
List will return sorted list with all snapshot files on store.
func (*OSSSnapStore) Save ¶
func (s *OSSSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) (err error)
Save will write the snapshot to store
type S3SnapStore ¶
type S3SnapStore struct { SSECredentials // contains filtered or unexported fields }
S3SnapStore is snapstore with AWS S3 object store as backend
func NewECSSnapStore ¶ added in v0.29.0
func NewECSSnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
NewECSSnapStore creates a new S3SnapStore from shared configuration with the specified bucket.
func NewOCSSnapStore ¶ added in v0.29.0
func NewOCSSnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
NewOCSSnapStore creates a new S3SnapStore from shared configuration with the specified bucket.
func NewS3FromClient ¶
func NewS3FromClient(bucket, prefix, tempDir string, maxParallelChunkUploads uint, minChunkSize int64, cli s3iface.S3API, sseCreds SSECredentials) *S3SnapStore
NewS3FromClient will create the new S3 snapstore object from S3 client
func NewS3SnapStore ¶
func NewS3SnapStore(config *brtypes.SnapstoreConfig) (*S3SnapStore, error)
NewS3SnapStore create new S3SnapStore from shared configuration with specified bucket
func (*S3SnapStore) Delete ¶
func (s *S3SnapStore) Delete(snap brtypes.Snapshot) error
Delete should delete the snapshot file from store
func (*S3SnapStore) Fetch ¶
func (s *S3SnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*S3SnapStore) List ¶
func (s *S3SnapStore) List(_ bool) (brtypes.SnapList, error)
List returns a sorted list of snapshot files present in the object store. If Bucket versioning is not enabled for S3 bucket:
- It returns a sorted list of all snapshot files present in the object store.
If Bucket versioning or object lock is enabled for S3 bucket:
- It returns a sorted list of all firstCreated/oldest snapshot files present in the object store.
- It also captures the "ImmutabilityExpiryTime" and "VersionID" of corresponding versioned snapshot.
func (*S3SnapStore) Save ¶
func (s *S3SnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) (err error)
Save will write the snapshot to store
type SSECredentials ¶ added in v0.29.0
type SSECredentials struct {
// contains filtered or unexported fields
}
SSECredentials to hold fields for server-side encryption in I/O operations
type SwiftSnapStore ¶
type SwiftSnapStore struct {
// contains filtered or unexported fields
}
SwiftSnapStore is snapstore with Openstack Swift as backend
func NewSwiftSnapStore ¶
func NewSwiftSnapStore(config *brtypes.SnapstoreConfig) (*SwiftSnapStore, error)
NewSwiftSnapStore create new SwiftSnapStore from shared configuration with specified bucket
func NewSwiftSnapstoreFromClient ¶
func NewSwiftSnapstoreFromClient(bucket, prefix, tempDir string, maxParallelChunkUploads uint, minChunkSize int64, cli *gophercloud.ServiceClient) *SwiftSnapStore
NewSwiftSnapstoreFromClient will create the new Swift snapstore object from Swift client
func (*SwiftSnapStore) Delete ¶
func (s *SwiftSnapStore) Delete(snap brtypes.Snapshot) error
Delete deletes the objects related to the DLO (dynamic large object) from the store. This includes the manifest object as well as the segment objects, as described in https://docs.openstack.org/swift/latest/overview_large_objects.html
func (*SwiftSnapStore) Fetch ¶
func (s *SwiftSnapStore) Fetch(snap brtypes.Snapshot) (io.ReadCloser, error)
Fetch should open reader for the snapshot file from store
func (*SwiftSnapStore) List ¶
func (s *SwiftSnapStore) List(_ bool) (brtypes.SnapList, error)
List will return sorted list with all snapshot files on store.
func (*SwiftSnapStore) Save ¶
func (s *SwiftSnapStore) Save(snap brtypes.Snapshot, rc io.ReadCloser) (err error)
Save will write the snapshot to store, as a DLO (dynamic large object), as described in https://docs.openstack.org/swift/latest/overview_large_objects.html