- From: Adrian Gropper <agropper@healthurl.com>
- Date: Thu, 4 Nov 2021 10:53:46 -0400
- To: phil@rhzconsulting.com
- Cc: Credentials Community Group <public-credentials@w3.org>, dzagidulin@gmail.com, public-vc-edu@w3.org
- Message-ID: <CANYRo8irDABU9Sg13-BR_H9VC9G_1xzFGNon-DoaaQ1OROy3ew@mail.gmail.com>
see also https://github.com/w3c/vc-data-model/issues/831#issuecomment-960249901 for special cases where the hash is of a subject’s biometric. - Adrian On Wed, Nov 3, 2021 at 7:52 PM Phillip Long <phil@rhzconsulting.com> wrote: > Dimitri: we have been talking about how endorsements could be handled as a > VC, and linked to specific attributes in a different VC (a skill or > competency, e.g.), as part of work under way in the HR Open Resume > workgroup. Your proposal is timely and warmly welcomed. > > Thank for triggering this useful discussion. > > Cheers, > Phil > > Phillip D. Long, Ph.D.-Founder and Principal > RHz Consulting LLC > Inquire-Listen-Design-Prototype-Analyze-Repeat > e: phil@rhzconsulting.com > LinkedIn:http://www.linkedin.com/in/longpd > — > Senior Scholar, Center for New Designs in Learning and Scholarship (CNDLS) > Georgetown University, e: pl673@georgetown.edu > — > > Honorary Professor, Institute for Teaching and Learning Innovation > University of Queensland, St. Lucia, Brisbane, QLD, Australia > > On Nov 2, 2021, at 9:57 PM, Dmitri Zagidulin <dzagidulin@gmail.com> wrote: > > > > I've been hearing the subject of cryptographically binding links between > VCs and other VCs (or other external resources like PDFs) come up more and > more lately (it's especially been prevalent in the VC Edu community). I'd > like to put forth a proposal that hopefully addresses the use case, or at > very least starts a conversation. Motivation > > 1. Provide a mechanism with which to link multiple VCs together (as > peers or as parent/child relationships). > 2. Provide examples of a general purpose hashlink > <https://urldefense.com/v3/__https://datatracker.ietf.org/doc/html/draft-sporny-hashlink__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjblMyI7Xc$> mechanism > (useful for linking VCs, but also for linking to external images, PDFs, and > other files). > > Background / Use Cases > > There are many use cases that involve binding multiple Verifiable > Credentials together. For example, a simple Student ID credential can > consist of an overall container credential, which links to several > individual credentials (such as a student Photo credential, a proof of > enrollment at a particular university, a proof of age, etc). > > Note that this is different than binding multiple credentials together in > a Verifiable Presentation (and having the presenter sign the VP). In the VP > case, the binding just means "this presenter is authenticating the handing > over of these unrelated credentials". Whereas in the linked VC case, the > credentials are aware of each other, and the peer or hierarchical > relationship is built into the VC itself. > Proposal > > This proposal introduces two new related properties: anchoredResource and > contentHash. > Anchored Resource > > An anchored resource points to one or more linked or bound resources. It > can appear in the credentialSubject section (which implies that the > resource is linked to the subject), or in the top level credential (same > level as issuer, issuanceDate, etc), which implies that the resource is > linked to the credential itself. > Content Hash > > A contentHash property provides a way to refer to an external resource > via a Hashlink. > Example > > Here's what this would look like, using a mock Student ID credential. > > { > "@context": [ > "https://www.w3.org/2018/credentials/v1 <https://urldefense.com/v3/__https://www.w3.org/2018/credentials/v1__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjbOszy8yY$>", > "https://w3id.org/security/suites/ed25519-2020/v1 <https://urldefense.com/v3/__https://w3id.org/security/suites/ed25519-2020/v1__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjbc8KWzks$>" > ], > > "id": "urn:uuid:123445", > "type": ["VerifiableCredential", "StudentIdCredential"], > "issuer": { > "id": "did:key:....", > "image": { > "id": "https://example-university.edu/logo.png <https://urldefense.com/v3/__https://example-university.edu/logo.png__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjbqzUqoCY$>", > "contentHash": "hl:<hashlink to the logo url above>" > }, > "name": "Example University" > }, > "issuanceDate": "2020-04-03T00:00:00.000Z", > "expirationDate": "2020-12-15T00:00:00.000Z", > "name": "Student Identification Document", > "anchoredResource": [{ > "id": "urn:uuid:<URN of the related photo id credential>", > "contentHash": "hl:<hashlink to the related photo id credential>" > }], > "proof": { > // ed25519 signature proof goes here > }} > > Note the two usages of contentHash in the example. In the issuer, the > hashlink > <https://urldefense.com/v3/__https://datatracker.ietf.org/doc/html/draft-sporny-hashlink__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjblMyI7Xc$> is > to a resolvable resource (a regular .png hosted somewhere), and its only > purpose is to cryptographically bind the exact version of the logo. (The > alternative way to do that is to embed the full image in a > ... url. Except those tend to make the > VC too large for some use cases, such as fitting onto a QR Code.) > > Whereas in the anchoredResource, the hashlink is to a non-resolvable > urn:uuid: type URN, which only makes sense if both the student id and the > photo credential were presented to the verifier. > > > Let's continue the conversation over at > https://github.com/w3c/vc-data-model/issues/831 > <https://urldefense.com/v3/__https://github.com/w3c/vc-data-model/issues/831__;!!IKRxdwAv5BmarQ!NXUqh588uxaE1iorS_inMNy0emRogYtZ0JD5t4VUParF0iaxmthxUGjbktVVMk0$> > ! > >
Received on Thursday, 4 November 2021 14:54:11 UTC