|
@@ -16,15 +16,15 @@ type Layer struct {
|
|
status string
|
|
status string
|
|
}
|
|
}
|
|
|
|
|
|
-func NewLayer(r io.Reader, mediatype string) (*Layer, error) {
|
|
|
|
|
|
+func NewLayer(r io.Reader, mediatype string) (Layer, error) {
|
|
blobs, err := GetBlobsPath("")
|
|
blobs, err := GetBlobsPath("")
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
temp, err := os.CreateTemp(blobs, "sha256-")
|
|
temp, err := os.CreateTemp(blobs, "sha256-")
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
defer temp.Close()
|
|
defer temp.Close()
|
|
defer os.Remove(temp.Name())
|
|
defer os.Remove(temp.Name())
|
|
@@ -32,28 +32,28 @@ func NewLayer(r io.Reader, mediatype string) (*Layer, error) {
|
|
sha256sum := sha256.New()
|
|
sha256sum := sha256.New()
|
|
n, err := io.Copy(io.MultiWriter(temp, sha256sum), r)
|
|
n, err := io.Copy(io.MultiWriter(temp, sha256sum), r)
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
if err := temp.Close(); err != nil {
|
|
if err := temp.Close(); err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
digest := fmt.Sprintf("sha256:%x", sha256sum.Sum(nil))
|
|
digest := fmt.Sprintf("sha256:%x", sha256sum.Sum(nil))
|
|
blob, err := GetBlobsPath(digest)
|
|
blob, err := GetBlobsPath(digest)
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
status := "using existing layer"
|
|
status := "using existing layer"
|
|
if _, err := os.Stat(blob); err != nil {
|
|
if _, err := os.Stat(blob); err != nil {
|
|
status = "creating new layer"
|
|
status = "creating new layer"
|
|
if err := os.Rename(temp.Name(), blob); err != nil {
|
|
if err := os.Rename(temp.Name(), blob); err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
- return &Layer{
|
|
|
|
|
|
+ return Layer{
|
|
MediaType: mediatype,
|
|
MediaType: mediatype,
|
|
Digest: digest,
|
|
Digest: digest,
|
|
Size: n,
|
|
Size: n,
|
|
@@ -61,22 +61,22 @@ func NewLayer(r io.Reader, mediatype string) (*Layer, error) {
|
|
}, nil
|
|
}, nil
|
|
}
|
|
}
|
|
|
|
|
|
-func NewLayerFromLayer(digest, mediatype, from string) (*Layer, error) {
|
|
|
|
|
|
+func NewLayerFromLayer(digest, mediatype, from string) (Layer, error) {
|
|
if digest == "" {
|
|
if digest == "" {
|
|
- return nil, errors.New("creating new layer from layer with empty digest")
|
|
|
|
|
|
+ return Layer{}, errors.New("creating new layer from layer with empty digest")
|
|
}
|
|
}
|
|
|
|
|
|
blob, err := GetBlobsPath(digest)
|
|
blob, err := GetBlobsPath(digest)
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
fi, err := os.Stat(blob)
|
|
fi, err := os.Stat(blob)
|
|
if err != nil {
|
|
if err != nil {
|
|
- return nil, err
|
|
|
|
|
|
+ return Layer{}, err
|
|
}
|
|
}
|
|
|
|
|
|
- return &Layer{
|
|
|
|
|
|
+ return Layer{
|
|
MediaType: mediatype,
|
|
MediaType: mediatype,
|
|
Digest: digest,
|
|
Digest: digest,
|
|
Size: fi.Size(),
|
|
Size: fi.Size(),
|
|
@@ -109,7 +109,7 @@ func (l *Layer) Remove() error {
|
|
}
|
|
}
|
|
|
|
|
|
for _, m := range ms {
|
|
for _, m := range ms {
|
|
- for _, layer := range append(m.Layers, &m.Config) {
|
|
|
|
|
|
+ for _, layer := range append(m.Layers, m.Config) {
|
|
if layer.Digest == l.Digest {
|
|
if layer.Digest == l.Digest {
|
|
// something is using this layer
|
|
// something is using this layer
|
|
return nil
|
|
return nil
|