Example Verifiable Credentials. Beyond being useful for general testing, these are also in use on the Verifiable Credential Playground.
Warning
The Verifiable Credentials in this repository are primarily created for the Verifiable Credentials Playground. Consequently, they should not be considered production ready credentials and they may be missing many necessary production and stability focused features. Please only use them for experimentation.
Credentials added to this package are used on the VC Playground's Issuer tool.
- Node.js 18+ is required.
To install locally (for development):
git clone https://github.com/credential-handler/vc-examples.git
cd vc-examples
npm install
To run test:
npm test
To check credentials against local (and remote) contexts:
npm run check
This uses jsonld.js's "Safe Mode" to to check for missing terms.
All local example context files are added as static contexts mapped to their future publication URLs via jsonld-document-loader.
To add or update credentials in the ./credentials
directory:
- Within the
./credentials
directory, create a new directory for the credential. Make sure to use kebab case for the directory name. - Inside the newly created credential directory, add a
credential.json
file. This file should contain all the necessary information for the credential, including the issuer, credential subject, and other relevant data, for example./credentials/movie-ticket/credential.json
. The credential MUST be conformant to VC Data Model 1.1. - Additionally, place a logo
image
file for the credential in the corresponding directory. The image file should be in eitherJPG
orPNG
format, for example./credentials/movie-ticket/image.png
.
To optionally add or update contexts in the ./contexts
directory:
- If you wish to include a context for a credential, create a new directory
for the context in the
./contexts
directory. Make sure to use kebab case for the directory name. It should contain a filev1.json
that should contain the JSON-LD context definition for the credential, for example./contexts/movie-ticket/v1.json
. The context MUST be conformant to VC Data Model 1.1. - Please note that once a context is created, it becomes locked and cannot be
modified. If you want to update or make changes to a context, you must create a
new context file with a new version within the context directory. For instance,
if you want to update the context for the "Alumni" credential, create a new file
named
v2.json
containing the updated JSON-LD context definition within./contexts/alumni
. The previous version,v1.json
, should be retained in the directory without any modifications. - Please make sure that the context URLs for the contexts created in the
./contexts
directory follow the format:https://contexts.vcplayground.org/examples/foo-bar/v1.json
. - In case you need to add a custom vocabulary documentation, you can include a
vocab
directory within your./contexts/foo-bar
context directory. Inside the./contexts/foo-bar/vocab
directory, you can define the vocabularies within anindex.html
file.
import {credentialsDir} from '@credential-handler/vc-examples';
import {contextsDir} from '@credential-handler/vc-examples';
To generate a JSON array of context URLs used in these examples, run the following command:
$ npm -s run extract
See the contribute file!
PRs accepted.
If editing the Readme, please conform to the standard-readme specification.
New BSD License (3-clause) © Digital Bazaar