2015-01-17 02:24:07 +00:00
|
|
|
package storage
|
|
|
|
|
2015-02-09 22:44:58 +00:00
|
|
|
import (
|
2015-02-11 02:14:23 +00:00
|
|
|
storagedriver "github.com/docker/distribution/registry/storage/driver"
|
2015-02-09 22:44:58 +00:00
|
|
|
"golang.org/x/net/context"
|
|
|
|
)
|
2015-01-17 02:24:07 +00:00
|
|
|
|
|
|
|
// registry is the top-level implementation of Registry for use in the storage
|
|
|
|
// package. All instances should descend from this object.
|
|
|
|
type registry struct {
|
|
|
|
driver storagedriver.StorageDriver
|
|
|
|
pm *pathMapper
|
|
|
|
blobStore *blobStore
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewRegistryWithDriver creates a new registry instance from the provided
|
|
|
|
// driver. The resulting registry may be shared by multiple goroutines but is
|
|
|
|
// cheap to allocate.
|
|
|
|
func NewRegistryWithDriver(driver storagedriver.StorageDriver) Registry {
|
|
|
|
bs := &blobStore{}
|
|
|
|
|
|
|
|
reg := ®istry{
|
|
|
|
driver: driver,
|
|
|
|
blobStore: bs,
|
|
|
|
|
|
|
|
// TODO(sday): This should be configurable.
|
|
|
|
pm: defaultPathMapper,
|
|
|
|
}
|
|
|
|
|
|
|
|
reg.blobStore.registry = reg
|
|
|
|
|
|
|
|
return reg
|
|
|
|
}
|
|
|
|
|
|
|
|
// Repository returns an instance of the repository tied to the registry.
|
|
|
|
// Instances should not be shared between goroutines but are cheap to
|
|
|
|
// allocate. In general, they should be request scoped.
|
2015-02-09 22:44:58 +00:00
|
|
|
func (reg *registry) Repository(ctx context.Context, name string) Repository {
|
2015-01-17 02:24:07 +00:00
|
|
|
return &repository{
|
2015-02-09 22:44:58 +00:00
|
|
|
ctx: ctx,
|
2015-01-17 02:24:07 +00:00
|
|
|
registry: reg,
|
|
|
|
name: name,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// repository provides name-scoped access to various services.
|
|
|
|
type repository struct {
|
|
|
|
*registry
|
2015-02-09 22:44:58 +00:00
|
|
|
ctx context.Context
|
2015-01-17 02:24:07 +00:00
|
|
|
name string
|
|
|
|
}
|
|
|
|
|
|
|
|
// Name returns the name of the repository.
|
|
|
|
func (repo *repository) Name() string {
|
|
|
|
return repo.name
|
|
|
|
}
|
|
|
|
|
|
|
|
// Manifests returns an instance of ManifestService. Instantiation is cheap and
|
|
|
|
// may be context sensitive in the future. The instance should be used similar
|
|
|
|
// to a request local.
|
|
|
|
func (repo *repository) Manifests() ManifestService {
|
|
|
|
return &manifestStore{
|
|
|
|
repository: repo,
|
|
|
|
revisionStore: &revisionStore{
|
|
|
|
repository: repo,
|
|
|
|
},
|
|
|
|
tagStore: &tagStore{
|
|
|
|
repository: repo,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Layers returns an instance of the LayerService. Instantiation is cheap and
|
|
|
|
// may be context sensitive in the future. The instance should be used similar
|
|
|
|
// to a request local.
|
|
|
|
func (repo *repository) Layers() LayerService {
|
|
|
|
return &layerStore{
|
|
|
|
repository: repo,
|
|
|
|
}
|
|
|
|
}
|