imagetools(create): set correct media type when combining manifests

When using imagetools create and combining multiple sources
we should check the media type of each manifest and set
the right media type for the manifest list.

If there is a mismatch we set OCI index as best effort.

Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com>
pull/1797/head
CrazyMax 2 years ago committed by CrazyMax
parent 1eb9ad979e
commit b702188b65
No known key found for this signature in database
GPG Key ID: 3248E46B6BB8C7F7

@ -122,24 +122,29 @@ func (r *Resolver) Combine(ctx context.Context, srcs []*Source) ([]byte, ocispec
} }
} }
mt := images.MediaTypeDockerSchema2ManifestList //ocispec.MediaTypeImageIndex dockerMfsts := 0
idx := struct { for _, desc := range newDescs {
// MediaType is reserved in the OCI spec but if strings.HasPrefix(desc.MediaType, "application/vnd.docker.") {
// excluded from go types. dockerMfsts++
MediaType string `json:"mediaType,omitempty"` }
ocispec.Index
}{
MediaType: mt,
Index: ocispec.Index{
Versioned: specs.Versioned{
SchemaVersion: 2,
},
Manifests: newDescs,
},
} }
idxBytes, err := json.MarshalIndent(idx, "", " ") var mt string
if dockerMfsts == len(newDescs) {
// all manifests are Docker types, use Docker manifest list
mt = images.MediaTypeDockerSchema2ManifestList
} else {
// otherwise, use OCI index
mt = ocispec.MediaTypeImageIndex
}
idxBytes, err := json.MarshalIndent(ocispec.Index{
MediaType: mt,
Versioned: specs.Versioned{
SchemaVersion: 2,
},
Manifests: newDescs,
}, "", " ")
if err != nil { if err != nil {
return nil, ocispec.Descriptor{}, errors.Wrap(err, "failed to marshal index") return nil, ocispec.Descriptor{}, errors.Wrap(err, "failed to marshal index")
} }

Loading…
Cancel
Save