snapstore

package
v0.33.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 17, 2025 License: Apache-2.0 Imports: 49 Imported by: 1

Documentation

Index

Constants

View Source
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

func ConstructBlobServiceURL(storageAccount, domain string, emulatorEnabled bool) (string, error)

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

func GetABSCredentialsLastModifiedTime() (time.Time, error)

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

func GetEnvVarOrError(varName string) (string, error)

GetEnvVarOrError returns the value of specified environment variable or terminates if it's not defined.

func GetEnvVarToBool added in v0.29.0

func GetEnvVarToBool(varName string) (bool, error)

GetEnvVarToBool return corresponding boolen if an environment is set to string true|false

func GetGCSCredentialsLastModifiedTime added in v0.29.0

func GetGCSCredentialsLastModifiedTime() (time.Time, error)

GetGCSCredentialsLastModifiedTime returns the latest modification timestamp of the GCS credential file

func GetOCSCredentialsLastModifiedTime added in v0.29.0

func GetOCSCredentialsLastModifiedTime() (time.Time, error)

GetOCSCredentialsLastModifiedTime returns the latest modification timestamp of the OCS credential file(s)

func GetOSSCredentialsLastModifiedTime added in v0.29.0

func GetOSSCredentialsLastModifiedTime() (time.Time, error)

GetOSSCredentialsLastModifiedTime returns the latest modification timestamp of the OSS credential file(s)

func GetS3CredentialsLastModifiedTime added in v0.29.0

func GetS3CredentialsLastModifiedTime() (time.Time, error)

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

func GetSnapstoreSecretModifiedTime(snapstoreProvider string) (time.Time, error)

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

func GetSwiftCredentialsLastModifiedTime() (time.Time, error)

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.

func ParseSnapshot

func ParseSnapshot(snapPath string) (*brtypes.Snapshot, error)

ParseSnapshot parse <snapPath> to create snapshot structure

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

type AzureContainerClient struct {
	*container.Client
}

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

type FailedSnapStore struct {
	brtypes.SnapStore
}

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

func (*LocalSnapStore) Size

func (s *LocalSnapStore) Size(snap brtypes.Snapshot) (int64, error)

Size should return size of the snapshot file from 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

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL