From 126b5bce9db0d67f73600b950cf5576daa529b04 Mon Sep 17 00:00:00 2001 From: Derek McGowan Date: Wed, 27 Jun 2018 17:58:54 -0700 Subject: [PATCH] Register OCI image media types OCI types are backwards compatible with Docker manifest types, however the media types must be registered. Signed-off-by: Derek McGowan (cherry picked from commit c4f0515837b834ec66ec463d92a32015062a0804) Signed-off-by: Sebastiaan van Stijn --- distribution/oci.go | 45 ++++++++++++++++++++++++++++++++++++++++ distribution/registry.go | 2 ++ 2 files changed, 47 insertions(+) create mode 100644 distribution/oci.go diff --git a/distribution/oci.go b/distribution/oci.go new file mode 100644 index 0000000000000..7366546d09611 --- /dev/null +++ b/distribution/oci.go @@ -0,0 +1,45 @@ +package distribution + +import ( + "fmt" + + "github.com/docker/distribution" + "github.com/docker/distribution/manifest/manifestlist" + "github.com/docker/distribution/manifest/schema2" + digest "github.com/opencontainers/go-digest" + ocispec "github.com/opencontainers/image-spec/specs-go/v1" +) + +func init() { + // TODO: Remove this registration if distribution is included with OCI support + + ocischemaFunc := func(b []byte) (distribution.Manifest, distribution.Descriptor, error) { + m := new(schema2.DeserializedManifest) + err := m.UnmarshalJSON(b) + if err != nil { + return nil, distribution.Descriptor{}, err + } + + dgst := digest.FromBytes(b) + return m, distribution.Descriptor{Digest: dgst, Size: int64(len(b)), MediaType: ocispec.MediaTypeImageManifest}, err + } + err := distribution.RegisterManifestSchema(ocispec.MediaTypeImageManifest, ocischemaFunc) + if err != nil { + panic(fmt.Sprintf("Unable to register manifest: %s", err)) + } + + manifestListFunc := func(b []byte) (distribution.Manifest, distribution.Descriptor, error) { + m := new(manifestlist.DeserializedManifestList) + err := m.UnmarshalJSON(b) + if err != nil { + return nil, distribution.Descriptor{}, err + } + + dgst := digest.FromBytes(b) + return m, distribution.Descriptor{Digest: dgst, Size: int64(len(b)), MediaType: ocispec.MediaTypeImageIndex}, err + } + err = distribution.RegisterManifestSchema(ocispec.MediaTypeImageIndex, manifestListFunc) + if err != nil { + panic(fmt.Sprintf("Unable to register manifest: %s", err)) + } +} diff --git a/distribution/registry.go b/distribution/registry.go index 8b46aaad6d118..d81530b75cbbf 100644 --- a/distribution/registry.go +++ b/distribution/registry.go @@ -17,11 +17,13 @@ import ( "github.com/docker/docker/dockerversion" "github.com/docker/docker/registry" "github.com/docker/go-connections/sockets" + ocispec "github.com/opencontainers/image-spec/specs-go/v1" ) // ImageTypes represents the schema2 config types for images var ImageTypes = []string{ schema2.MediaTypeImageConfig, + ocispec.MediaTypeImageConfig, // Handle unexpected values from https://github.com/docker/distribution/issues/1621 // (see also https://github.com/docker/docker/issues/22378, // https://github.com/docker/docker/issues/30083)