cas

package
v0.0.0-...-a76f865 Latest Latest
Warning

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

Go to latest
Published: Jan 10, 2025 License: Apache-2.0 Imports: 29 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	// ErrImageNotFound describes the error for when image is not found in containerd
	ErrImageNotFound = errors.New("image not found")
)

Functions

func CheckAndCorrectBlobHash

func CheckAndCorrectBlobHash(blobHash string) string

CheckAndCorrectBlobHash checks if the blobHash has hash algo sha256 as prefix. If not then it'll prepend it.

func GetRoofFsPath

func GetRoofFsPath(rootPath string) string

GetRoofFsPath returns rootfs path

Types

type BlobInfo

type BlobInfo struct {
	// Digest to identify the blob uniquely. The format will/should be <algo>:<hash> (currently supporting only sha256:<hash>).
	Digest string

	// Size of the blob
	Size int64

	// Labels to add/define properties for the blob
	Labels map[string]string
}

BlobInfo holds the info of a blob present in CAS's blob store

type CAS

type CAS interface {

	// CheckBlobExists: returns true if the blob exists.
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	CheckBlobExists(blobHash string) bool
	// GetBlobInfo: returns BlobInfo of type BlobInfo for the given blobHash.
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	// Returns error if no blob is found for the given 'blobHash'.
	GetBlobInfo(blobHash string) (*BlobInfo, error)
	// ListBlobInfo: returns list of BlobInfo for all the blob present in CAS
	ListBlobInfo() ([]*BlobInfo, error)
	// ListBlobsMediaTypes get a map of all blobs and their media types.
	// If a blob does not have a media type, it is not returned here.
	// If you want *all* blobs, whether or not it has a type, use ListBlobInfo
	ListBlobsMediaTypes() (map[string]string, error)
	// IngestBlob: parses the given one or more `blobs` (BlobStatus) and for each blob reads the blob data from
	// BlobStatus.Path and ingests it into CAS's blob store.
	// Accepts a custom context. If ctx is nil, then default context will be used.
	// Returns a list of loaded BlobStatus and an error is thrown if the read blob's hash does not match with the
	// respective BlobStatus.Sha256 or if there is an exception while reading the blob data.
	// In case of exception, the returned list of loaded blob will contain all the blob that were loaded until that point.
	IngestBlob(ctx context.Context, blobs ...types.BlobStatus) ([]types.BlobStatus, error)
	// UpdateBlobInfo updates BlobInfo of a blob in CAS.
	// Arg is BlobInfo type struct in which BlobInfo.Digest is mandatory, and other field to be fill only if need to be updated
	// Returns error is no blob is found match blobInfo.Digest
	UpdateBlobInfo(blobInfo BlobInfo) error
	// ReadBlob: returns a reader to consume the raw data of the blob which matches the given arg 'blobHash'.
	// Returns error if no blob is found for the given 'blobHash'.
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	ReadBlob(ctx context.Context, blobHash string) (io.Reader, error)
	// RemoveBlob: removes a blob which matches the given arg 'blobHash'.
	// To keep this method idempotent, no error is returned if the given arg 'blobHash' does not match any blob.
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	RemoveBlob(blobHash string) error
	// Children: returns a list of child blob hashes if the given arg 'blobHash' belongs to a
	// index or a manifest blob, else an empty list is returned.
	// Format of returned blob hash list and arg 'blobHash' is <algo>:<hash> (currently supporting only sha256:<hash>)
	Children(blobHash string) ([]string, error)

	// CreateImage: creates a reference which points to a blob with 'blobHash'. 'blobHash' must belong to a index blob
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	// Returns error if no blob is found matching the given 'blobHash' or if the given 'blobHash' does not belong to an index.
	CreateImage(reference, mediaType, blobHash string) error
	// GetImageHash: returns a blob hash of format <algo>:<hash> (currently supporting only sha256:<hash>) which the given 'reference' is pointing to.
	// Returns error if the given 'reference' is not found.
	GetImageHash(reference string) (string, error)
	// GetImageLabels  returns the labels set on the image.
	// Returns error if the given reference is not found
	GetImageLabels(reference string) (map[string]string, error)
	// ListImages: returns a list of references
	ListImages() ([]string, error)
	// RemoveImage removes an reference from CAS
	// To keep this method idempotent, no error  is returned if the given 'reference' is not found.
	RemoveImage(reference string) error
	// ReplaceImage: replaces the blob hash to which the given 'reference' is pointing to with the given 'blobHash'.
	// Returns error if the given 'reference' or a blob matching the given arg 'blobHash' is not found.
	// Returns if the given 'blobHash' does not belong to an index.
	// Arg 'blobHash' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	ReplaceImage(reference, mediaType, blobHash string) error

	// CreateSnapshotForImage: creates an snapshot with the given snapshotID for the given 'reference'
	// Arg 'snapshotID' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	CreateSnapshotForImage(snapshotID, reference string) error
	// MountSnapshot: mounts the snapshot on the given target path
	// Arg 'snapshotID' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	MountSnapshot(snapshotID, targetPath string) error
	// SnapshotUsage returns current usage of snapshot in bytes
	// We create snapshots for every layer of image and one active snapshot on top of them
	// which presents the writable layer to store modified files
	// If parents defined also adds usage of all parents of provided snapshot,
	// not only the top active one
	SnapshotUsage(snapshotID string, parents bool) (int64, error)
	// ListSnapshots returns a list of snapshotIDs where each entry is of format <algo>:<hash> (currently supporting only sha256:<hash>).
	ListSnapshots() ([]string, error)
	// RemoveSnapshot removes a snapshot matching the given 'snapshotID'.
	// Arg 'snapshotID' should be of format <algo>:<hash> (currently supporting only sha256:<hash>).
	// To keep this method idempotent, no error  is returned if the given 'snapshotID' is not found.
	RemoveSnapshot(snapshotID string) error

	// PrepareContainerRootDir creates a reference pointing to the rootBlob and prepares a writable snapshot
	// from the reference. Before preparing container's root directory, this API must remove any existing state
	// that may have accumulated (like existing snapshots being available, etc.)
	// This effectively voids any kind of caching, but on the flip side frees us
	// from cache invalidation. Additionally this API should deposit an OCI config json file and image name
	// next to the rootfs so that the effective structure becomes:
	//    rootPath/rootfs, rootPath/image-config.json, rootPath/image-name
	// The rootPath is expected to end in a basename that becomes the snapshotID
	PrepareContainerRootDir(rootPath, reference, rootBlobSha string) error

	// UnmountContainerRootDir unmounts container's rootPath.
	// with force flag will use MNT_FORCE
	// if not mounted will not return error
	UnmountContainerRootDir(rootPath string, force bool) error

	// RemoveContainerRootDir removes contents of a container's rootPath, existing snapshot and reference.
	RemoveContainerRootDir(rootPath string) error

	// IngestBlobsAndCreateImage is a combination of IngestBlobs and CreateImage APIs,
	// but this API will add a lock, upload all the blobs, add reference to the blobs and release the lock.
	// By adding a lock before uploading the blobs we prevent the unreferenced blobs from getting GCed.
	// We will assume that the first blob in the list will be the root blob for which the reference will be created.
	// Returns an error if the read blob's hash does not match with the respective BlobStatus.Sha256 or
	// if there is an exception while reading the blob data.
	// NOTE: This either loads all the blobs or loads nothing. In other words, in case of error,
	// this API will GC all blobs that were loaded until that point.
	IngestBlobsAndCreateImage(reference string, root types.BlobStatus, blobs ...types.BlobStatus) ([]types.BlobStatus, error)

	// Resolver get an interface that satisfies resolver.ResolverCloser to communicate directly with a generic CAS
	Resolver(ctx context.Context) (resolver.ResolverCloser, error)

	// CtrNewUserServicesCtx() returns a context and a cancel function
	CtrNewUserServicesCtx() (context.Context, context.CancelFunc)

	// CloseClient closes (only) the respective CAS client initialized while calling `NewCAS()`.
	CloseClient() error
}

CAS provides methods to interact with CAS clients Context handling should be taken care by the underlying implementor.

func NewCAS

func NewCAS(selectedCAS string) (CAS, error)

NewCAS returns new CAS object with a new client of underlying implementor(selectedCAS). It's the caller/user's responsibility to close the respective client after use by calling CAS.CloseClient().

Jump to

Keyboard shortcuts

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