Skip to content

Commit

Permalink
Drop storageReference.breakDockerReference and storageImageDestinatio…
Browse files Browse the repository at this point in the history
…n.publicRef

Now that storageImageDestination.IgnoreEmbeddedDockerReference exists, this hack
is no longer needed.

Signed-off-by: Miloslav Trmač <[email protected]>
  • Loading branch information
mtrmac committed Apr 7, 2018
1 parent 9939187 commit 8d89188
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 20 deletions.
17 changes: 4 additions & 13 deletions storage/storage_image.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,7 @@ type storageImageSource struct {
}

type storageImageDestination struct {
imageRef storageReference // The reference we'll use to name the image
publicRef storageReference // The reference we return when asked about the name we'll give to the image
imageRef storageReference
directory string // Temporary directory where we store blobs until Commit() time
nextTempFileID int32 // A counter that we use for computing filenames to assign to blobs
manifest []byte // Manifest contents, temporary
Expand Down Expand Up @@ -244,15 +243,8 @@ func newImageDestination(ctx *types.SystemContext, imageRef storageReference) (*
if err != nil {
return nil, errors.Wrapf(err, "error creating a temporary directory")
}
// Break reading of the reference we're writing, so that copy.Image() won't try to rewrite
// schema1 image manifests to remove embedded references, since that changes the manifest's
// digest, and that makes the image unusable if we subsequently try to access it using a
// reference that mentions the no-longer-correct digest.
publicRef := imageRef
publicRef.breakDockerReference = true // FIXME: this does not change .StringWithinTransport(), but modifies DockerReference()
image := &storageImageDestination{
imageRef: imageRef,
publicRef: publicRef,
directory: directory,
blobDiffIDs: make(map[digest.Digest]digest.Digest),
fileSizes: make(map[digest.Digest]int64),
Expand All @@ -262,11 +254,10 @@ func newImageDestination(ctx *types.SystemContext, imageRef storageReference) (*
return image, nil
}

// Reference returns a mostly-usable image reference that can't return a DockerReference, to
// avoid triggering logic in copy.Image() that rewrites schema 1 image manifests in order to
// remove image names that they contain which don't match the value we're using.
// Reference returns the reference used to set up this destination. Note that this should directly correspond to user's intent,
// e.g. it should use the public hostname instead of the result of resolving CNAMEs or following redirects.
func (s storageImageDestination) Reference() types.ImageReference {
return s.publicRef
return s.imageRef
}

// Close cleans up the temporary directory.
Expand Down
10 changes: 3 additions & 7 deletions storage/storage_reference.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,9 @@ import (
// where an image is, or would be, kept.
// Either "named" or "id" must be set.
type storageReference struct {
transport storageTransport
named reference.Named // may include a tag and/or a digest
id string
breakDockerReference bool // Possibly set by newImageDestination. FIXME: Figure out another way.
transport storageTransport
named reference.Named // may include a tag and/or a digest
id string
}

func newReference(transport storageTransport, named reference.Named, id string) (*storageReference, error) {
Expand Down Expand Up @@ -112,9 +111,6 @@ func (s storageReference) Transport() types.ImageTransport {

// Return a name with a tag or digest, if we have either, else return it bare.
func (s storageReference) DockerReference() reference.Named {
if s.breakDockerReference {
return nil
}
return s.named
}

Expand Down

0 comments on commit 8d89188

Please sign in to comment.