forked from TrueCloudLab/distribution
553d48d618
After consideration, it has been decided that the interfaces defined in the storage package provide a good base for interacting with various registry instances. Whether interacting with a remote API or a local, on-disk registry, these types have proved flexible. By moving them here, they can become the central components of interacting with distribution components. Signed-off-by: Stephen J Day <stephen.day@docker.com>
51 lines
1.7 KiB
Go
51 lines
1.7 KiB
Go
package storage
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/docker/distribution"
|
|
storagedriver "github.com/docker/distribution/registry/storage/driver"
|
|
)
|
|
|
|
// LayerHandler provides middleware for serving the contents of a Layer.
|
|
type LayerHandler interface {
|
|
// Resolve returns an http.Handler which can serve the contents of a given
|
|
// Layer if possible, or nil and an error when unsupported. This may
|
|
// directly serve the contents of the layer or issue a redirect to another
|
|
// URL hosting the content.
|
|
Resolve(layer distribution.Layer) (http.Handler, error)
|
|
}
|
|
|
|
// LayerHandlerInitFunc is the type of a LayerHandler factory function and is
|
|
// used to register the contsructor for different LayerHandler backends.
|
|
type LayerHandlerInitFunc func(storageDriver storagedriver.StorageDriver, options map[string]interface{}) (LayerHandler, error)
|
|
|
|
var layerHandlers map[string]LayerHandlerInitFunc
|
|
|
|
// RegisterLayerHandler is used to register an LayerHandlerInitFunc for
|
|
// a LayerHandler backend with the given name.
|
|
func RegisterLayerHandler(name string, initFunc LayerHandlerInitFunc) error {
|
|
if layerHandlers == nil {
|
|
layerHandlers = make(map[string]LayerHandlerInitFunc)
|
|
}
|
|
if _, exists := layerHandlers[name]; exists {
|
|
return fmt.Errorf("name already registered: %s", name)
|
|
}
|
|
|
|
layerHandlers[name] = initFunc
|
|
|
|
return nil
|
|
}
|
|
|
|
// GetLayerHandler constructs a LayerHandler
|
|
// with the given options using the named backend.
|
|
func GetLayerHandler(name string, options map[string]interface{}, storageDriver storagedriver.StorageDriver) (LayerHandler, error) {
|
|
if layerHandlers != nil {
|
|
if initFunc, exists := layerHandlers[name]; exists {
|
|
return initFunc(storageDriver, options)
|
|
}
|
|
}
|
|
|
|
return nil, fmt.Errorf("no layer handler registered with name: %s", name)
|
|
}
|