2015-11-18 22:18:07 +00:00
|
|
|
package image
|
|
|
|
|
2016-09-06 16:09:18 +00:00
|
|
|
import (
|
|
|
|
"runtime"
|
|
|
|
|
|
|
|
"github.com/Sirupsen/logrus"
|
|
|
|
"github.com/docker/docker/layer"
|
|
|
|
)
|
2015-11-18 22:18:07 +00:00
|
|
|
|
2016-03-29 01:14:05 +00:00
|
|
|
// TypeLayers is used for RootFS.Type for filesystems organized into layers.
|
|
|
|
const TypeLayers = "layers"
|
|
|
|
|
2016-09-06 16:09:18 +00:00
|
|
|
// typeLayersWithBase is an older format used by Windows up to v1.12. We
|
|
|
|
// explicitly handle this as an error case to ensure that a daemon which still
|
|
|
|
// has an older image like this on disk can still start, even though the
|
|
|
|
// image itself is not usable. See https://github.com/docker/docker/pull/25806.
|
|
|
|
const typeLayersWithBase = "layers+base"
|
|
|
|
|
2016-07-22 22:29:21 +00:00
|
|
|
// RootFS describes images root filesystem
|
|
|
|
// This is currently a placeholder that only supports layers. In the future
|
|
|
|
// this can be made into an interface that supports different implementations.
|
|
|
|
type RootFS struct {
|
|
|
|
Type string `json:"type"`
|
|
|
|
DiffIDs []layer.DiffID `json:"diff_ids,omitempty"`
|
|
|
|
}
|
|
|
|
|
2016-03-29 01:14:05 +00:00
|
|
|
// NewRootFS returns empty RootFS struct
|
|
|
|
func NewRootFS() *RootFS {
|
|
|
|
return &RootFS{Type: TypeLayers}
|
|
|
|
}
|
|
|
|
|
2015-11-18 22:18:07 +00:00
|
|
|
// Append appends a new diffID to rootfs
|
|
|
|
func (r *RootFS) Append(id layer.DiffID) {
|
|
|
|
r.DiffIDs = append(r.DiffIDs, id)
|
|
|
|
}
|
2016-07-22 22:29:21 +00:00
|
|
|
|
|
|
|
// ChainID returns the ChainID for the top layer in RootFS.
|
|
|
|
func (r *RootFS) ChainID() layer.ChainID {
|
2016-09-06 16:09:18 +00:00
|
|
|
if runtime.GOOS == "windows" && r.Type == typeLayersWithBase {
|
|
|
|
logrus.Warnf("Layer type is unsupported on this platform. DiffIDs: '%v'", r.DiffIDs)
|
|
|
|
return ""
|
|
|
|
}
|
2016-07-22 22:29:21 +00:00
|
|
|
return layer.CreateChainID(r.DiffIDs)
|
|
|
|
}
|