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

Clarify relationship bx securing mechanisms and media types #1107

Merged
merged 5 commits into from
May 13, 2023

Conversation

brentzundel
Copy link
Member

@brentzundel brentzundel commented Apr 27, 2023

This PR attempts to add some clarity around the relationship between securing mechanisms and media types.

It primarily uses language suggested in Issue #1065.
It adds that media types defined that allow for transformation into application/vc+ld+json should begin with application/vc+
It states that application/vc+ld+json does not imply any securing mechanism
it states that other media types should not imply any securing mechanism
I removes the note about Issue #1065

fixes #1065


Preview | Diff

Signed-off-by: Brent Zundel <[email protected]>
index.html Outdated
Comment on lines 3403 to 3405
mechanism. It describes an object that is securable. Other specifications
defining media types that begin with `application/vc+` SHOULD NOT define those
media types to imply any particular securing mechanism.
Copy link
Member

Choose a reason for hiding this comment

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

I had to read this last sentence a number of times and I'm still not sure I understand what it's saying.

I think it's saying: "This core spec doesn't imply a securing mechanism, and other media types shouldn't imply a securing mechanism either"...

IOW, "that other thing might have proof and experimentalSecuringMechanism and be wrapped in a CWT (or any combination thereof), so... you can't presume any of those things... you're just going to have to verify it using your own checks to see if it truly is verifiable, and then validate it to make sure it meets your business requirements."

I don't know how to say that more succinctly... once we have confirmation on the intent, we can probably go from there.

As an aside, it sounds like we're starting to collect: "Normative statements for specification authors that are authoring other specifications that contain transformation rules to application/vc+ld+json."

Copy link
Contributor

@OR13 OR13 Apr 28, 2023

Choose a reason for hiding this comment

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

I agree, I would remove this:

Other specifications
defining media types that begin with `application/vc+` SHOULD NOT define those
media types to imply any particular securing mechanism.

A general statement about media types here might be:

Implementers are advised not to assume veracity or security of content regardless of the media type used to communicate it. A validation process needs to be applied to confirm integrity, media types should not be trusted, or assumed to be secure without confirming by some validation process.

Copy link
Member Author

Choose a reason for hiding this comment

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

This has been refactored in 0d5dbd9

index.html Outdated
Comment on lines 3398 to 3399
media type. Media types that allow for transformation into
`application/vc+ld+json` SHOULD begin with `application/vc+`.
Copy link
Member

Choose a reason for hiding this comment

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

I think this is good. I was wondering if we should say anything at all about this... the upside of not saying something is that other media types like application/foo could have a section about transformation into a VC w/o having to register two media types; application/foo and application/vc+foo... maybe the argument there is that the thing that's important is the transformation rules, not the media type? Does differentiating it via a new media type always help?

I'm fine w/ the text above for now, and it is a SHOULD so, people that are working on application/foo can choose to ignore it because they're concerned about media type proliferation. If they ignore the advice, my expectation is that we'd still add them to the VC Specifications Directory.

To be clear, this isn't a change request, just noting thoughts hoping others will engage in a discussion on the benefits/drawbacks of the specification requirement.

Copy link
Member

Choose a reason for hiding this comment

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

I'm a bit concerned that talking this way about application/vc+ suggests that there's a single way to deal with any and all such media types, though the way to deal with a media type is most simply determined by the outer edges of the media type -- e.g., application/vc+ld+json is most simply handled as application/json, not as application/vc+.

Copy link
Member Author

Choose a reason for hiding this comment

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

This has been refactored in 0d5dbd9

Copy link
Contributor

@OR13 OR13 left a comment

Choose a reason for hiding this comment

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

I think we should remove or refactor this sentence:

https://github.com/w3c/vc-data-model/pull/1107/files#r1180475199

The rest of the PR looks to be in pretty good shape.

@brentzundel
Copy link
Member Author

I think we should remove or refactor this sentence:

https://github.com/w3c/vc-data-model/pull/1107/files#r1180475199

The rest of the PR looks to be in pretty good shape.

This has been refactored in 0d5dbd9

@brentzundel brentzundel requested a review from OR13 April 28, 2023 19:44
index.html Outdated Show resolved Hide resolved
Co-authored-by: Andres Uribe <[email protected]>
@brentzundel
Copy link
Member Author

@OR13 please re-review and let me know if you would like any more changes

@msporny
Copy link
Member

msporny commented May 4, 2023

Waiting on review by @OR13 to merge.

@@ -3404,6 +3397,13 @@ <h3>Media Types</h3>
those other syntaxes to be transformed to the `application/vc+ld+json`
media type.
</p>
<p>
The media type `application/vc+ld+json` does not imply any particular securing
Copy link
Contributor

Choose a reason for hiding this comment

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

Not sure this is true, it implies at least the possibility of DataIntegrityProof based on the current normative requirements regarding proof and @context.

#1091

Copy link
Member Author

Choose a reason for hiding this comment

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

The language suggested in this PR is an attempt to clarify that in spite of the requirement to include a specific @context, and in spite of that @context containing references to a specific securing mechanism, no specific securing mechanism should be assumed. Just because the @context points to data integrity doesn't mean the data has been secured.

Happy for further suggestions on how to better communicate that here.

index.html Outdated
Comment on lines 3402 to 3404
mechanism. It describes an object that is securable, but a securing mechanism
needs to be applied to enable verification of integrity. This also applies to
media types that allow for transformation into `application/vc+ld+json`. Do not
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
mechanism. It describes an object that is securable, but a securing mechanism
needs to be applied to enable verification of integrity. This also applies to
media types that allow for transformation into `application/vc+ld+json`. Do not
mechanism. Do not

Copy link
Contributor

Choose a reason for hiding this comment

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

"It describes an object that is securable, but a securing mechanism needs to be applied to enable verification of integrity." This sentence hurts... and I think we are doing a better job of addressing it in:

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 have reworked that sentence in an attempt to make it less painful in 1e350e3

Copy link
Contributor

@OR13 OR13 left a comment

Choose a reason for hiding this comment

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

I agree with the intention of the PR, but I think it does not reflect the current normative requirements and their interpretation by developers.

This paragraph seems to contradict existing requirements.

Perhaps a smaller paragraph can be made compatible with the existing requirements, and we can adjust / add more, if we are able to reach consensus on the related open PRs.

Signed-off-by: Brent Zundel <[email protected]>
@iherman
Copy link
Member

iherman commented May 11, 2023

The issue was discussed in a meeting on 2023-05-10

  • no resolutions were taken
View the transcript

1.5. Clarify relationship bx securing mechanisms and media types (pr vc-data-model#1107)

See github pull request vc-data-model#1107.

Manu Sporny: PR 1107 - topic clarifying relationship between securing mechanisms and media types.

Orie Steele: needs to review recent changes.

@msporny
Copy link
Member

msporny commented May 13, 2023

Editorial, multiple reviews, changes requested and made, no objections, merging.

@msporny msporny merged commit 354036f into w3c:main May 13, 2023
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.

Media types do not indicate securing mechanism
9 participants