What are credentials?
A digital credential is an electronic record issued by a trusted source that certifies specific information about a person or entity. Crossmint makes it easy to issue, manage, and verify credentials onchain, following the W3C VC standard.
Verifiable Credentials is an Enterprise feature. Contact Sales
for access.
Integration steps
1. Create a Developer Account
To get started, create a developer account in the Crossmint Staging Console. Open that link, sign in, and accept the dialog to continue.Crossmint offers two consoles: staging, for development and testing, and
production.
2. Get an API Key
Once you log in to the console, the next step is to create an . Click the "Integrate" tab and click on the "API Keys" option on top. Within the “Server-side keys” section, click the “Create new key” button in the top right. Then, check the scopescredentials.create
, credentials.read
, and credentials:templates.create
under the “Verifiable Credentials”
category and create your key. Save this key for the next step.
3. Create a Credential Template
Every Verifiable Credential must belong to a template. Verifiable Credentials within a template share the same schema (referred to as “type” in the template definition), default-metadata, encryption, storage, and chain configurations. A credential template is equivalent to an NFT collection. For the purpose of this quickstart, we will create a template with the following parameters:-
Type:
crossmint:bedea4c5-4cea-425b-99c7-797ecbc8bc13:CourseCompletionCertificate
. Types allow you to specify the attributes you are interested in certifying. They also act as a protective measure, preventing the addition of unauthorized fields and, as a result, the tampering of the Verifiable Credential. You can define your own. -
Encryption:
none
. This means the Verifiable Credential data will be stored in plain text. To encrypt the data, read about the supported encryption modalities. -
Storage:
crossmint
. This means the Verifiable Credential data will be stored by Crossmint. To store the data at the location of your choice, or in decentralized storage, read about the supported storage modalities.
polygon-amoy
), along with public (non-confidential) metadata related to your credential’s template.
createTemplate.js
Example response
Example response
JSON
id
from the response as your TEMPLATE_ID
for the next step.
4. Issue a Credential
With a template created, we can start issuing credentials. To do this, we need to enter the subject’s email address, or wallet address, if they have one. Then, we need to specify the exact data required by the Verifiable Credential type, i.e. course name and grade. The credential’s contents are identified by the “subject” key within the credential.If you don’t include an expiration date, the credential will not expire. You can always revoke the credential in the
future, if necessary.
issueCredential.js
Example response
Example response
JSON
id
from the response for the next step.
5. Retrieve a Credential
You can retrieve a Verifiable Credential using different identifiers associated with the credential itself or the NFT associated with the credential.- Get Verifiable Credential by ID uses the format:
urn:uuid:<UUID>
- Get Verifiable Credential by NFT Locator uses the format:
<chain>:<contractAddress>:<tokenId>
- Get Verifiable Credential by NFT ID uses crossmint’s internal NFT ID
getCredential.js
Example response
Example response
JSON
6. Verify a Credential
Verifying a credential can be done in different ways, the easiest one is to call the verify API route. You can also accomplish
this with the SDK.
verifyCredential.js
Example response
Example response
JSON
7. Revoke a Credential (Optional)
To revoke a credential, you can directly use the revoke credential API:revokeCredential.js
Example response
Example response
JSON