diff --git a/index.html b/index.html index ebd66e1..f25d649 100644 --- a/index.html +++ b/index.html @@ -302,13 +302,12 @@
-When an [=issuer=] desires to specify template-based rendering instructions -for a [=verifiable credential=], they MAY add a `renderMethod` property that uses -the data model described below. +The `RenderMethod` base class can be used to provide a predetermined payload to +be displayed, transmitted, or otherwise rendered when templating is not required.
| type | -A REQUIRED [=string=] that MUST be the value `TemplateRenderMethod`. +A REQUIRED [=string=] that MUST be the value `RenderMethod`. | |
| renderSuite | +modality | -A REQUIRED [=string=] that identifies the algorithms that are used for -generating the concrete rendering. +A REQUIRED [=string=] that identifies the mode by which the payload will be +transmitted or rendered. Possible examples of modalities may include `nfc`, +`qr-code`, `audio`, and `braille`. + + |
| renderProperty | +payload | -An OPTIONAL [=list=] of [=string=] values that each conform to the -[[[RFC6901]]] syntax that specifies which properties from the [=verifiable -credential=] are exposed when using this specific render method. If -`renderProperty` is not provided, the entire [=verifiable credential=] is -presumed to be shared when the render method is used. - | -
| template | -
-An OPTIONAL [=string=] or [=ordered map|map=] that provides the template that
-will be used to perform the rendering. If the value is a [=string=], it MUST be
+An OPTIONAL [=string=] or [=ordered map|map=] that provides the raw data that
+will be used for rendering. If the value is a [=string=], it MUST be
a URL. If the value is a [=ordered map|map=], it MUST conform to the following
rules:
|
|
| renderProperty | ++An OPTIONAL [=list=] of [=string=] values that each conform to the +[[[RFC6901]]] syntax that specifies which properties from the [=verifiable +credential=] are exposed when using this specific render method. If +`renderProperty` is not provided, the entire [=verifiable credential=] is +presumed to be shared when the render method is used. + | +|
| digestMultibase |
@@ -415,15 +419,73 @@ TemplateRenderMethod |
+The `nfc` render modality transmits a binary payload representing the +[=verifiable credential=] over a wireless NFC connection. +
-The data model shown above is expressed in a [=verifiable credential=] -in the example below. +In the example below, a fully embedded NFC payload is used.
+ title="Usage of the nfc render suite">
+{
+ ...
+ "renderMethod": {
+ "type": "RenderMethod",
+ "modality": "nfc",
+ "name": "Tap to send",
+ // the NFC payload is embedded
+ "payload": "data:application/octet-stream;base64,2QZkpQGDG...G8XJWnROcY4Biw"
+ }
+
+}
+
+
+
+
+ +When an [=issuer=] desires to specify template-based rendering instructions +for a [=verifiable credential=], they MAY add a `renderMethod` property using +the `TemplateRenderMethod` class on the base data model adding additional +processing instructions as described below. +
+ +| Property | +Description | +
|---|---|
| renderSuite | ++A REQUIRED [=string=] that identifies the algorithms that are used for +generating the concrete rendering. + | +
{
"@context": [
"https://www.w3.org/ns/credentials/v2",
@@ -444,7 +506,7 @@ TemplateRenderMethod
"renderMethod": {
"type": "TemplateRenderMethod",
"renderSuite": "svg-mustache",
- "template": {
+ "payload": {
"id": "https://example.edu/credential-templates/BachelorDegree",
"mediaType": "image/svg+xml",
"digestMultibase": "zQmerWC85Wg6wFl9znFCwYxApG270iEu5h6JqWAPdhyxz2dR",
@@ -463,7 +525,7 @@ TemplateRenderMethod
information from the [=verifiable credential=] listed in `renderProperty`.
-
+
The `svg-mustache` Render Suite
The `svg-mustache` render suite uses the Mustache templating language to
@@ -484,7 +546,7 @@
The `svg-mustache` Render Suite
"type": "TemplateRenderMethod",
"renderSuite": "svg-mustache",
// the SVG file is embedded in the VC
- "template": "...3jZpW"
+ "payload": "...3jZpW"
}
}
@@ -501,7 +563,7 @@ The `pdf-mustache` render suite uses the Mustache templating language to @@ -552,7 +614,7 @@
-The `nfc` render suite transmits a binary payload representing the -[=verifiable credential=] over a wireless NFC connection. -
- --In the example below, a fully embedded NFC payload is used as the rendering -template, which only discloses the barcode identifier associated with the -credential. -
- -
-{
- ...
- "renderMethod": {
- "type": "TemplateRenderMethod",
- "renderSuite": "nfc",
- "name": "Tap to send",
- // the NFC payload is embedded
- "template": "data:application/octet-stream;base64,2QZkpQGDG...G8XJWnROcY4Biw",
- // only the barcode is transmitted over NFC
- "renderProperty": ["/credentialSubject/barcode"]
- }
-
-}
-
-