package registry

import "github.com/google/go-containerregistry/pkg/registry"

Package registry implements a docker V2 registry and the OCI distribution specification.

It is designed to be used anywhere a low dependency container registry is needed, with an initial focus on tests.

Its goal is to be standards compliant and its strictness will increase over time.

This is currently a low flightmiles system. It's likely quite safe to use in tests; If you're using it in production, please let us know how and send us CL's for integration tests.

Index

Functions

func New

func New(opts ...Option) http.Handler

New returns a handler which implements the docker registry protocol. It should be registered at the site root.

func TLS

func TLS(domain string) (*httptest.Server, error)

TLS returns an httptest server, with an http client that has been configured to send all requests to the returned server. The TLS certs are generated for the given domain which should correspond to the domain the image is stored in. If you need a transport, Client().Transport is correctly configured.

Types

type BlobDeleteHandler

type BlobDeleteHandler interface {
	// Delete the blob contents.
	Delete(ctx context.Context, repo string, h v1.Hash) error
}

BlobDeleteHandler is an extension interface representing a blob storage backend that can delete blob contents.

type BlobHandler

type BlobHandler interface {
	// Get gets the blob contents, or errNotFound if the blob wasn't found.
	Get(ctx context.Context, repo string, h v1.Hash) (io.ReadCloser, error)
}

BlobHandler represents a minimal blob storage backend, capable of serving blob contents.

func NewDiskBlobHandler

func NewDiskBlobHandler(dir string) BlobHandler

func NewInMemoryBlobHandler

func NewInMemoryBlobHandler() BlobHandler

type BlobPutHandler

type BlobPutHandler interface {
	// Put puts the blob contents.
	//
	// The contents will be verified against the expected size and digest
	// as the contents are read, and an error will be returned if these
	// don't match. Implementations should return that error, or a wrapper
	// around that error, to return the correct error when these don't match.
	Put(ctx context.Context, repo string, h v1.Hash, rc io.ReadCloser) error
}

BlobPutHandler is an extension interface representing a blob storage backend that can write blob contents.

type BlobStatHandler

type BlobStatHandler interface {
	// Stat returns the size of the blob, or errNotFound if the blob wasn't
	// found, or redirectError if the blob can be found elsewhere.
	Stat(ctx context.Context, repo string, h v1.Hash) (int64, error)
}

BlobStatHandler is an extension interface representing a blob storage backend that can serve metadata about blobs.

type Option

type Option func(r *registry)

Option describes the available options for creating the registry.

func Logger

func Logger(l *log.Logger) Option

Logger overrides the logger used to record requests to the registry.

func WithBlobHandler

func WithBlobHandler(h BlobHandler) Option

func WithReferrersSupport

func WithReferrersSupport(enabled bool) Option

WithReferrersSupport enables the referrers API endpoint (OCI 1.1+)

func WithWarning

func WithWarning(prob float64, msg string) Option

Source Files

blobs.go blobs_disk.go error.go manifest.go registry.go tls.go

Version
v0.20.3 (latest)
Published
Jan 15, 2025
Platform
linux/amd64
Imports
21 packages
Last checked
19 hours ago

Tools for package owners.