Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

specs-go: clarify mediatypes #411

Merged
merged 1 commit into from
Jan 20, 2017
Merged

Conversation

vbatts
Copy link
Member

@vbatts vbatts commented Oct 21, 2016

Due to the conflicting use of the mediatType field across
documents, and after discussion on
#411,
this changeset removes the use of mediaType where it is used to refers
to a document's own type. Leaving only the use of mediaType for
descriptors, where it is used to describe the type of a referenced object.

@@ -75,6 +75,7 @@ type History struct {
}

// Image is the JSON structure which describes some basic information about the image.
// This provides the `application/vnd.oci.image.config.v1+json` mediatype when marshalled to JSON.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is annoying that this one is inconsistent. Can't we safely add a media type field to it?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i was thinking the same. Especially since the field is omitEmpty for JSON. Perhaps make it optional with a SHOULD, so it will have compat with older docker? Thoughts @stevvooe ?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(to that end, also the oci-layout file, and it doesn't even have a mediatype assigned for it)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On Fri, Oct 21, 2016 at 07:12:12AM -0700, Vincent Batts wrote:

(to that end, also the oci-layout file, and it doesn't even have a mediatype assigned for it)

+1 to assigning a media type to oci-layout. I don't expect to find it in CAS, but image-layout directories might be accessed over HTTP, and it would be strange to return application/json for it when all of our other schemas have more specific types.

On Fri, Oct 21, 2016 at 06:59:20AM -0700, Jonathan Boulle wrote:

It is annoying that this one is inconsistent. Can't we safely add a media type field to it?

This is going the wrong way. If folks want to look inside inside the blob and try to guess its type (e.g. by unmarshalling into Versioned), they can do that. But I don't think we should require anyone to look inside the blob to figure out what it is. Descriptor references tell you the media type ahead of time, and we should be using those to identify blob types, and that approach places no restrictions on the blob itself. So while we may want to keep the Versioned fields for backwards compat with Docker, I don't think we want to extend that approach to additional structures.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@jonboulle In general, we should not actually be embedding mediaTypes in the target types. The mediaType is a lens to the data. Really, we should remove them from the types.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why not just follow along with literally every other format that exists and make it self-describing?

The only time I can see where we'd want this to be the recommended method for typing a blob is in signed assertions. For everything else, I'd rather have:

The descriptor that sent me here said this was a application/vnd.oci.image.manifest.v1+json, so I'll attach it to my manifest handler…

Instead of:

Lets see, does it have ustar\000 at offset 257? No? Good, because I'm not sure how I would have figured out if that was using the .wh.* whiteout handling or the new [static] whiteout handling (#24). Do the first four bytes match 00 00 00 xx? No? Ok, not UTF-32BE JSON. What about 00 xx 00 xx? … Maybe the first byte is {? Ok, that sounds like UTF-8 JSON. Let me unmarshal it into MediaTyped. That worked! And it has a value from mediaType! It says it is application/vnd.oci.image.manifest.v1+json, so I'll seek back to the beginning and attach it to my manifest handler…

And again, I'm just arguing that we shouldn't be using peek-inside typing for image unpacking, etc. I'm ok with us deciding that we want to use it to save keystrokes on pre-CAS-push validation.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@wking You're arguing that there's dichotomy between "free for all, no need to have mediaType" and "hueristic so that we can recognise every blob type". I don't think there is one.

The benefit of being able to know what a JSON blob is meant to represent is entirely separate from "I can tell what every blob in the image is without references". If you're not happy with detecting tar files (like file and libmagic do) that's fine. But please let's not make all of our JSON objects meaningless blobs that require jumping through references in order to even understand what we're looking at (or keeping the type information out-of-band).

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But please let's not make all of our JSON objects meaningless blobs that require jumping through references in order to even understand what we're looking at…

You're saying “assuming (for some out-of-band reason) that the blob is a JSON object which contains a self-describing mediaType field, we can use that mediaType field to unambiguously identify the content”. That initial assumption is what I'm worried about. If you see cases where you are comfortable making that assumption (for whatever out-of-band reasons), then great, use peek-inside type detection based on the mediaType value. But I'd strongly recommend consumers use the referencing descriptor's mediaType to avoid having to rely on that assumption.

Copy link
Member

@cyphar cyphar Nov 4, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But I'd strongly recommend consumers use the referencing descriptor's mediaType to avoid having to rely on that assumption.

Your consistent implication that all consumers will have access to the entire image is getting annoying. If I have a tool like oci-do-something which I pipe a JSON object to, I don't expect that it will be reading the repository. In fact, I might have a service that modifies the JSON objects (and therefore actually cannot access the original repo). So you can't "use the referencing descriptor" because there isn't one (that you can see).

Now, you might argue that we should send the out-of-band media type with it. But why should that be a requirement? What are you gaining by removing mediaType?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Now, you might argue that we should send the out-of-band media type with it. But why should that be a requirement?

That's exactly what I'll argue ;). And unless you implement completely generic peek-inside detection (which I don't think anyone's arguing for), you're going to have to transmit some amount of media-type guidance along with your blob content. I'm suggesting that guidance be the media type.

You seem to be suggesting that that guidance be “this blob is a JSON object which contains a self-describing mediaType field”. Maybe you transmit that information because the tool-caller knows the tool can only handle such media types and therefore only feeds matching blobs into the tool. That's how oci-image-validate works, and I'm comfortable with that from a keystroke-saving perspective. However, I don't think we should pretend that this approach is completely free of out-of-band type guidance.

What are you gaining by removing mediaType?

I'm not suggesting we remove mediaType, because some users (e.g. you with oci-do-something, or a number of people with oci-image-validate's autodection) can't be bothered to pass media types around. And I'm fine with that (typing out a long media type is not something I'd like to do repeatedly).

I'm just suggesting image-handling tools follow the spec's SHOULD and use descriptors to reference blob content, with peek-inside type detection being reserved for signed-assertions. And having acquired the media type from the referencing descriptor (or because we authored the blob ourselves), I see no need for image-handling tools to use peek-inside type detection.

Perhaps our difference here is that I see (almost) all tooling as being descriptor-based, while you see the tooling as being isolated-blob based. Since I'm fine leaving existing mediaType entries in place, maybe we can just wait a year to see how that plays out and revisit this discussion then?

type ManifestList struct {
specs.MediaTyped
specs.Versioned
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If Versioned contains MediaTyped (which is what you currently have), isn't it redundant to list MediaTyped here?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, technically. Does not change anything and is very apparent that it is media typed

@stevvooe
Copy link
Contributor

@vbatts Is this to support partial decode for mediaType sniffing? If so, are there other fields that are common to all types that we want in this decode structure.

@jonboulle
Copy link
Contributor

Why did we ever do this?

On 21 October 2016 at 20:35, Stephen Day notifications@github.com wrote:

@stevvooe commented on this pull request.

In specs-go/v1/config.go
#411:

@@ -75,6 +75,7 @@ type History struct {
}

// Image is the JSON structure which describes some basic information about the image.
+// This provides the application/vnd.oci.image.config.v1+json mediatype when marshalled to JSON.

@jonboulle https://github.com/jonboulle In general, we should not
actually be embedding mediaTypes in the target types. The mediaType is a
lens to the data. Really, we should remove them from the types.


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#411, or mute the
thread
https://github.com/notifications/unsubscribe-auth/ACewN0bFsBrR04esbK8ZVK_IDBWi6X_jks5q2QX7gaJpZM4KdNZp
.

type Descriptor struct {
// MediaType contains the MIME type of the referenced object.
MediaType string `json:"mediaType"`
specs.MediaTyped
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oh, so this is actually wrong because the mediatype here is the REFERENCED object not itself.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, same field name, and opposite intention. :-|

@jonboulle
Copy link
Contributor

@vbatts can we rather remove media type fields?

@vbatts
Copy link
Member Author

vbatts commented Oct 28, 2016

@jonboulle like completely? or just this PR?

@jonboulle
Copy link
Contributor

@vbatts like completely

@vbatts
Copy link
Member Author

vbatts commented Oct 28, 2016

well, honestly I like the self describing nature of it. I wish the descriptor field names could be fixed, such that it could self describe and have a separate field that describes the object pointing to.
Self-describing, while this approach is slightly more expensive, allows for an algorithm like

mt := v1.MediaTyped{}
if err := json.Unmarshal(buf, &mt); err != nil {
  // handle yer biz
}
switch mt.MediaType {
case v1.MediaTypeImageManifest:
  // something specific
default:
  // handle yer biz
}

So we can have discovery without having a map[string]interface{}{}.

@wking
Copy link
Contributor

wking commented Oct 28, 2016

On Fri, Oct 28, 2016 at 07:07:03AM -0700, Vincent Batts wrote:

well, honestly I like the self describing nature of it.

There was a bit more discussion of this in
opencontainers/image-tools#5 starting with 1. @cyphar was arguing
for this peek-inside auto-detection in the proposed oci-refs because
tracking media types is tedious. I was arguing against peek-inside
auto-detection because it doesn't always work (it requires a JSON blob
whose mediaType is self-describing, so not the current descriptors or
any non-JSON type, e.g. a layer tarball).

We SHOULD descriptors for all blob references 2, so if the initial
publisher references the blob they published (and presumably they
would or future garbage collection would remove it), that descriptor
reference will have media type information for the blob. Anyone else
who stumbles across the same blob either:

a. Created it independently (in which case they should know what it is),
b. Found it by following a descriptor (in which case that descriptor
tells them what it is), or
c. Found it by walking the CAS (e.g. during an interal GC pass).

(c) is the only tricky case, and the solution is to have the GC engine
walk the CAS from pinned descriptors (so it's like (c)) instead of
walking the CAS via readdir(3) on the blob filesystem.

@cyphar
Copy link
Member

cyphar commented Oct 29, 2016

My main concern is that without mediaType things are properly self-describing -- you have no clue what each object represents unless you've walked from a ref to the object itself. For me, this is just tedious to deal with (as a consumer I shouldn't be caring about the internals of all of the referencing if there's oci-image-tools that should handle this for me and just output the JSON blob that I am trying to look at).

@wking gave the example that mediaType won't on the layer tar+gzip archives. But that isn't helping the case against mediaType, because both tar and gzip have unique headers that identify what they are! There's no ambiguity with regards to whether a layer object is a layer object or not. The only thing that's ambiguous is the JSON blobs we're using which aren't adequately expressing what they represent.

In particular, the fact that descriptors don't say that they're descriptors is quite silly (mediaType is broken in that instance).

@wking
Copy link
Contributor

wking commented Oct 29, 2016

The tar+gzip headers do not distinguish application/vnd.oci.image.layer.v1.tar+gzip from application/vnd.oci.image.layer.nondistributable.v1.tar+gzip or from a future application/vnd.oci.image.layer.v1.1.tar.

Walking the DAG sounds like an integral part of using CAS. Can you provide more details about what you mean by "just output the JSON blob that I am trying to look at"?

@cyphar
Copy link
Member

cyphar commented Oct 29, 2016

Walking the DAG sounds like an integral part of using CAS. Can you provide more details about what you mean by "just output the JSON blob that I am trying to look at"?

Lets say I want to modify the config for an image. Currently the way I need to do this is:

  1. Get the reference descriptor using oci-refs get. I then have to parse this JSON to get the right blob for the manifest.
  2. Get the manifest using oci-cas get. I then have to parse this JSON to get the right blob for the config.
  3. I now have the config JSON and I can modify it using jq or whatever.

In order to update the image I now need to:

  1. Push the new modified config and get the new digest, which I do with oci-cas put.
  2. Update the manifest to use the new config, then push it to get a new digest with oci-cas put.
  3. Create a new reference descriptor and push it to get the new reference with oci-refs put.
  4. Clean everything up with the (currently non-existant) oci-gc.

Now, my main point is that the OCI tooling hasn't added anything. The process takes precisely as long as it would using sha256sum, jq, ls, cat and rm! The fact that so many of the things need to be done manually even with having tooling just makes this ridiculous. Imagine if oci-create-runtime-bundle or oci-unpack would only let you extract a single layer at a time -- that would also be useless.

I'm going to end up writing a wrapper for all of this, but I think we should be considering who the target user of these utilities is. Looking at oci-image-init, oci-unpack, oci-validate and oci-create-runtime-bundle I would assume that the target is people who just want to use images without having to understand the intricacies of the specification and how things need to have 15 layers of referencing and double-checking of sizes and so on. But maybe I was mistaken and the intended users are just us? In which case I'll be happy to just go and write the tooling I need and maintain it outside of this project -- it's just a bit of a shame that we're not concrete on who will be using this tooling and what they would want from such tooling.

@wking
Copy link
Contributor

wking commented Oct 29, 2016

The process takes precisely as long as it would using sha256sum, jq, ls, cat and rm!

But ls, cat, and rm don't abstract away the CAS registry implementation. And the presence of low-level tools like oci-cas doesn't preclude additional tooling like oci-jq-manifest (or whatever your high-level tweaker looks like). In fact, oci-cas makes it much easier to write a CAS-engine agnostic oci-jq-manifest.

I'm missing the connection between "I'll wrap DAG walking because it's tedious" and "I need to discover media types by inspecting the blob content". In your example above you start with oci-refs get, so you'll be following descriptors (which tell you the media type before you have the blob content) all the way down.

@cyphar
Copy link
Member

cyphar commented Oct 30, 2016

@wking My point will be more clear if I just make my wrapping tool. I'm working on it now, but in order to handle it properly I need to merge this PR into my branch -- so we can just continue with merging this (and we can discuss higher-level handlers later).

@wking
Copy link
Contributor

wking commented Oct 30, 2016

My point is that I see no need for peek-inside type detection. But the mediaType properties (excepting Descriptor's) will be the same amount of work to remove regardless of this PR, so I don't have a problem with it landing.

@cyphar
Copy link
Member

cyphar commented Oct 30, 2016

@wking ... You can't have it both ways. In opencontainers/image-tools#5 you want to make the tooling around images as flexible as possible (so that you can support extensions that don't match the spec). That's fine, but you can't then also say that all of the objects should no longer be self-describing. The result is that you cannot use any generic OCI tooling for images, because all of the objects are defined relative to one another and thus you couldn't effectively modify a single object (you'd have to parse the image each time to know what object you're modifying -- and even then you'd need to track the object types implicitly). In other words, you'd have to craft new tooling for every new producer of an OCI image (because they could add extensions that make it impossible to normally parse the image).

Explicit is better than implicit.

@wking
Copy link
Contributor

wking commented Oct 30, 2016

It's a Merkle DAG, you can never modify a single blob. Peek-inside type detection doesn't change that.

@wking
Copy link
Contributor

wking commented Oct 30, 2016

Even if you're modifying the root blob, you'd still need to push a new ref.

@stevvooe
Copy link
Contributor

@cyphar The model for CAS-based engine distribution typically requires referencing an object through type-qualified references, which are called descriptors. I disagree that using CAS in this manner prevents extension, as I don't think OCI could be introduced at all if the concepts defined in manifests and manifest lists didn't work. We have been doing this in compilers and runtime since forever.

The difference is the propagation of the modification. Typically, the process of modifying something requires a walk don't the qualified reference path, then anything that was touched or references something that was touched gets update. This is what happens with this technology (I also suspect this is part of why CAS is not adopted more often). When you touch something, it modifies the "address" of that thing and those changes and their references need to be updated.

I don't know what is going on in opencontainers/image-tools#5, but if CAS access to a tar file is being exposed over CLI, something is going way wrong.

In general, I'd like to see a proposal for the image-tools that are useful. I am not familiar with your work, but it would be helpful if you could identify the problems that have led to a "wrapper" or even how we can incorporate that work into OCI.

@wking
Copy link
Contributor

wking commented Oct 31, 2016

On Mon, Oct 31, 2016 at 02:22:54PM -0700, Stephen Day wrote:

I don't know what is going on in opencontainers/image-tools#5, but
if CAS access to a tar file is being exposed over CLI, something is
going way wrong.

I disagree, but I think we should probably be discussing this point in
opencontainers/image-tools#5. Can you file your concerns in more
detail over there?

In general, I'd like to see a proposal for the image-tools that are
useful. I am not familiar with your work, but it would be helpful if
you could identify the problems that have led to a "wrapper" or even
how we can incorporate that work into OCI.

+1.

@stevvooe
Copy link
Contributor

Can you file your concerns in more
detail over there?

I did, then you just opened three more PRs. I have no more time to waste.

@cyphar
Copy link
Member

cyphar commented Nov 1, 2016

@stevvooe Okay, so here's what I'm working on at the moment (the only reason I haven't published it yet is just because right now I'm doing a bunch of go-mtree related work rather than actually getting imagectl to work at the moment):

The main issue I have with the current incarnation of @wking's oci-cas and oci-refs is that it doesn't appear to me as though the tooling was written with the image-spec in mind. In particular, it looks more like "generic CAS tooling" that just happens to handle the CAS layout of the OCI image spec.

The tooling I would like (and am planning on writing) actually is written around images as a first-class concept. In particular, it lets you modify images rather than blobs. So you can say "modify this field in the config of this image ref" and that will translate to replacing the config, the manifest blob that referenced it and the ref blob that referenced that. Same thing applies to changing the set of layers and so on -- the tooling is actually written around the end-user goal of actually modifying images as a first-class concept.

And in my case, imagectl already knows the types of everything implicitly (because I had to walk through the CAS to get there) -- though that precludes a descriptor telling me what type it points to (or every blob being self-describing). However, the main issue I have with @wking's PR (aside from not being sure why we're exposing tar handling code) is that it exposes a generic CAS interface that isn't actually helpful to anyone unless we're also planning on writing some more tooling that can take our JSON blobs and do useful things with them -- and to do that you need to have self-describing blobs.

@wking
Copy link
Contributor

wking commented Nov 1, 2016

On Mon, Oct 31, 2016 at 08:22:31PM -0700, Aleksa Sarai wrote:

The main issue I have with the current incarnation of @wking's
oci-cas and oci-refs is that it doesn't appear to me as though
the tooling was written with the image-spec in mind. In particular,
it looks more like "generic CAS tooling" that just happens to handle
the CAS layout of the OCI image spec.

oci-cas is generic CAS tooling. oci-refs is generic mutable-refs
tooling. They're written with image-spec in mind because image-layout
is a generic CAS/refs format (although it's obviously not the only
possible CAS or refs format). The idea in putting a layer of
abstraction between the image-layout tooling and the rest of the
image-spec support is that it lets you adjust image-layout or swap in
some completely different CAS/refs engine without rewriting the
domain-specific logic.

The tooling I would like (and am planning on writing) actually is
written around the spec. In particular, it lets you modify
images rather than blobs. So you can say "modify this field in
the config of this image ref" and that will translate to replacing
the config, the manifest blob that referenced it and the ref blob
that referenced that. Same thing applies to changing the set of
layers and so on -- the tooling is actually written around the
end-user goal of actually modifying images as a first-class
concept
.

This sounds useful to me too. I don't see why having this
higher-level code and command-line interface makes oci-cas or
oci-refs a bad idea.

And in my case, imagectl already knows the types of everything
implicitly (because I had to walk through the CAS to get there) --
though that precludes a descriptor telling me what type it points to
(or every blob being self-describing).

So your imagectl doesn't need to self-describing blobs or a type-aware
CAS engine? I'm glad, although not particularly surprised, since I
expect most CAS consumers will be publishing content with known types
or walking down from a ref.

However, the main issue I have with @wking's PR (aside from not
being sure why we're exposing tar handling code)…

It's not just exposing tar-handling code, it's exposing a generic
CAS/refs handling API. One backend for those CAS and ref stores is
tar, but it also supports directories, and can be extended in the
future to support zip, HTTP, FTP, rsync, etc. 1. It's also possible
that it could be extended to support the Docker registry and other
existing CAS/ref stores.

… is that it exposes a generic CAS interface that isn't actually
helpful to anyone unless we're also planning on writing some more
tooling that can take our JSON blobs and do useful things with them…

I completely agree that we don't want oci-cas and oci-refs to be our
highest-level commands. oci-image-validate, oci-unpack, and
oci-create-runtime-bundle are already higher-level commands. Your
imagectl will be another higher-level command. But the CAS and refs
implementations decouple cleanly from the higher-level,
domain-specific logic. I don't think the presence of the high-level
commands is a reason to not expose the low-level CAS/refs API on the
command-line.

… and to do that you need to have self-describing blobs.

I'm still not understanding this leap. Can you present a workflow
that requires self-describing blobs?

@wking
Copy link
Contributor

wking commented Nov 1, 2016

On Mon, Oct 31, 2016 at 09:45:02PM -0700, W. Trevor King wrote:

… and to do that you need to have self-describing blobs.

I'm still not understanding this leap. Can you present a workflow
that requires self-describing blobs?

The only situation I've seen where self-describing blobs is useful is
outside-of-CAS validation, where we currently attempt to auto-detect
the type when the user doesn't pass it through to us 1. That is
useful, but it doesn't involve the CAS engine. And I don't think it
is so useful that we need to preserve it going forwards. Do we
expect folks to frequently validate content whose type they don't
know? “Is this something that OCI can autodetect and validate?”
seems like a much less useful question to ask than “Is this a valid
application/vnd.oci.image.manifest.v1+json?”. But still,
autodetection for out-of-CAS validation was useful enough for folks to
add validation support for it. Is that a sufficient use-case for
extending self-describing media types to
application/vnd.oci.image.config.v1+json? How about
application/vnd.oci.descriptor.v1+json or
application/vnd.oci.image.layer.v1.tar+gzip? I don't think so, but I
consider it to be a policy question and not a technical question
(folks do know what they're validating, they just don't want to type
out the media type), so I'm comfortable with image-spec maintainers
ruling either way.

Are there other use-cases for self-describing blobs that do make this
a technical requirement?

@stevvooe
Copy link
Contributor

stevvooe commented Nov 3, 2016

@cyphar I completely agree. CAS is too-level to be useful. Thank you for the break down!

moby/moby#27455 is a proposal to docker to add a manifest tool which has the same UX problem. Basically, you need to "check out" an image, modify it, then check it back in.

In the spirt of OCI being made up of proven technologies, I think it would be worthwhile to let imagectl inform the work in image tools, if possible.

@vbatts
Copy link
Member Author

vbatts commented Nov 3, 2016

lots of philosophy and bike sheds, it seems to me. Is the motivation to remove mediatype from all but the descriptor, @stevvooe @jonboulle ?

dattgoswami9lk5g added a commit to dattgoswami9lk5g/bremlinr that referenced this pull request Jun 6, 2022
Due to the conflicting use of the `mediatType` field across
documents, and after discussion on
opencontainers/image-spec#411,
this changeset removes the use of `mediaType` where it is used to refers
to a document's own type. Leaving only the use of `mediaType` for
descriptors, where it is used to describe the type of a referenced object.

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
7c00d pushed a commit to 7c00d/J1nHyeockKim that referenced this pull request Jun 6, 2022
Due to the conflicting use of the `mediatType` field across
documents, and after discussion on
opencontainers/image-spec#411,
this changeset removes the use of `mediaType` where it is used to refers
to a document's own type. Leaving only the use of `mediaType` for
descriptors, where it is used to describe the type of a referenced object.

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
7c00d added a commit to 7c00d/J1nHyeockKim that referenced this pull request Jun 6, 2022
Due to the conflicting use of the `mediatType` field across
documents, and after discussion on
opencontainers/image-spec#411,
this changeset removes the use of `mediaType` where it is used to refers
to a document's own type. Leaving only the use of `mediaType` for
descriptors, where it is used to describe the type of a referenced object.

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
laventuraw added a commit to laventuraw/Kihara-tony0 that referenced this pull request Jun 6, 2022
Due to the conflicting use of the `mediatType` field across
documents, and after discussion on
opencontainers/image-spec#411,
this changeset removes the use of `mediaType` where it is used to refers
to a document's own type. Leaving only the use of `mediaType` for
descriptors, where it is used to describe the type of a referenced object.

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
tomalopbsr0tt added a commit to tomalopbsr0tt/fabiojosej that referenced this pull request Oct 6, 2022
Due to the conflicting use of the `mediatType` field across
documents, and after discussion on
opencontainers/image-spec#411,
this changeset removes the use of `mediaType` where it is used to refers
to a document's own type. Leaving only the use of `mediaType` for
descriptors, where it is used to describe the type of a referenced object.

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants