mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Extract ImageService interface from the image service
Signed-off-by: Djordje Lukic <djordje.lukic@docker.com> Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
This commit is contained in:
parent
5daceee6ca
commit
5b0eb69635
3 changed files with 89 additions and 3 deletions
|
@ -79,7 +79,7 @@ type Daemon struct {
|
||||||
containers container.Store
|
containers container.Store
|
||||||
containersReplica container.ViewDB
|
containersReplica container.ViewDB
|
||||||
execCommands *exec.Store
|
execCommands *exec.Store
|
||||||
imageService *images.ImageService
|
imageService ImageService
|
||||||
configStore *config.Config
|
configStore *config.Config
|
||||||
statsCollector *stats.Collector
|
statsCollector *stats.Collector
|
||||||
defaultLogConfig containertypes.LogConfig
|
defaultLogConfig containertypes.LogConfig
|
||||||
|
@ -1473,7 +1473,7 @@ func (daemon *Daemon) IdentityMapping() idtools.IdentityMapping {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ImageService returns the Daemon's ImageService
|
// ImageService returns the Daemon's ImageService
|
||||||
func (daemon *Daemon) ImageService() *images.ImageService {
|
func (daemon *Daemon) ImageService() ImageService {
|
||||||
return daemon.imageService
|
return daemon.imageService
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1481,7 +1481,7 @@ func (daemon *Daemon) ImageService() *images.ImageService {
|
||||||
func (daemon *Daemon) BuilderBackend() builder.Backend {
|
func (daemon *Daemon) BuilderBackend() builder.Backend {
|
||||||
return struct {
|
return struct {
|
||||||
*Daemon
|
*Daemon
|
||||||
*images.ImageService
|
ImageService
|
||||||
}{daemon, daemon.imageService}
|
}{daemon, daemon.imageService}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
78
daemon/image_service.go
Normal file
78
daemon/image_service.go
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
package daemon
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"github.com/docker/distribution"
|
||||||
|
"github.com/docker/distribution/reference"
|
||||||
|
"github.com/docker/docker/api/types"
|
||||||
|
"github.com/docker/docker/api/types/backend"
|
||||||
|
"github.com/docker/docker/api/types/filters"
|
||||||
|
imagetype "github.com/docker/docker/api/types/image"
|
||||||
|
"github.com/docker/docker/api/types/registry"
|
||||||
|
"github.com/docker/docker/builder"
|
||||||
|
"github.com/docker/docker/container"
|
||||||
|
"github.com/docker/docker/daemon/images"
|
||||||
|
"github.com/docker/docker/image"
|
||||||
|
"github.com/docker/docker/layer"
|
||||||
|
v1 "github.com/opencontainers/image-spec/specs-go/v1"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ImageService is a temporary interface to assist in the migration to the
|
||||||
|
// containerd image-store. This interface should not be considered stable,
|
||||||
|
// and may change over time.
|
||||||
|
type ImageService interface {
|
||||||
|
// Images
|
||||||
|
|
||||||
|
PullImage(ctx context.Context, image, tag string, platform *v1.Platform, metaHeaders map[string][]string, authConfig *types.AuthConfig, outStream io.Writer) error
|
||||||
|
PushImage(ctx context.Context, image, tag string, metaHeaders map[string][]string, authConfig *types.AuthConfig, outStream io.Writer) error
|
||||||
|
CreateImage(config []byte, parent string) (builder.Image, error)
|
||||||
|
ImageDelete(imageRef string, force, prune bool) ([]types.ImageDeleteResponseItem, error)
|
||||||
|
ExportImage(names []string, outStream io.Writer) error
|
||||||
|
LoadImage(inTar io.ReadCloser, outStream io.Writer, quiet bool) error
|
||||||
|
Images(ctx context.Context, opts types.ImageListOptions) ([]*types.ImageSummary, error)
|
||||||
|
LogImageEvent(imageID, refName, action string)
|
||||||
|
LogImageEventWithAttributes(imageID, refName, action string, attributes map[string]string)
|
||||||
|
CountImages() int
|
||||||
|
ImageDiskUsage(ctx context.Context) ([]*types.ImageSummary, error)
|
||||||
|
ImagesPrune(ctx context.Context, pruneFilters filters.Args) (*types.ImagesPruneReport, error)
|
||||||
|
ImportImage(src string, repository string, platform *v1.Platform, tag string, msg string, inConfig io.ReadCloser, outStream io.Writer, changes []string) error
|
||||||
|
TagImage(imageName, repository, tag string) (string, error)
|
||||||
|
TagImageWithReference(imageID image.ID, newTag reference.Named) error
|
||||||
|
GetImage(refOrID string, platform *v1.Platform) (retImg *image.Image, retErr error)
|
||||||
|
ImageHistory(name string) ([]*imagetype.HistoryResponseItem, error)
|
||||||
|
CommitImage(c backend.CommitConfig) (image.ID, error)
|
||||||
|
SquashImage(id, parent string) (string, error)
|
||||||
|
|
||||||
|
// Layers
|
||||||
|
|
||||||
|
GetImageAndReleasableLayer(ctx context.Context, refOrID string, opts backend.GetImageAndLayerOptions) (builder.Image, builder.ROLayer, error)
|
||||||
|
CreateLayer(container *container.Container, initFunc layer.MountInit) (layer.RWLayer, error)
|
||||||
|
GetLayerByID(cid string) (layer.RWLayer, error)
|
||||||
|
LayerStoreStatus() [][2]string
|
||||||
|
GetLayerMountID(cid string) (string, error)
|
||||||
|
ReleaseLayer(rwlayer layer.RWLayer) error
|
||||||
|
LayerDiskUsage(ctx context.Context) (int64, error)
|
||||||
|
GetContainerLayerSize(containerID string) (int64, int64)
|
||||||
|
|
||||||
|
// Windows specific
|
||||||
|
|
||||||
|
GetLayerFolders(img *image.Image, rwLayer layer.RWLayer) ([]string, error)
|
||||||
|
|
||||||
|
// Build
|
||||||
|
|
||||||
|
MakeImageCache(sourceRefs []string) builder.ImageCache
|
||||||
|
CommitBuildStep(c backend.CommitConfig) (image.ID, error)
|
||||||
|
|
||||||
|
// Other
|
||||||
|
|
||||||
|
GetRepository(ctx context.Context, ref reference.Named, authConfig *types.AuthConfig) (distribution.Repository, error)
|
||||||
|
Map() map[image.ID]*image.Image
|
||||||
|
SearchRegistryForImages(ctx context.Context, searchFilters filters.Args, term string, limit int, authConfig *types.AuthConfig, headers map[string][]string) (*registry.SearchResults, error)
|
||||||
|
DistributionServices() images.DistributionServices
|
||||||
|
Children(id image.ID) []image.ID
|
||||||
|
Cleanup() error
|
||||||
|
GraphDriverName() string
|
||||||
|
UpdateConfig(maxDownloads, maxUploads int)
|
||||||
|
}
|
|
@ -4,9 +4,17 @@
|
||||||
package images // import "github.com/docker/docker/daemon/images"
|
package images // import "github.com/docker/docker/daemon/images"
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/docker/docker/image"
|
||||||
|
"github.com/docker/docker/layer"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// GetLayerFolders returns the layer folders from an image RootFS
|
||||||
|
func (i *ImageService) GetLayerFolders(img *image.Image, rwLayer layer.RWLayer) ([]string, error) {
|
||||||
|
// Windows specific
|
||||||
|
panic("not implemented")
|
||||||
|
}
|
||||||
|
|
||||||
// GetContainerLayerSize returns the real size & virtual size of the container.
|
// GetContainerLayerSize returns the real size & virtual size of the container.
|
||||||
func (i *ImageService) GetContainerLayerSize(containerID string) (int64, int64) {
|
func (i *ImageService) GetContainerLayerSize(containerID string) (int64, int64) {
|
||||||
var (
|
var (
|
||||||
|
|
Loading…
Reference in a new issue