This ReSpec extension enhances the Verifiable Credential examples in your specification.
The Verifiable Credentials extension to the ReSpec document authoring environment enables authors to express simple examples of credentials in their specification which are then enhanced by this extension to show the digitally signed forms of the credential. An example of the output of this extension is provided below (this extension adds the tabs seen in the image below):
This extension can also be used to generate human-readable cryptographic hashes of files that are retrievable by a browser environment.
To use this extension, include the following line in your ReSpec file:
<script class="remove" src="https://cdn.jsdelivr.net/gh/w3c/[email protected]/dist/main.js"></script>
Note that there might be releases later than the one listed above. Check this repository's tags for all known releases.
To use this extension, you must add the vc
class to your examples.
The data-vc-tabs
property can be set to a space-delimited list containing any
of the following values to customize the tabs displayed:
On by default:
ecdsa-rdfc-2019
- https://www.w3.org/TR/vc-di-ecdsa/eddsa-rdfc-2022
- https://www.w3.org/TR/vc-di-eddsa/ecdsa-sd-2023
- https://www.w3.org/TR/vc-di-ecdsa/bbs-2023
- https://www.w3.org/TR/vc-di-bbs/jose
- https://w3c.github.io/vc-jose-cose/#with-jose
Optional:
Ed25519Signature2020
- https://www.w3.org/TR/vc-di-eddsa/#the-ed25519signature2020-suitesd-jwt
- https://www.w3.org/TR/vc-jose-cose/#with-sd-jwtcose
- https://www.w3.org/TR/vc-jose-cose/#securing-with-cose
<pre class="example nohighlight vc" title="Usage of the id property"
data-vc-tabs="bbs-2023 vc-jwt">
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
<span class="highlight">"id": "http://example.edu/credentials/3732"</span>,
"type": ["VerifiableCredential", "UniversityDegreeCredential"],
"issuer": "https://example.edu/issuers/565049",
"issuanceDate": "2010-01-01T00:00:00Z",
"credentialSubject": {
<span class="highlight">"id": "did:example:ebfeb1f712ebc6f1c276e12ec21"</span>,
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Science and Arts"
}
}
}
</pre>
### Set Verification Method
The `data-vc-vm` option can be used to provide a digital proof verification
method (e.g., a URL to a public key):
```html
<pre class="example nohighlight vc" title="Usage of the id property"
data-vc-vm="https://example.edu/issuers/565049#key-1">
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
<span class="highlight">"id": "http://example.edu/credentials/3732"</span>,
"type": ["VerifiableCredential", "UniversityDegreeCredential"],
"issuer": "https://example.edu/issuers/565049",
"issuanceDate": "2010-01-01T00:00:00Z",
"credentialSubject": {
<span class="highlight">"id": "did:example:ebfeb1f712ebc6f1c276e12ec21"</span>,
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Science and Arts"
}
}
}
</pre>
To use this extension, you must add the vc-hash
class to an HTML element
such as a SPAN or DIV tag.
<p>
This section demonstrates the hashing of remote files. Hashes for
`https://www.w3.org/ns/credentials/v2` are provided below:
</p>
<ul>
<li>
raw (`openssl dgst -sha256`):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="openssl dgst -sha256" />
</li>
<li>
digestSRI (sha2-256 base64pad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="sri sha2-256" />
</li>
<li>
digestSRI (sha2-384 base64pad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="sri sha2-384" />
</li>
<li>
digestMultibase (sha2-256 base16):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha2-256 base16" />
</li>
<li>
digestMultibase (sha2-256 base58btc):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha2-256 base58btc" />
</li>
<li>
digestMultibase (sha2-256 base64-url-nopad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha2-256" />
</li>
<li>
digestMultibase (sha2-384 base64-url-nopad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha2-384" />
</li>
<li>
digestMultibase (sha3-256 base64-url-nopad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha3-256" />
</li>
<li>
digestMultibase (sha3-384 base64-url-nopad):
<span class="vc-hash" data-hash-url="https://www.w3.org/ns/credentials/v2"
data-hash-format="multihash sha3-384" />
</li>
</ul>
The data-hash-url
option is used to provide the URL for which a
cryptographic digest should be generated.
The data-hash-format
specifies various ways in which the cryptographic digest
can be expressed. The supported hash expression formats are: openssl
, sri
, and multihash
. The supported digest algorithms are sha2-256
(default), sha2-384
, sha3-256
, and sha3-384
. The supported base encodings are base64url
(default), base64pad
, base16
, and base58btc
.
$ npm i
$ npm run build # build and watch index.js changes
$ npm run start # serve this directory
NOTE: This release process is not ideal and is planned to be changed/imporved in future.
To create a new release:
- Clear out
node_modules/
anddist/
git pull origin main
git checkout -b VERSION
(whereVERSION
is something like3.3.2
)npm i
npm run build
- Test by running
npm run start
and ensureindex.html
loads without errors. git add -f dist/main.js && git commit -a
git tag VERSION
git push --tags
DO NOT merge the branch down to main. All tagged releases are "headless" because they contain massive 7MB files.