@credential-handler/vc-examples
v6.13.0
Published
Verifiable Credentials for the CHAPI Issuer Playground
Readme
Example Verifiable Credentials (@credential-handler/vc-examples)
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.
Table of Contents
Background
Credentials added to this package are used on the VC Playground's Issuer tool.
Install
- Node.js 18+ is required.
Development
To install locally (for development):
git clone https://github.com/credential-handler/vc-examples.git
cd vc-examples
npm installTo run test:
npm testTo check credentials against local (and remote) contexts:
npm run checkThis 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.
Usage
Add / Update a Verifiable Credential
To add or update credentials in the ./credentials directory:
- Within the
./credentialsdirectory, 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.jsonfile. 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
imagefile for the credential in the corresponding directory. The image file should be in eitherJPGorPNGformat, for example./credentials/movie-ticket/image.png.
Add / Update a Credential Context
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
./contextsdirectory. Make sure to use kebab case for the directory name. It should contain a filev1.jsonthat 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.jsoncontaining 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
./contextsdirectory 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
vocabdirectory within your./contexts/foo-barcontext directory. Inside the./contexts/foo-bar/vocabdirectory, you can define the vocabularies within anindex.htmlfile.
Get the path to credentials directory
import {credentialsDir} from '@credential-handler/vc-examples';Get the path to contexts directory
import {contextsDir} from '@credential-handler/vc-examples';Contribute
See the contribute file!
PRs accepted.
If editing the Readme, please conform to the standard-readme specification.
License
New BSD License (3-clause) © Digital Bazaar
