Documentation ¶
Overview ¶
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 ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func New ¶
New returns a handler which implements the docker registry protocol. It should be registered at the site root.
func TLS ¶
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 ManifestsStore ¶
type Option ¶
type Option func(r *registry)
Option describes the available options for creating the registry.
func WithBlobHandler ¶
func WithBlobHandler(h BlobHandler) Option
func WithCustomManifestsStore ¶
func WithCustomManifestsStore(store ManifestsStore) Option
func WithReferrersSupport ¶
WithReferrersSupport enables the referrers API endpoint (OCI 1.1+)