The Dock Certs API
A complete solution for creating, managing and presenting Verifiable Credentials.
The Dock Certs API allows you to issue, verify and revoke verifiable credentials, manage DIDs and interact with the Dock blockchain. Dock integrates industry-leading World Wide Web Consortium (W3C) and VCDM standards, allowing it to interoperate with other open source technologies. We provide a range of open-source software on GitHub that can be used alongside the API. Primary features include:
- Easily issue, verify, manage, and revoke/unrevoke verifiable credentials.
- Create and manage decentralized identifiers (DIDs).
- Drop anchors on the blockchain for better validation and security.
- Create and assign schemas to credentials for compliance.
- Harness the security of the Dock blockchain, a network run by 50 independent validators.
- Work seamlessly across platforms with Dock’s standards-compliant, interoperable solutions.
In addition to the code samples shown in these docs, we have provided various code samples for the common requests that you can easily access here.
We also offer a free trial, testnet sandboxing and fair monthly pricing. Sign up and start issuing credentials with Dock Certs. Please read our Terms of Service before using Dock Certs.
Example Use Case
Tim is a newly graduated Lawyer from the University of Chicago, looking for an opportunity to grow his career. With the use of verifiable credentials, Tim is issued a certificate proving his qualifications from the university, the certificate resides on Tim’s mobile device.
Details of the certificate reside in the Verifiable Credential and the proof of identity of the university (which is the decentralized identifier) is stored on the blockchain. The University can also opt to create a record (called an anchor) of the credential on the blockchain with a timestamp.
When Tim applies for jobs, the process of:
- Tim applying and providing a copy of his certificate to the company. The company having to call the university to prove the authenticity of the certificate before progressing.
Changes to:
- Tim sending his digital certificate to the company who can verify the authenticity immediately.
The new process of validating and authenticating credentials is instantaneous and leaves no room for error and tampering.
Participants in the Process
Issuer
The issuer in the scenario above is the university. The educational institution providing the certificate. They also have the power to revoke the credential if necessary.
Holder
The owner of the credential, Tim has the certificate proving his qualifications on his mobile device and can share and send it to whomever he wishes.
Verifier
The workplace where Tim wants to work. They are the ones who need to verify Tim’s qualifications and can instantly do this.
Getting Started
Prerequisites
You must first have an account and acquire your credentials (API keys) before accessing the Dock Certs API. You can register an account and generate a key in your Dock Certs dashboard.
Endpoints
Dock Certs provides two endpoints based on which mode was selected when creating your API key. By default, the API keys are created for production. You can switch to test mode in Dock Certs by clicking the test mode toggle in the top right next to your avatar icon. Once in test mode you will see only testnet transactions, API keys, webhooks etc. You can then create an API key from the Dock Certs dashboard. It should be noted that in test mode your used transaction count will not increase or hit monthly limits allowing for sandboxing on our test network.
- For production mode, use the endpoint: https://api.dock.io
- For test mode, use the endpoint: https://api-testnet.dock.io
IMPORTANT NOTES:
- Any transaction you perform in test mode cannot be used for production. This means that, for example, any DID created in test mode will not work for issuing or verification in production.
- test mode will be subject to data resets periodically, so the DIDs, etc. that you create there should not be expected to be permanent.
Authentication
Dock Certs uses API keys to authenticate requests. You can obtain an API Key by signing into Dock Certs. Once a key has been generated, it should be included in all request headers as below:
- API Key (accessToken)
- Name: DOCK-API-TOKEN
- OR HTTP Bearer Authorization
Architecture Style
Dock Certs is built using a REST architecture. Our API uses standard HTTP response codes, authentication, delivers JSON-encoded responses, accepts form-encoded request bodies, and accepts form-encoded request bodies.
HTTPS is required for all API requests. Requests performed via plain HTTP will be rejected. API requests that do not include authentication will also fail. JSON requests should typically be encoded as UTF-8.
HTTP Method | Description |
---|---|
GET | Gets one or many resources |
POST | Creates a new resources |
PATCH | Partially updates a resource |
DELETE | Deletes a resource |
Rate Limits
We allow you to make up to 200 requests in a 2 minute window (avg 100 reqs/min or 1.6 reqs/second). If you exceed beyond that, you will receive a 429 Too Many Requests response and have to wait up to a minute for the next request depending on when you hit the limit. If you require higher rate limits, please contact us.
Error Handling
The Dock Certs API uses standard HTTP response codes to indicate if an API request was successful or unsuccessful.
The table below shows the most frequent HTTP error messages:
Code | Meaning |
---|---|
400 | Bad Request -- Your request was rejected (e.g., missing mandatory field). |
402 | Payment required -- Transaction limit reached or upgrade required to proceed |
401 | Unauthorized -- Do not own resource or have an invalid API key in the header. |
404 | Not Found -- The resource that you're trying to interact with could not be found on the server. |
405 | Method Not Allowed -- The requested method does not exist in the API spec. Please check the {did} value and ensure that it's not empty/blank. |
429 | Too Many Requests -- You sent too many requests. Please try to reduce the number of requests. |
500 | Server Errors -- Something has gone wrong on the server. Contact us if this keeps happening. |
Terminology
It is important to fully understand all the terminologies within the Dock ecosystem. The following are common terminologies within our ecosystem:
Terminology | Description |
---|---|
DID | DID stands for Decentralized Identifier. It is a new type of identifier that enables verifiable, decentralized digital identity. A DID refers to any subject (e.g., a person, organization, thing, data model, abstract entity, etc.) as determined by the controller of the DID. For more information, please refer here. |
Anchoring | A feature that allows users to store a digest of one or more credentials (or any files) on our blockchain so that they are associated with immutable timestamps and hence can be proven to have been created at a certain point in time. |
Data Schema | The structure that describes the logical view of the data. It is useful to enforce a specific structure on a collection of data like a Verifiable Credential. |
Registries | A process to verify credentials in such a way that each verified credential has its own unique number. This process references a credential definition and specifies how revocation of that credential type will be handled. |
Schema | The structure of credentials which are shareable among issuers as they do not contain any cryptographic material and thus are created less frequently. |
Blob | Blob stands for Binary Large OBject. It is a collection of binary data stored as a single entity. The schemas are identified and retrieved by their unique blob id, which is a 32-byte long hex string. |
DID Resolver | The tool that initiates the process of learning the DID document. |
Webhooks
We provide webhooks for asynchronous integration with the API. You can configure a webhook to receive notifications whenever events occur within the API (see below for the list of published events). To use our webhook, you need to set the webhook URL that acts as a receiver receiving the information whenever an event happens. You also need to select at least one of the webhook events from Dock Certs to trigger the data exchange.
How to Setup Webhook
To setup webhook, simply follow the steps below:
- Go to Webhooks in Dock Certs.
- Click Add Endpoint.
- Fill in the Endpoint URL and select Endpoint Events for the webhook events.
- Click Create Webhook.
- Once the webhook is created you will see a secret token. This token is sent in the webook POST request for you to validate that the webhook came from Dock.
Webhook Events
You can configure the following events to trigger the HTTP request to send the data to your application.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "anchor_create",
"data": {
"status": "finalized",
"encodedTx": "0x90040f008082f112f7575ff922ffa2290c9b11e071cc45a79b3cc1d3de66d0be819fe7e808",
"result": {
"InBlock": "0xbaf1bfcc5b629b775a4d03c9baa0b0d6d7197fe1ab1805993d38da3447661c76"
}
}
}
anchor_create
This event indicates an anchor has been created. It will fire when an anchor has been created.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "credential_create",
"data": {
"id": "http://example.com/39",
"signingOps": 1,
"byteSize": 727,
"key": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy#5GsBC74MW9DxHkFUYDVGPnbtioEaFgPgkdytQU3cRTQcHJCz",
"credential": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"VerifiableCredential"
],
"credentialSubject": {
"id": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy"
},
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"proof": {
"type": "Sr25519Signature2020",
"created": "2021-11-23T03:16:47Z",
"verificationMethod": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy#keys-1",
"proofPurpose": "assertionMethod",
"proofValue": "z4jUYjc4CyQSfVCivjjTpngjg9TsSL5GkdNesqQFBxwtZwgruophe7xaAzFMSx2gZt4CmXhhhWz4aEyA9wtpqwhdn"
},
"issuer": {
"id": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy",
"name": "Issuer Name"
}
}
}
}
credential_create
This event indicates a credential has been created. It will fire when a credential has been created.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "credential_issued",
"data": {
"id": "http://example.com/39",
"signingOps": 1,
"byteSize": 691,
"key": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy#5GsBC74MW9DxHkFUYDVGPnbtioEaFgPgkdytQU3cRTQcHJCz",
"credential": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"VerifiableCredential"
],
"credentialSubject": {
"id": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy"
},
"issuanceDate": "2021-11-23T03:16:25.321Z",
"proof": {
"type": "Sr25519Signature2020",
"created": "2021-11-23T03:16:25Z",
"verificationMethod": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy#keys-1",
"proofPurpose": "assertionMethod",
"proofValue": "z41DNxuUzSvKz68L2YkXehR3nQ9PWoAfj6zk44gUzFXKK7pd2zEQByYAUGGg5TT2cZCxiYAmg49NGMX8tRLyf9W1G"
},
"issuer": {
"id": "did:dock:5DhSFTFJwD6bFdrPdTibhxQypDruZkBGeWs1p34FS87ko5Vy",
"name": "Issuer Name"
}
}
}
}
credential_issued
This event indicates a credential has been issued. It will fire when a credential has been issued.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "credential_revoke",
"data": {
"status": "finalized",
"encodedTx": "0xa902040a0153b52f6bac3d812853d8aad9c94eb98b4a5dd632c5bf805dc4140965c753641e04aff1aa6770d43d684690c0ad679a8608d5b7576feb3fdc1d6712decf73ca44efd3ec3b0004483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed00787db3a6322a4d81ab64848fdb4ec7f76404ad2360075b64e2de1c3d4bb0f2624d4684d073e528367a2dba2379254a50be816afa7eb731fa4f4807f1c6b4548f",
"result": {
"InBlock": "0x759314aa18d741335ac809ca2d877aed0a00375c3ba4a7dfc398d80dbc7bf2d5"
}
}
}
credential_revoke
This event indicates a credential has been revoked. It will fire when a credential has been revoked.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "credential_unrevoke",
"data": {
"status": "finalized",
"encodedTx": "0xa902040a0253b52f6bac3d812853d8aad9c94eb98b4a5dd632c5bf805dc4140965c753641e04aff1aa6770d43d684690c0ad679a8608d5b7576feb3fdc1d6712decf73ca44ef45ed3b0004483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed0052ced1926bc978029cf9ebe9107450961ca8f0aed21033b61087a901271e1451c67a1f8feb7851f8dda0913223fc3bb5a26b9550014dccce61b5392e9a5e3181",
"result": {
"InBlock": "0x4279f477c280d1721efaee8a3ee621f3d96068fe978811db73d4ab27fecc687a"
}
}
}
credential_unrevoke
This event indicates a credential has been unrevoked. It will fire when a credential has been unrevoked.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "did_create",
"data": {
"status": "finalized",
"encodedTx": "0x91010409004e0d07d7121cbfb78be48fea337f7afd6f90aa233e33c17ab8137c4873c7da924e0d07d7121cbfb78be48fea337f7afd6f90aa233e33c17ab8137c4873c7da920012e604ac480aa06981c9b5dae4fc0e0bd8961fd858584e0a53f8a66e9b5e1648",
"result": {
"InBlock": "0xe5f17466a3c4b2ac3f455d923367e6e2baf9970583c2ed56299280d3a269a471"
}
}
}
did_create
This event indicates a DID has been created. It will fire when a DID has been created.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "did_update_key",
"data": {
"status": "finalized",
"encodedTx": "0xa902040901c7f54544fc24f652c4bfd1eded6e26d4400cd2cc91f130f85076aee6f1f6efb2001eabe8649baa2de3ee613dd488a433f743ed36854843e2aef4317a924118487201483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed15293c000030af292a54c9ac95c999dd746ae61b6f35e1b8e610a637ef7d8710c093826e6d7a01d665bbcc8e4825830711371dade0f78b604b39fa864e92911ed030e15181",
"result": {
"InBlock": "0x8c876bd6fe0dbbadc91ed04a5d9f811dca02850f95dda409e558034df24177bb"
}
}
}
did_update_key
This event indicates a keyType
value within the DID has been updated. It will fire when the keyType
value has been updated.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "did_update_controller",
"data": {
"status": "finalized",
"encodedTx": "0xad02040901c81cd739fdd090d889280f04ddec47cad8240290e974319eaf1a7d7f10213c500203d5dc1a348b80aa06673fc36b8d1c0405125ad61d90c43e157815cc0779a8696801483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed822b3c000139a87a45eaf9ada41c964bada887ebffa7bf34d66aec88821fb7a6d2177d634e83ab7a45f685835add00cebcc96a8c572e2833ad01d6dcacb0f72fb9bf80fa0a",
"result": {
"InBlock": "0x47c6640633a8a22df1de8fdc8e80f36dc403e735975e6f14d1a30419a18a6abd"
}
}
}
did_update_controller
This event indicates a controller
value within the DID has been updated. It will fire when the controller
value has been updated.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "did_delete",
"data": {
"status": "finalized",
"encodedTx": "0xa1010409024e0d07d7121cbfb78be48fea337f7afd6f90aa233e33c17ab8137c4873c7da92c0ea3b000008dcdfb22efd01604ca38facdb6c1086f2d76c2a36425f293e4c687e48f0ea295e02162e8af53f334544676bbf906f12f60d36a0b42dad89e169bc2816d68a85",
"result": {
"InBlock": "0x588b2170d114f68f47d697b92c4c2184db26deada7e114f205a6bb95a157a3bd"
}
}
}
did_delete
This event indicates a DID has been deleted. It will fire when a DID has been deleted.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "registry_create",
"data": {
"status": "finalized",
"encodedTx": "0x1901040a0035cbd5b17285e74b86b198543f712c03c99b75d7e2ed82923fa1fde7f1129ef40004483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed00",
"result": {
"InBlock": "0x2407aa20e16ae915698888ed84f41d1bc06d3733ed17c89041b897e91ecf8fac"
}
}
}
registry_create
This event indicates a registry has been created. It will fire when a registry has been created.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "registry_delete",
"data": {
"status": "finalized",
"encodedTx": "0x2502040a0335cbd5b17285e74b86b198543f712c03c99b75d7e2ed82923fa1fde7f1129ef443ec3b0004483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed00405a766d239405e6e3c63104581168cbb831e32299f7af72e39b5e8774631674f41595542249599a454ce957374be99fc061ec40200d380a8df1776e4417fa82",
"result": {
"InBlock": "0x4c58ebd08823a2dd5d776eaed526bfeddacf988d79c8e85cd807e8765622de7a"
}
}
}
registry_delete
This event indicates a registry has been deleted. It will fire when a registry has been deleted.
SAMPLE JSON PAYLOAD
{
"token": "4A_Z0fYD19q1qKZ03qAfB0zTu8XYuLPpGk0oHfP8OrvGGDi5Jz8C86F6EVz8Wd2c",
"event": "schema_create",
"data": {
"status": "finalized",
"encodedTx": "0xa106040b00e1420661c333988c024f0a4bd3ea4ed0e75773247a369419acdaa67447c22ca489047b2224736368656d61223a22687474703a2f2f6a736f6e2d736368656d612e6f72672f64726166742d30372f736368656d6123222c226164646974696f6e616c50726f70657274696573223a66616c73652c226465736372697074696f6e223a22446f636b20536368656d61204578616d706c65222c2270726f70657274696573223a7b22616c756d6e694f66223a7b2274797065223a22737472696e67227d2c22656d61696c41646472657373223a7b22666f726d6174223a22656d61696c222c2274797065223a22737472696e67227d2c226964223a7b2274797065223a22737472696e67227d7d2c227265717569726564223a5b22656d61696c41646472657373222c22616c756d6e694f66225d2c2274797065223a226f626a656374227d483fc667eb8a63f8e040bb91cd23f6c650fb668d0152390a026620d05c5168ed00c2d11f1a68160f1a7d926c7c89a937866d70fdd0b5d350a6b2be88ad099a8776c6518e1d798553f596baff8d3be36d0172860e7a9b1368019339c7da05bf3485",
"result": {
"InBlock": "0x8b7042e52223334929e1cb2507e9be5b35014573dbe693bbcda2952f6254934f"
}
}
}
schema_create
This event indicates a schema has been created. It will fire when a schema has been created.
Dock Postman Collection
Download and use our Postman Collection to experiment with basic API flows:
- Download Postman here.
- Download our API collection here.
- Import Dock Collection in Postman with our API collection that you have downloaded previously. For the detailed instructions to import the json file, please refer here.
- Create a new environment in Postman. For the detailed instruction to create a new environment, please refer here.
- In your new Postman environment, you need to create two new
ApiKey
andBaseUrl
variables. Please refer here for the instructions to set the new variables. - Login to Dock Certs.
- Enable the Test mode in your Dock Certs dashboard to use the sandbox environment.
- In your Dock Certs dashboard, click Create API key on the keys page to generate the key, copy and save it.
- Set
ApiKey
initial and current values with the value that you generated in Dock Certs. - Set
BaseUrl
initial and current values with https://api-testnet.dock.io
Simple E2E Create Credentials/Presentation Flow
This flow refers to Postman, but the general steps are the same however you use the API. The Postman collection includes the scripts that automatically propagate results into the next request bodies when you follow the below steps. To issue a credential and or a presentation on the holder's behalf, the following steps are required:
DID CREATED - 200 Response
{
"id": "823",
"data": {
"did": "did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg",
"hexDid": "0x8b3997a95f86c80e5eb8a4ab67dbb164d5cc19ea24c072a85a3eb0d552fa837f",
"controller": "did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg"
}
}
1. Create a DID
To create a new DID to issue with, go to Create DID and click Send. The id
property denotes a job ID in the system that you can use to query for blockchain transaction status.
The Dock API supports did:dock
, did:polygonid
and did:key
method creation.
DID VERIFIED - 200 Response
{
"@context": "https://www.w3.org/ns/did/v1",
"id": "did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg",
"authentication": [
"did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg#keys-1"
],
"assertionMethod": [
"did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg#keys-1"
],
"publicKey": [ ... ]
}
2. Verify the New DID
To verify if the new DID has been registered, go to Verify DID Registered and click Send.
CREDENTIAL ISSUED - 200 Response
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"VerifiableCredential"
],
"credentialSubject": {
"id": "did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg"
},
"issuanceDate": "2021-11-12T14:43:46.504Z",
"proof": { ... },
"issuer": { ... }
}
3. Create a Signed Credential
To create a Verifiable Credential using the the new issuer DID, go to Create Signed Credential and click Send. This will send some example credential data to the API and sign it with your DID keypair. It will return a Verifiable Credential that conforms to the W3C spec.
CREDENTIAL VERIFIED - 200 Response
{
"verified": true,
"results": [ ... ]
}
4. Verify the Signed Credential
To verify if the credential's cryptographic proof, revocation status and more go to Verify Signed Credential and click Send.
PRESENTATION CREATED - 200 Response
{
"@context": [
"https://www.w3.org/2018/credentials/v1"
],
"verifiableCredential": [
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"VerifiableCredential"
],
"credentialSubject": {
"id": "did:dock:5FDFd1Woa3cG1m18PLgPpYgGfwE5S1RqXyHeEYC86vUxzzkg"
},
"issuanceDate": "2021-11-12T14:43:46.504Z",
"proof": { ... },
"issuer": { ... }
}
],
"id": "https://creds.dock.io/presentation/adfb13f1a4b8934d0e94d2aa507e006c",
"type": [
"VerifiablePresentation"
],
"proof": { ... }
}
5. Create a Presentation
To create a Verifiable Presentation by using the credential, go to Create Presentation and click Send.
PRESENTATION VERIFIED - 200 Response
{
"verified": true,
"results": []
}
6. Verify the Presentation
The same credential verification route can be used to verify a presentation. In Postman, go to Verify Presentation and click Send.
Dock Swagger UI
Dock Swagger UI generates interactive API documentation to try out the API calls directly in any browser. Use our Swagger UI to execute the API calls quickly:
- Login to Dock Certs.
- Enable the Test mode in Dock Certs to benefit from unlimited transactions.
- Create your first API key by clicking 'Create API key'. Copy and Save it.
- Use this key to 'Authorize' into the Swagger UI.
DIDs
Endpoints
DID stands for Decentralized IDentifiers. DIDs are meant to be globally unique identifiers that allow their owner to prove cryptographic control over them. A DID identifies any subject (e.g., a person, organization, thing, data model, abstract entity, etc.) that the controller of the DID decides that it identifies.
DIDs in Dock are created by choosing a 32-byte unique (on Dock chain) identifier along with a public key. You can update and delete a DID as well as list all DIDs. DID is identified by a unique, random key.
For a detailed example of the DIDs workflow. Please refer here.
Create DID
POST /dids REQUEST
curl --location --request POST 'https://api.dock.io/dids' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw '{
"type": "dock",
"keyType": "ed25519"
}'
{
"type": "dock",
"keyType": "ed25519"
}
A DID, a public key, and a controller are required to create a new DID. The controller is both the owner of the public key and a DID. The DID can be created using an auto-generated keypair, and the controller will be the same as the DID unless otherwise specified. The DID and public key have no cryptographic relation.
It is important to have a public key of one of its three supported types. Dock supports 3 types of public keys: sr25519
, ed25519
, and secp256k1
.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | body | DIDDock | false | DID as fully qualified, e.g., did:dock: . Default value will is a randomly generated DID. |
type | body | string | false | Specifies the DID method to for the generated DID. Supported options are key , polygonid and dock (default). |
controller | body | DIDDock | false | DID as fully qualified, e.g., did:dock: . The default value of the controller is the did property. |
keyType | body | KeyType | false | Type of public key for DID. The default value of the keyType is sr25519 . |
Enumerated Values
Parameter | Value | Desctiprion |
---|---|---|
keyType | sr25519 or ed25519 or secp256k1 or bjj | keyType signature variants. |
type | dock or key or polyginid | which DID method to generate |
200 Response
{
"id": "926",
"data": {
"did": "did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA",
"hexDid": "0x3d7129a4d915e8f864c4bf4f4bcbdb67cde87e9bbcec06cb3baefd5b31812c03",
"controller": "did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA"
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will try to create DID. NOTE: DID does not exist on network until the job identified in the response is complete. | JobStartedResult |
400 | Bad Request | The request was unsuccessful, because of invalid params. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get DID
GET /dids/{did} REQUEST
curl --location --request GET 'https://api.dock.io/dids/did:dock:xyz' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
When a DID is provided in the path, the API will attempt to resolve that DID into a DID document. This document contains the public keys and more information relating to that DID, check the identity foundation did configuration document to learn more.
The API supports resolving many DID methods, some examples are:
did:dock:5CEdyZkZnALDdCAp7crTRiaCq6KViprTM6kHUQCD8X6VqGPW
- resolves through the Dock blockchaindid:key:z6MkjRagNiMu91DduvCvgEsqLZDVzrJzFrwahc4tXLt9DoHd
- the public key is embedded in the DID
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | DIDDock | true | Represents a specific DID that uniquely identifies the key resource. |
200 Response
{
"@context": "https://www.w3.org/ns/did/v1",
"id": "did:dock:5EEepQGeAeWnYgV8DWj5pH7pjHqrP2ZN2oBiE6ND2ZHA1dyN",
"authentication": [
"did:dock:5EEepQGeAeWnYgV8DWj5pH7pjHqrP2ZN2oBiE6ND2ZHA1dyN#keys-1"
],
"assertionMethod": [
"did:dock:5EEepQGeAeWnYgV8DWj5pH7pjHqrP2ZN2oBiE6ND2ZHA1dyN#keys-1"
],
"publicKey": [
{
"id": "did:dock:5EEepQGeAeWnYgV8DWj5pH7pjHqrP2ZN2oBiE6ND2ZHA1dyN#keys-1",
"type": "Sr25519VerificationKey2020",
"controller": "did:dock:5EEepQGeAeWnYgV8DWj5pH7pjHqrP2ZN2oBiE6ND2ZHA1dyN",
"publicKeyBase58": "ZY7vx2Jg1NSpEyrfGpDm7mRxNZyoYtbjjCjhHbhPtzM"
}
]
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the DID doc. | |
404 | Not Found | The requested DID was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
List DIDs
GET /dids REQUEST
curl --location --request GET 'https://api.dock.io/dids' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Return a list of all DIDs that your user account controls as fully resolved DID documents.
200 Response
[
{
"@context": "https://www.w3.org/ns/did/v1",
"id": "did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA",
"authentication": [
"did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA#keys-1"
],
"assertionMethod": [
"did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA#keys-1"
],
"publicKey": [
{
"id": "did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA#keys-1",
"type": "Sr25519VerificationKey2020",
"controller": "did:dock:5DTGPqE2qYncxoDjrEWKhcTnn6hfsN24F7YZWSjGVUxgBgHA",
"publicKeyBase58": "4vm85LvBvhro1N9u4dfKWEyTayXojrTJbJCmzSJixK6L"
}
]
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | All of a user's DIDs fully resolved into DID documents. | DIDDock |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Delete DID
DELETE /dids/{did} REQUEST
curl --location --request DELETE https://api.dock.io/dids/{did} \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
}'
Deletes a DID and its metadata from the blockchain and our platform. This will also delete the associated keypair from the key management system meaning that you cannot sign messages or credentials with it after this operation. The DID will no longer be able to be resolved. This operation is not reversible.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | DID | true | Represents a specific DID that uniquely identifies the key resource. |
200 Response
{
"id": "928",
"data": {
"deleted": true
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will remove the DID. | JobId |
401 | Unauthorized | The request was unsuccessful, because you don't own the DID. | Error |
404 | Not Found | The DID does not exist. | Error |
405 | Method not Allowed | The {did} value is blank/empty. Please ensure that the {did} value does exist. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Export DID
POST /dids/{did}/export REQUEST
curl --location --request POST https://api.dock.io/dids/{did}/export \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"password": "aStr0ngP@ssw0rd"
}'
Exports the DID document and keys as an encrypted Universal Wallet JSON-LD document
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | DID | true | Represents a specific DID that uniquely identifies the key resource. |
password | body | string | true | A password to encrypt the JSON-LD payload with |
200 Response
{
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and the DID has been exported. | |
401 | Unauthorized | The request was unsuccessful, because you don't own the DID. | Error |
404 | Not Found | The DID does not exist. | Error |
Profiles
Endpoints
Organization Profiles are used to provide more context for an Issuer DID. Details about the issuer such as name and logo can be added using a Organization Profile. These details will be included in credentials that are issued by the DID.
Create Profile
POST /profiles REQUEST
curl --location --request POST 'https://api.dock.io/profiles' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw '{
"name": "My Test Profile",
"did": "did:dock:xyz",
"description": "Testing out the Organization Profiles API",
"logo":""
}'
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
The did
and name
fields are required to create a new Profile.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | body | DIDDock | true | DID as fully qualified, e.g., did:dock: . |
name | body | string | true | The name to use for this issuer (e.g. a school name). |
description | body | string | false | A description of the issuer. |
logo | body | string | false | A Base64 encoded image to use as the logo for the issuer. |
200 Response
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and the Profile was created. | |
400 | Bad Request | The request was unsuccessful, because of invalid params. | Error |
Get Profile
GET /profiles/{did} REQUEST
curl --location --request GET 'https://api.dock.io/profiles/did:dock:xyz' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
When a DID is provided in the path, the API will retrieve the Profile associated with that DID.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | DIDDock | true | Represents a specific DID that uniquely identifies the profile. |
200 Response
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the profile. | |
404 | Not Found | The requested profile was not found. | Error |
List Profiles
GET /profiles REQUEST
curl --location --request GET 'https://api.dock.io/profiles' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Return a list of all Profiles that your user account controls.
200 Response
[
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | All of a user's profiles. | DIDDock |
Update Profile
PATCH /profiles/{did} REQUEST
curl --location --request PATCH 'https://api.dock.io/profiles/did:dock:xyz' \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}'
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
The update profile operation means that you can update the details of the profile. To do so, you need to provide a different value for at least one of name
, description
or logo
.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | body | DIDDock | true | DID as fully qualified, e.g., did:dock: . |
name | body | string | true | The name to use for this issuer (e.g. a school name). |
description | body | string | false | A description of the issuer. |
logo | body | string | false | A Base64 encoded image to use as the logo for the issuer. |
200 Response
{
"did": "did:dock:xyz",
"name": "My Test Profile",
"description": "Testing out the Organization Profiles API",
"logo":""
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will update the profile. | |
400 | Bad Request | The controller value is incorrect. | Error |
401 | Unauthorized | The request was unsuccessful, because you don't own the profile. | Error |
404 | Not Found | The profile does not exist. | Error |
Delete Profile
DELETE /profiles/{did} REQUEST
curl --location --request DELETE https://api.dock.io/profiles/{did} \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
}'
Deletes a profile from our platform. It does NOT delete the associated DID, nor revoke the credentials issued for the profile.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | DID | true | Represents a specific DID that uniquely identifies the profile to delete. |
200 Response
{
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will remove the profile. | |
401 | Unauthorized | The request was unsuccessful because you don't own the profile. | Error |
404 | Not Found | The profile does not exist. | Error |
405 | Method not Allowed | The {did} value is blank/empty. Please ensure that the {did} value does exist. | Error |
Credentials
Endpoints
You can create and sign Verifiable Credentials on Dock Certs and its API. By default, Dock does not store the credential - only its metadata. You can choose to persist a credential, in which case we will encrypt and store the credential for later retrieval using a password. Verifiable Credentials are cryptographically secure and tamper-proof. Once issued, they cannot be edited.
The Dock API supports issuing two types of credentials. The native Dock Verifiable Credentials and Polygon ID Verifiable Credentials.
Issue Credential
POST /credentials REQUEST
{
"anchor": true,
"persist": false,
"distribute": true,
"recipientEmail": "myemail@dock.io",
"schema": "https://schema.dock.io/TestSchema-V1-1695817897561.json",
"template": "b8dd5768-0777-42c2-ae73-859e1079369b",
"credential": {
"type": ["UniversityDegreeCredential"],
"subject": {
"id": "did:dock:5CDsD8HZa6TeSfgmMcxAkbSXYWeob4jFQmtU6sxr4XWTZzUA",
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Science and Arts"
}
},
"issuer": "did:dock:xyz",
"issuanceDate": "2020-08-24T14:15:22Z"
}
}
curl --location --request POST https://api.dock.io/credentials/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"persist": false,
"anchor": true,
"template": "b8dd5768-0777-42c2-ae73-859e1079369b",
"credential": {
"type": ["UniversityDegreeCredential"],
"subject": {
"id": "did:dock:5CDsD8HZa6TeSfgmMcxAkbSXYWeob4jFQmtU6sxr4XWTZzUA",
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Science and Arts"
}
},
"issuer": "did:dock:xyz",
"issuanceDate": "2020-08-24T14:15:22Z"
}
}'
Creates and issues a JSON-LD Verifiable Credential that conforms to the W3C VCDM specification. The type
values and subject properties must be represented by a schema URI in the context
property. If you do not specify a context
property, the API will automatically generate an embedded JSON-LD context based on the properties within your credential. You can read more about JSON-LD and contexts here.
To sign a credential, an issuer
must be supplied as either a fully qualified DID string or an object with at least an id
property which is a fully qualified DID. (e.g: did:dock:xyz
)
By default, Dock does not store the credential contents at all - only minimal credential metadata. You can choose to set the persist
value to true
and provide a password
string which will store the credential contents encrypted on our platform. The following metadata is stored on each issuance:
- Credential ID property
- Credential size in bytes
- Issuer DID
- Issuance date
For a detailed example of the credential workflow. Please refer here.
Zero Knowledge Proofs (ZKP)
Dock credentials support anonymous credentials using Zero Knowledge Proofs and Selective Disclosure by using the BBS+ signing algorithm when issuing the credential. To enable this functionality, simply set the algorithm
field in the request to dockbbs+
.
Credential Distribution
Dock's API has built in credential distribution on issuance, allowing you to send credentials directly to a holder's email and/or Dock-compatible wallet. You can achieve this by supplying the recipientEmail
field and distribute: true
in your request. For DID distribution, simply set the credentialSubject.id
property to the holder's DID.
Revocation
In order to support revocation the credential must be linked to a revocation registry at the time of issuance. To link the revocation registry to the credential set the status
field in the Credential body to the registry.id
value.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
anchor | body | boolean | false | Whether to anchor the credential on the blockchain as soon as it is issued. Defaults to false. |
persist | body | boolean | false | Whether to store an encrypted version of this credential with us. Defaults to false, if true you must supply password. |
password | body | string | false | Password used to encrypt the credential if you choose to store it. The same password must be used to retrieve the credential contents. Dock does not store this password. |
template | body | UUID string | false | The ID of the intended template/design, optional |
format | body | string | false | Specifies the output format of the credential, either jsonld or jwt . Defaults to jsonld . |
algorithm | body | string | false | Specifies which signing algorithm to use to sign the issued credential. Defaults to ed25519 . |
distribute | body | boolean | false | Whether to use credential distribution to DID/email, optional |
recipientEmail | body | string | false | The holder's email for email distribution |
credential | body | Credential | true | Credential object as described in the schema. |
Enumerated Values
Parameter | Value | Description |
---|---|---|
algorithm | ed25519 or secp256k1 or sr25519 or dockbbs+ | The algorithm used to sign the credential. |
200 Response
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"VerifiableCredential",
"UniversityDegreeCredential"
],
"credentialSubject": {
"id": "did:dock:5CDsD8HZa6TeSfgmMcxAkbSXYWeob4jFQmtU6sxr4XWTZzUA",
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Science and Arts"
}
},
"issuanceDate": "2020-08-24T14:15:22Z",
"proof": {
"type": "EcdsaSecp256k1Signature2019",
"created": "2021-11-22T22:51:08Z",
"verificationMethod": "did:dock:5FfmGmkY1BqEqRQhRLCLDLHPBFvhSbEBK3DJhEk9mbkpfAXT#keys-1",
"proofPurpose": "assertionMethod",
"proofValue": "zAN1rKrjNqYSr6mjbNEohqhCAnEoLWFgJutBmYMkXZYG8RatBuCv7ymFHEchufa1vjiM4JkHCkasswjukYVVJT3rBmTaRaUDHT"
},
"issuer": "did:dock:xyz"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns the created Verifiable Credential. | VerifiableCredential |
400 | Bad Request | The request was unsuccessful, because of invalid/insufficient credential params. | Error |
401 | Unauthorized | The request was unsuccessful, either because the authorization token was missing/invalid or you don't own the DID. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Request Claims
POST /credentials/request-claims REQUEST
{
"schema": "https://docknetwork.github.io/vc-schemas/basic-credential.json",
"claims": [
"id"
],
"credentialOptions": {
"anchor": false,
"persist": false,
"credential": {
"schema": "https://docknetwork.github.io/vc-schemas/basic-credential.json",
"name": "Basic Credential",
"type": [
"VerifiableCredential",
"BasicCredential"
],
"issuer": "did:dock:5GZn9zQTggPWijzgnoV8sZ5a74rFqC8qrz2ncp7GggeGCtKd",
"issuanceDate": "2023-12-20T00:33:15.803Z",
"subject": {
"name": "Predefined Claim"
}
},
"distribute": false
}
}
curl --location --request POST https://api.dock.io/credentials/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"schema": "https://docknetwork.github.io/vc-schemas/basic-credential.json",
"claims": [
"id"
],
"credentialOptions": {
"anchor": false,
"persist": false,
"credential": {
"schema": "https://docknetwork.github.io/vc-schemas/basic-credential.json",
"name": "Basic Credential",
"type": [
"VerifiableCredential",
"BasicCredential"
],
"issuer": "did:dock:5GZn9zQTggPWijzgnoV8sZ5a74rFqC8qrz2ncp7GggeGCtKd",
"issuanceDate": "2023-12-20T00:33:15.803Z",
"subject": {
"name": "Predefined Claim"
}
},
"distribute": false
}
}'
Creates a request to gather certain claims and then issues the holder a credential after submission. The claims are user provided and type is based on the schema provided. This can be useful to catch a subject's DID without knowing it beforehand, name or other field. It should only be used when you do not already know this data or cannot find it by other means. There is a risk that a user may enter false data - so use it sparingly and not for fields that are important.
Typically, once the request has been created, you would show the holder the QR URL as an image or deep link for them to scan with a wallet and enter claims.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
schema | body | string | false | Schema URL for the issued credential |
claims | body | array | false | The list of claims for the subject |
credentialOptions | body | CredentialIssueParameters | true | Credential issue parameters. |
200 Response
{
"id": "f1831768-853f-4ac1-ae99-adf61a92724f",
"qrUrl": "openid://discovery?issuer=https://api.dock.io/openid/connect/issuers/f1831768-853f-4ac1-ae99-adf61a92724f",
"created": "2023-12-20T00:33:35.720Z",
"updated": "2023-12-20T00:33:35.720Z",
"singleUse": true,
"claimMap": {
"id": "id"
},
"issuer": "did:dock:5GZn9zQTggPWijzgnoV8sZ5a74rFqC8qrz2ncp7GggeGCtKd",
"protocol": "openid",
"credentialOptions": {
"anchor": false,
"persist": false,
"credential": {
"name": "Basic Credential",
"type": [
"VerifiableCredential",
"BasicCredential"
],
"issuer": "did:dock:5GZn9zQTggPWijzgnoV8sZ5a74rFqC8qrz2ncp7GggeGCtKd",
"schema": "https://docknetwork.github.io/vc-schemas/basic-credential.json",
"subject": {
"name": "Predefined Claim"
},
"issuanceDate": "2023-12-20T00:33:15.803Z"
},
"distribute": false
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns the claims request properties. | OIDCIssuer |
400 | Bad Request | The request was unsuccessful, because of invalid/insufficient credential params. | Error |
401 | Unauthorized | The request was unsuccessful, either because the authorization token was missing/invalid or you don't own the DID. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get Credential
GET /credentials/{id} REQUEST
curl --location --request GET 'https://api.dock.io/credentials/credential_id?password=test' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
When a credential has been persisted on our systems, you can fetch the credential data by supplying a credential ID and the password used at issuance to encrypt the credential.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | string | true | The ID of the credential (as a full URI). |
password | query | string | true | The password given at issuance to encrypt the credential in storage |
200 Response
{
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"byteSize": 1074,
"issuerKey": "did:dock:5CU97DhQ3mnbxPAiYw3GoRqFcnvCLGuHj3MS8evD8sARmg3e#KWAtkADdAy1rCiysr4cPZre4Lj7GFWGqyN5mP5X8xuzAnGzAb ",
"createdAt": "2021-12-21T01:36:23.062Z",
"credential": { ... }
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the credential metadata and its JSON contents. | |
404 | Not Found | The requested credential was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Delete Credential
DELETE /credentials/{id} REQUEST
curl --location --request DELETE https://api.dock.io/credentials/{id} \
--header 'DOCK-API-TOKEN: API_KEY'
A credential can have its metadata deleted, and if persisted the contents will also be deleted. Deleting a credential will remove any reference to it and its contents from our systems. This action cannot be undone. This action will not revoke or invalidate the credential in any way.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
did | path | string | true | The ID of the credential (as a full URL-encoded URI). |
200 Response
{ }
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and credential will be deleted. | |
404 | Not Found | The request was unsuccessful, because the credential was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get Credentials Metadata
GET /credentials REQUEST
curl --location --request GET 'https://api.dock.io/credentials' \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
When you issue a credential with us, persistent or not, we will store certain metadata about the credential to make it easier for you to reference. You can pull a list of credential metadata using this route. To return the content of a persisted credential, you should use the GET /credentials/{id}
route
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
200 Response
[
{
"id": "https://creds.dock.io/6d601b80d56f4bb2f35b4fbe2406cc186a25b615a66fc405283ad5967f28c143",
"issuerKey": "did:dock:xyz#xyz",
"type": "BasicCredential",
"revoked": false,
"revocationRegistry": "rev-reg:dock:0x357c104d14e81d66ef43debee91eb62aac9af27c34a1e1a2194ee443989c4d44",
"createdAt": "2022-04-18T18:28:09.914Z",
"expirationDate": null,
"byteSize": 917,
"persist": false
}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the credential metadata and its JSON contents. |
Presentations
The presentation is signed using the holder's private key as it is being created. To validate the presentation, the verifier must also check the issuer's signature and the holder's public key. One way to achieve this is to make the holder have a DID too, so that the verifier can look up the DID on the chain and learn the public key.
The API allows you to create and sign a verifiable presentation out of one or more Verifiable Credentials.
For a detailed example of the presentations workflow. Please refer here.
Create Presentation
POST /presentations REQUEST
curl --location --request POST https://api.dock.io/presentations/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"holder": "did:dock:xyz",
"challenge": "string",
"domain": "string",
"credentials": [
{
"@context": [
"string"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"string"
],
"credentialSubject": {},
"issuer": "did:dock:xyz",
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"credentialStatus": {},
"proof": {
"type": "Sr25519Signature2020",
"proofPurpose": "assertionMethod",
"verificationMethod": "string",
"created": "2019-08-24T14:15:22Z",
"proofValue": "string"
}
}
]
}'
{
"holder": "did:dock:xyz",
"challenge": "string",
"domain": "string",
"credentials": [
{
"@context": [
"string"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"string"
],
"credentialSubject": {},
"issuer": "did:dock:xyz",
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"credentialStatus": {},
"proof": {
"type": "Sr25519Signature2020",
"proofPurpose": "assertionMethod",
"verificationMethod": "string",
"created": "2019-08-24T14:15:22Z",
"proofValue": "string"
}
}
]
}
The holder while creating the presentation signs it with his private key. For the verifier to verify the presentation, in addition to verifying the issuer's signature, he/she needs to verify this signature as well, and for that he must know the holder's public key.
This is an operation to create and sign a verifiable presentation out of one or more Verifiable Credentials.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
holder | body | DIDDock | true | DID as fully qualified, e.g., did:dock:xyz . |
challenge | body | string | false | Presentation's Challenge in a string format. The default value for this is random hex string . NOTE: if this presentation is being created to respond to a proof-request the challenge should be set to the value from the nonce field in the proof-request. |
domain | body | string | false | A domain for the proof in a string format. The default value for the domain is dock.io . |
credentials | body | VerifiableCredential | false | Verifiable (signed) Credential returned by API. |
Enumerated Values
Parameter | Value | Description |
---|---|---|
type | Sr25519Signature2020 or Ed25519Signature2018 or EcdsaSecp256k1Signature2019 | Type of Signature. |
proofPurpose | assertionMethod or authentication | The purpose the credential will be used for. |
200 Response
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "urn:uuid:3978344f-8596-4c3a-a978-8fcaba3903c5",
"type": ["VerifiablePresentation", "CredentialManagerPresentation"],
"verifiableCredential": [{ }],
"proof": [{ }]
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns a Verifiable Presentation. | VerifiablePresentation |
400 | Bad Request | The request was unsuccessful, because of invalid/insufficient parameters. | Error |
401 | Unauthorized | The request was unsuccessful, either because of a missing/invalid auth header or you don't own the DID. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Create Proof Request
POST /proof-requests REQUEST
curl --location --request POST https://api.dock.io/proof-requests/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"name": "Proof Request Test",
"purpose": "Prove income",
"request": {
"input_descriptors": [
{
"id": "ProofIncome-1",
"name": "Proof Request Test",
"purpose": "Prove income",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.id",
"$.credentialSubject.income.total"
]
}
]
}
]
}
}'
{
"name": "Proof Request Test",
"purpose": "Prove income",
"request": {
"input_descriptors": [
{
"id": "ProofIncome-1",
"name": "Proof Request Test",
"purpose": "Prove income",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.id",
"$.credentialSubject.income.total"
]
}
]
}
]
}
}
It often makes sense for a verifier to request proof of credentials from a holder. For this, we have built a proof requests system into the API that works with the Dock Wallet. When a request is created, you will receive a URL which you should display in a QR code for a wallet application to scan. You can define which attributes should exist in the credential, a name for the holder and yourself to see and a nonce/challenge which prevents replay attacks.
Our system supports the DIF Presentation Exchange (PEX) syntax for querying and filtering credentials.
See the https://identity.foundation/presentation-exchange/#input-descriptor-extensions for more examples, but a few common use cases are:
Require a numeric attribute to be within a range
For example, a verifier might require that the holder have an income between $100,000 and $200,000 per year. This could be requested using the following input_descriptor
{
path: ['$.credentialSubject.income.2022.total'],
filter: {
type: 'number',
minimum: 100000,
maximum: 200000
},
}
Require a date attribute to be within a range
For example, a verifier might require that the credential be issued after a certain date. In this example the verifier is requiring that the credential was issued between January 1, 2020 and December 31, 2020.
{
path: ['$.issuanceDate'],
filter: {
"type": "string",
"format": "date",
"formatMinimum": "2020-01-01",
"formatMaximum": "2020-12-31"
},
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
attributes | body | object | false | Requested attribute specifications of proof request |
name | body | string | false | Proof request name, will be shown to the holder |
nonce | body | string | false | Nonce or challenge for the presentation to match |
200 Response
{
"id": "aeec1776-84c3-4783-b80b-c6690a652892",
"name": "Proof Request Test",
"nonce": "1234567890",
"verified": false,
"created": "2022-10-17T22:48:30.619Z",
"updated": "2022-10-17T22:48:30.619Z",
"presentation": {},
"response_url": "https://api.dock.io/proof-requests/aeec1776-84c3-4783-b80b-c6690a652892/send-presentation",
"type": "proof-request",
"qr": "https://creds-testnet.dock.io/proof/acaae15e-3c6e-412e-951e-4dc129b9745a",
"request": {
"input_descriptors": [
{
"id": "ProofIncome-1",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.income.total"
],
"filter": {
"type": "number",
"minimum": 100000,
"maximum": 200000
}
}
]
}
}
]
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns a Verifiable Presentation. | VerifiablePresentation |
400 | Bad Request | The request was unsuccessful, because of invalid/insufficient parameters. | Error |
401 | Unauthorized | The request was unsuccessful, either because of a missing/invalid auth header or you don't own the DID. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
List Proof Requests
GET /proof-requests REQUEST
curl --location --request GET https://api.dock.io/proof-requests/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw'{
}'
Return a list of all proof requests and their verification status
200 Response
[
{
"id": "f2ea3225-ef6b-44d7-a37c-7713c66875b5",
"name": "Proof of Bachelors of Education",
"nonce": "6684fb3d878f2c3a25e35e36045bde8d",
"verified": false,
"created": "2023-04-05T22:00:25.729Z",
"updated": "2023-04-05T22:00:25.729Z",
"presentation": {},
"response_url": "https://api-testnet.dock.io/proof-requests/f2ea3225-ef6b-44d7-a37c-7713c66875b5/send-presentation",
"type": "proof-request",
"qr": "https://creds-testnet.dock.io/proof/f2ea3225-ef6b-44d7-a37c-7713c66875b5",
"request": {
"input_descriptors": [
{
"id": "Credential 1",
"name": "Proof of Bachelors of Education",
"purpose": "Prove that the holder has a Bachelors of Education degree",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.degreeName",
"$.credentialSubject.degreeType",
"$.credentialSubject.dateEarned | date: \"%B %d, %Y\"",
"$.credentialSubject.fullName"
]
},
{
"path": [
"$.name"
],
"filter": {
"type": "string",
"pattern": "Bachelors of Education"
}
}
]
}
}
]
}
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return all proof requests created by the user. | Inline |
Get Proof Request
GET /proof-requests/{id} REQUEST
curl --location --request GET https://api.dock.io/proof-requests/{id} \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Get the details of an existing proof request and its verification status
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | UUID | true | Proof request UUID |
200 Response
{
"qr": "https://creds-testnet.dock.io/proof/acaae15e-3c6e-412e-951e-4dc129b9745a",
"id": "fcaae15e-3c6e-412e-951e-4dc129b9745a",
"name": "Proof Request Test",
"nonce": "ffa6d005dfd8ddecf1664079bda1af1e",
"created": "2023-05-16T15:42:53.925Z",
"updated": "2023-05-16T15:42:53.925Z",
"verified": false,
"response_url": "https://api-testnet.dock.io/proof-requests/acaae15e-3c6e-412e-951e-4dc129b9745a/send-presentation",
"request": {
"id": "acaae15e-3c6e-412e-951e-4dc129b9745a",
"input_descriptors": [
{
"id": "ProofIncome-1",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.id",
"$.credentialSubject.income.total"
]
}
]
}
}
]
},
"type": "proof-request"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the proof request. | Registry |
404 | Not Found | The request was unsuccessful, because the proof request was not found. | Error |
List Proof Request Templates
GET /proof-templates REQUEST
When working with Proof Requests you will often want to request the same information from holders. To make this easier you can create Proof Request Templates to define the contents of the proof requests to be re-used.
Code samples
# You can also use wget
curl -X GET https://api-testnet.dock.io/proof-templates \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer(int32) | false | How many items to offset by for pagination |
limit | query | integer(int32) | false | How many items to return at one time (max 64) |
Example responses
200 Response
[
{
"id": "dcd6e820-5ea6-4835-8ad5-ddf3de82f3d2",
"name": "Test Proof Template",
"created": "2023-05-09T13:18:09.290Z",
"updated": "2023-05-09T13:18:09.290Z",
"request": {
"input_descriptors": [
{
"id": "Credential 1",
"name": "Test Proof Template",
"purpose": "University Degree with name, issued date requested",
"constraints": {
"fields": [
{
"path": [
"$.credentialSubject.name",
"$.issuanceDate"
]
},
{
"path": [
"$.type[*]"
],
"filter": {
"type": "string",
"pattern": "UniversityDegree"
}
}
]
}
}
]
}
}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | A paged array of proof templates | ProofRequests |
Create Proof Request Template
POST /proof-templates REQUEST
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/proof-templates \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | ProofRequest | true | Proof template object |
Example responses
200 Response
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string",
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"error": "string",
"created": "2019-08-24T14:15:22Z",
"updated": "2019-08-24T14:15:22Z"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Proof request template created | ProofTemplateObject |
400 | Bad Request | Invalid parameters | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
Get Proof Template History
GET /proof-templates/{id}/history REQUEST
Get all of the previously created proof requests based on the specified template.
Code samples
# You can also use wget
curl -X GET https://api-testnet.dock.io/proof-templates/{id}/history \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string(uuid) | true | Proof template UUID |
offset | query | integer(int32) | false | How many items to offset by for pagination |
limit | query | integer(int32) | false | How many items to return at one time (max 64) |
Example responses
200 Response
[
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string"
}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Returns the information about the proof request history | ProofRequests |
404 | Not Found | Proof template was not found. | Error |
Create Proof Request from a Template
POST /proof-templates/{id}/request REQUEST
Create a proof requtest based on the specified template.
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/proof-templates/{id}/request \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"nonce": "string",
"domain": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | Specify optional nonce and domain |
» nonce | body | string | false | none |
» domain | body | string | false | none |
id | path | string(uuid) | true | Proof template UUID |
Example responses
200 Response
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string",
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"error": "string",
"response_url": "string",
"verified": true,
"presentation": {},
"created": "2019-08-24T14:15:22Z",
"updated": "2019-08-24T14:15:22Z"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Returns the information about the proof request | ProofRequestObject |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | Proof template was not found. | Error |
Get Proof Template
GET /proof-templates/{id} REQUEST
Get the details about a specific template.
Code samples
# You can also use wget
curl -X GET https://api-testnet.dock.io/proof-templates/{id} \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string(uuid) | true | Proof template UUID |
Example responses
200 Response
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string",
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"error": "string",
"created": "2019-08-24T14:15:22Z",
"updated": "2019-08-24T14:15:22Z"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Returns the information about the proof templates | ProofTemplateObject |
404 | Not Found | Proof templates was not found. | Error |
Update Proof Template
PATCH /proof-templates/{id} REQUEST
Code samples
# You can also use wget
curl -X PATCH https://api-testnet.dock.io/proof-templates/{id} \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | ProofRequest | true | Proof template object |
id | path | string(uuid) | true | Proof template UUID |
Example responses
200 Response
{
"attributes": {
"property1": {
"name": "favouriteDrink",
"names": [
"age"
]
},
"property2": {
"name": "favouriteDrink",
"names": [
"age"
]
}
},
"name": "Proof request",
"nonce": "1234567890",
"qr": "string",
"id": "497f6eca-6276-4993-bfeb-53cbbbba6f08",
"error": "string",
"created": "2019-08-24T14:15:22Z",
"updated": "2019-08-24T14:15:22Z"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Profile has been updated | ProofTemplateObject |
400 | Bad Request | Error creating profile | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | Proof templates was not found. | Error |
Delete Proof Template
DELETE /proof-templates/{id} REQUEST
Deletes the specified template and any associated data.
Code samples
# You can also use wget
curl -X DELETE https://api-testnet.dock.io/proof-templates/{id} \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string(uuid) | true | Proof template UUID |
Example responses
400 Response
{
"status": 0,
"type": "string",
"message": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Proof templates will be deleted | None |
400 | Bad Request | Something went wrong. | Error |
404 | Not Found | Proof templates was not found. | Error |
Registries
Endpoints
Revocation means deleting or updating a credential. On Dock, credential revocation is managed with a revocation registry.
There can be multiple registries on the chain, and each registry has a unique id. It is recommended that the revocation authority create a new registry for each credential type. Dock Certs allows you to create, delete, and revoke/unrevoke the credential. You can retrieve a specified registry as well as a list of all registries created by the user.
For a detailed example of the registry workflow. Please refer here.
Create Registry
POST /registries REQUEST
curl --location --request POST https://api.dock.io/registries/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"addOnly": true,
"policy": [
"did:dock:xyz"
],
"type": "CredentialStatusList2017"
}'
{
"addOnly": true,
"policy": [
"did:dock:xyz"
],
"type": "CredentialStatusList2017"
}
To create a registry, you have to create a policy
object for which a DID is needed. It is advised that the DID is registered on the chain first. Otherwise, someone can look at the registry and register the DID, thus gaining control of the registry.
Choosing the right revocation registry is essential. Here's a simplified overview of the available options: - CredentialStatusList2017 - Only supports non-BBS+ credentials. - Individual Tracking: Each entry is tracked separately, which means more ledger space is used for multiple entries. - This registry is cost-effective for a single entry. However, managing several entries can be more expensive. - Implements add-only policies. - StatusList2021Entry - Only supports non-BBS+ credentials. - Recommended for most users. - Collective Tracking: Manages all revocation entries together, making it less costly to revoke multiple credentials simultaneously. - W3C Compliant. - DockVBAccumulator2022 - Only supports BBS+ credentials. - Utilizes an on-ledger accumulator for enhanced privacy. - Offers more privacy than the W3C Status List 2021.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
addOnly | body | boolean | false | True/false options. The default value is "false". |
policy | body | [DIDDock] | true | The DIDs which control this registry. You must own a DID listed here to use the registry. Only one policy supported as of now: OneOf DID in list. |
type | body | string | false | Specifies which type of registry to create. Defaults to StatusList2021Entry . |
Enumerated Values
Parameter | Value | Description |
---|---|---|
type | StatusList2021Entry or CredentialStatusList2017 or DockVBAccumulator2022 | The type used in registry creation. |
200 Response
{
"id": "930",
"data": {
"id": "6151e62d7e03bc4012fde0595cfdb0d140e463a2f0ad5a431ff47243374bc612",
"policy": {
"type": "OneOf",
"policy": [
"did:dock:5GKeTJ7iMU4hEUwhK9a6ogh1bsWAv8Z1TMKnUf1vCNgdoiEM"
],
"addOnly": false
},
"type": "CredentialStatusList2017",
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will try to create the registry. | JobStartedResult |
400 | Bad Request | The request was unsuccessful, because of invalid params, e.g., policy not supported. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
List Registries
GET /registries REQUEST
curl --location --request GET https://api.dock.io/registries/ \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw'{
}'
Return a list of all registries created by the user. The list is returned with the registry id and policy of the revocation registry.
200 Response
[
{
"id": "6151e62d7e03bc4012fde0595cfdb0d140e463a2f0ad5a431ff47243374bc612",
"policy_and_type": {
"type": "OneOf",
"policy": [
"did:dock:5GKeTJ7iMU4hEUwhK9a6ogh1bsWAv8Z1TMKnUf1vCNgdoiEM"
],
"addOnly": false
},
"registry_type": "CredentialStatusList2017",
"created_at": "2021-11-25T12:20:51.773Z"
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return all registries created by the user. | Inline |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get Registry
GET /registries/{id} REQUEST
curl --location --request GET https://api.dock.io/registries/{id} \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Get the details of an existing registry, such as policy, add-only status, when it was last updated, and controller(s). You need only supply the revocation registry id that was returned upon revocation registry creation.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | Hex32 | true | Revocation registry id. |
200 Response
{
"id": "6151e62d7e03bc4012fde0595cfdb0d140e463a2f0ad5a431ff47243374bc612",
"policy_and_type": {
"type": "OneOf",
"policy": [
"did:dock:5GKeTJ7iMU4hEUwhK9a6ogh1bsWAv8Z1TMKnUf1vCNgdoiEM"
],
"addOnly": false
},
"registry_type": "CredentialStatusList2017",
"created_at": "2021-11-25T12:20:51.773Z",
"job_id": "930"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the revocation registry metadata. | Registry |
404 | Not Found | The request was unsuccessful, because the registry was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Revoke/Unrevoke Credential
POST /registries/{id} REQUEST
curl --location --request POST https://api.dock.io/registries/{id} \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"action": "revoke",
"credentialIds": [
"https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb"
]
}'
{
"action": "revoke",
"credentialIds": [
"https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb"
]
}
Credential revocation is managed with on-chain revocation registries. To revoke a credential, its id (or hash of its id) must be added to the credential. It is advised to have one revocation registry per credential type. Revoking an already revoked credential has no effect.
Similar to the replay protection mechanism for DIDs, the last modified block number is kept for each registry, which is updated each time a credential is revoked or unrevoked. Unrevoking an unrevoked credential has no effect.
In this API, simply add Revoke/Unrevoke into the action
parameter and input the desired credential ids.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | Hex32 | true | Revocation registry id. |
action | body | string | false | The action taken, either revoke or unrevoke. The default value is "revoke" |
credentialIds | body | array | true | The list of credential ids to act upon. |
Enumerated Values
Parameter | Value | Description |
---|---|---|
action | revoke or unrevoke | Action to take on the registry. |
200 Response
{
"id": "931",
"data": {
"revokeIds": [
"0xaff1aa6770d43d684690c0ad679a8608d5b7576feb3fdc1d6712decf73ca44ef"
]
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will try to revoke/unrevoke the credential. | JobStartedResult |
400 | Bad Request | The request was unsuccessful, because of invalid params. | Error |
404 | Not Found | The request was unsuccessful, because the registry was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Delete Registry
DELETE /registries/{id} REQUEST
curl --location --request POST https://api.dock.io/registries/{id} \
--header 'DOCK-API-TOKEN: API_KEY'
A registry can be deleted, leading to all the corresponding revocation ids being deleted as well. This requires the signature from the owner, similar to the other updates.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | Hex32 | true | Revocation registry id. |
200 Response
{
"id": "932",
"data": {
"id": "6151e62d7e03bc4012fde0595cfdb0d140e463a2f0ad5a431ff47243374bc612",
"hexId": "6151e62d7e03bc4012fde0595cfdb0d140e463a2f0ad5a431ff47243374bc612",
"lastModified": 4226296
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and revocation registry will be deleted. | JobStartedResult |
404 | Not Found | The request was unsuccessful, because the registry was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Revocation Status
Credentials can be revoked or unrevoked, and as such they contain a revocation status so that verifiers/issuers can check if the credential is still valid. Once a revocation registry has been created and credentials issued with it, you can check the revocation status. Verifiers will do this automatically.
Get Revocation Status
GET /revocationStatus/{regId}/{revId} REQUEST
curl --location --request GET https://api.dock.io/revocationStatus/{regId}/{revId} \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
To check if an id is revoked or not, you can check its status with the registry id (regId
) and revocation id (revId
).
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
regId | path | Hex32 | true | Revocation registry id. |
revId | path | Hex32 | true | Credential revocation id. |
200 Response
{
"type": true
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return true, if the credential is revoked, false otherwise. | Inline |
404 | Not Found | The request was unsuccessful, because the registry was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
400 | Server Error | The request was unsuccessful, because you have not revoked or unrevoked the registered credential yet. Please try to revoke/unrevoke the registered credential and try again. | Error |
Get Revocation Status Witness
GET /revocationStatus/{regId}/{revId}/witness REQUEST
curl --location --request GET https://api.dock.io/revocationStatus/{regId}/{revId} \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
The accumulator witness is utilized by the holder to generate a proof, which combines the witness with their revocation id associated with the credential id (revId
) and the accumulator associated with the registry id (regId
), allowing the verifier to validate the credential's status without directly accessing the revocation id on the blockchain.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
regId | path | Hex32 | true | Revocation registry id. |
revId | path | Hex32 | true | Credential revocation id. |
200 Response
{
"value": "0x81aa308882b663491e2b42803ad0855b030d92a586bc378bc844e1e003c8098a23f0d7d75b4fdbfb4b42cfc42aca8ad3"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the membership witness. | Inline |
404 | Not Found | The request was unsuccessful, because the registry was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
400 | Server Error | The request was unsuccessful, because you have not revoked or unrevoked the registered credential yet. Please try to revoke/unrevoke the registered credential and try again. | Error |
Credential Schemas
Endpoints
Schemas are useful when enforcing a specific structure on a collection of data like a Verifiable Credential. Data Verification schemas, for example, are used to verify that the structure and contents of a Verifiable Credential conform to a published schema. On the other hand, Data Encoding schemas are used to map the contents of a Verifiable Credential to an alternative representation format, such as a binary format used in a zero-knowledge proof.
Create Schema
POST /schemas REQUEST
curl --location --request POST https://api.dock.io/schemas \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '{
"$schema": "http://json-schema.org/draft-07/schema#",
"description": "Dock Schema Example",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"emailAddress": {
"type": "string",
"format": "email"
},
"alumniOf": {
"type": "string"
}
},
"required": [
"emailAddress",
"alumniOf"
],
"additionalProperties": false,
"author": "{{did}}"
}'
{
"$schema": "http://json-schema.org/draft-07/schema#",
"description": "Dock Schema Example",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"emailAddress": {
"type": "string",
"format": "email"
},
"alumniOf": {
"type": "string"
}
},
"required": [
"emailAddress",
"alumniOf"
],
"additionalProperties": false,
"author": "{{did}}"
}
Schemas are used to describe the structure of credentials, specifically the credential subject. It helps the issuer, holder, and verifier to unambiguously determine the claims contained within the credential. To create a schema, you need to define the object body using JSON schema.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | JSON-schema. |
200 Response
{
"id": "1082",
"data": {
"schema": {
"$schema": "http://json-schema.org/draft-07/schema#",
"description": "Dock Schema Example 3",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"emailAddress": {
"type": "string",
"format": "email"
},
"alumniOf": {
"type": "string"
}
},
"required": [
"emailAddress",
"alumniOf"
],
"additionalProperties": false
},
"author": "did:dock:5FBZNTZ4eg2EBuvEcYdkEtAhCXhCEA8zmPzYTwexM3g13fkF",
"signature": {
"Secp256k1": "..."
},
"id": "https://schema.dock.io/TestSchema-V1-1695817897561.json",
"uri": "https://schema.dock.io/TestSchema-V1-1695817897561.json"
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will try to create schema. | JobId |
400 | Bad Request | The request was unsuccessful, because of invalid params, e.g., size not supported or not JSON. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
List Schemas
GET /schemas REQUEST
curl --location --request GET https://api.dock.io/schemas \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Return a list of all schemas created by the authenticated user.
200 Response
[
{
"schema": {
"$schema": "http://json-schema.org/draft-07/schema#",
"description": "Dock Schema Example",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"emailAddress": {
"type": "string",
"format": "email"
},
"alumniOf": {
"type": "string"
}
},
"required": [
"emailAddress",
"alumniOf"
],
"additionalProperties": false
},
"author": "did:dock:5HcbppP8LjoJFYRV7PTLEyPy3ZUK9JCkzC4PQHuVF34gRhe6",
"id": "https://schema.dock.io/TestSchema-V1-1695817897561.json",
"uri": "https://schema.dock.io/TestSchema-V1-1695817897561.json"
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return all schemas created by the user. | Inline |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get Schema
GET /schemas/{schemaId} REQUEST
curl --location --request GET https://api.dock.io/schemas/{schemaId} \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Reading a Schema from the Dock chain can easily be achieved by using the get
method which will return the JSON schema to a specific schema ID. The schemaId
needs to be URL encoded (e.g. /schemas/https%3A%2F%2Fschema.dock.io%2FTestSchema-V1-1695817897561.json
)
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
schemaId | path | String | true | A URL encoded schema id. |
200 Response
{
"schema": {
"$schema": "http://json-schema.org/draft-07/schema#",
"description": "Dock Schema Example",
"type": "object",
"properties": {
"id": {
"type": "string"
},
"emailAddress": {
"type": "string",
"format": "email"
},
"alumniOf": {
"type": "string"
}
},
"required": [
"emailAddress",
"alumniOf"
],
"additionalProperties": false
},
"author": "did:dock:5HcbppP8LjoJFYRV7PTLEyPy3ZUK9JCkzC4PQHuVF34gRhe6",
"id": "https://schema.dock.io/TestSchema-V1-1695817897561.json",
"uri": "https://schema.dock.io/TestSchema-V1-1695817897561.json"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns the requested Schema. | Inline |
404 | Not Found | The request was unsuccessful, because the schema was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Anchors
Endpoints
Anchoring allows users to store a digest of one or more credentials (or any document) on our blockchain, tying them to immutable timestamps and proving that they were generated at a certain moment in time. By enabling this feature, users will have more options for auditing credentials given and timestamping any documents.
The Dock Blockchain includes a module explicitly intended for proof of existence. You post the hash of a document on-chain at a specific block. Later you can use that hash to prove the document existed at or before that block.
The API allows you to create, get, and retrieve anchors as well as a list of all anchors created by the user.
For a detailed example of the anchor workflow. Please refer here.
Create Anchor
POST /anchors REQUEST
curl --location --request POST https://api.dock.io/anchors \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '[
"can be a string",
{
"or": "a JSON document"
}
]'
[
"can be a string",
{
"or": "a JSON document"
}
]
Creating an anchor will state on the blockchain that one or more document hashes were created at a specific time. In the context of verifiable credentials, anchors are used to attest that the credential document was not altered and was created at a specific time. Batching multiple documents/credentials into a single anchor is done through a Merkle tree and can save on cost/time as only the Merkle root has to be anchored.
The API will store the blake2b256
hash of a document or string that you provide. Dock provides a fully functioning reference client and SDK example for anchoring.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | array of strings or JSON | true | Supply an array of strings or JSON documents to be hashed and anchored to the blockchain. For credentials, send the Verifiable Credential document(s) or anchor when issuing. |
200 Response
{
"id": "829",
"data": {
"root": "0xdfc3cd9ff7836143746c292d4099e62277fac4c2b6a1c004d784adcbc0319634",
"proofs": []
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will try to create an anchor on the blockchain. | JobId |
400 | Bad Request | The request was unsuccessful, because of invalid params. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
List Anchors
GET /anchors REQUEST
curl --location --request GET https://api.dock.io/anchors \
--header 'DOCK-API-TOKEN: API_KEY' \
--data-raw ''
Return a list of all anchors created by the authenticated user, regardless of whether they have contributed to the batching or not.
200 Response
[
{
"anchor":"54bdd55207c4d41d2b8a7780e967bb5a06bdfb793fc4055baf244e60cd0d839c",
"type": "single",
"data": {
"proofs": [],
"root":"0x54bdd55207c4d41d2b8a7780e967bb5a06bdfb793fc4055baf244e60cd0d839c",
"documentIds": [
"https://creds.dock.io/credential/b1ed680d3d2d8167dc31bc4913e9c511"
]
},
"created_at": "2021-11-12T13:53:51.640Z",
"job_id": "827"
}
]
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer | false | How many items to offset by for pagination |
limit | query | integer | false | How many items to return at one time (max 64) |
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return all anchors created by the user. | Inline |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Get Anchor
GET /anchors/{anchor} REQUEST
curl --location --request GET https://api.dock.io/anchors/{anchor} \
--header 'DOCK-API-TOKEN: API_KEY'
--data-raw ''
Get a specific anchor with the given ID.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
anchor | path | Hex32 | true | An anchor id. |
200 Response
{
"type": "single",
"proofs": [],
"root": "0x00",
"created_at": "2021-11-30T15:47:24.667Z"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns the anchor's details, e.g., blockHash and root . |
Anchor |
404 | Not Found | The request was unsuccessful, because the anchor was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Verify Anchor
POST /verify REQUEST
curl --location --request POST https://api.dock.io/anchors \
--header 'DOCK-API-TOKEN: API_KEY' \
--header 'Content-Type: application/json' \
--data-raw '[
"can be a string",
{
"or": "a JSON document"
}
]'
{
"documents": [],
"proofs": [],
"root": "0x00"
}
Verify an anchor's merkle root and proof by supplying the source documents (array of strings of JSON objects, same as in anchor creation).
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
documents | body | array of strings or JSON | true | An array of strings or JSON objects to represent documents to be hashed |
proofs | body | JSON object array | true | An array of proofs given on anchor creation |
root | body | Hex32 | true | The anchor merkle root/ID. |
200 Response
{
"verified": true,
"results": [
{}
]
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and returns the anchor's details, e.g., blockHash and root . |
Anchor |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Jobs
Endpoints
In Dock Certs, "jobs" are blockchain transactions that we submit on your behalf. You can choose to either register a webhook or poll the API to receive job information. Certain things in the API, such as revoking a credential, require a blockchain transaction to finalize before the job can be considered "done". The time to wait varies on network load and other factors, but typically is within 5-10 seconds.
You can track the current job status by querying the job id returned as part of the initial API response that triggered the job. The work is done asynchronously.
Get Job Status and Data
GET /jobs/{Id} REQUEST
curl --location --request GET https://api.dock.io/jobs/{id} \
--header 'DOCK-API-TOKEN: API_KEY'
To check the Job status and data, you can use the GET
method and simply put the Job id. It will return information related to the job being processed and its associated blockchain transaction. On completion or failure, the job data will be updated with a response from the blockchain.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | JobId | true | Represents a Job id. |
200 Response
{
"id": "123",
"result": {
"InBlock": "0x00"
},
"status": "finalized"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and return the job description. | JobDesc |
404 | Not Found | The request was unsuccessful, because the Job id was not found. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Verify
VCDM Verification
POST /verify REQUEST
curl --location --request POST https://api.dock.io/verify \
--header 'DOCK-API-TOKEN: API_KEY'
--header 'Content-Type: application/json' \
--data-raw '{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/credential/93a1cd57a46fd5e6e641f0288e2f8b44",
"type": [
"VerifiableCredential"
],
"credentialSubject": [
{
"id": "did:dock:5Gwh4PxDjLUXnfqExALYTju9UpZTHzBLNb7j8Ug8NhTKivUe"
}
],
"issuanceDate": "2021-11-18T19:28:49.840Z",
"proof": {
"type": "EcdsaSecp256k1Signature2019",
"created": "2021-11-18T19:28:51Z",
"verificationMethod": "did:dock:5FfmGmkY1BqEqRQhRLCLDLHPBFvhSbEBK3DJhEk9mbkpfAXT#keys-1",
"proofPurpose": "assertionMethod",
"proofValue": "zAN1rKvtics5d8AZ5rvm9n9DNjfXGtFegv48PorsWvQdeVKPkzSSyKJzdN3jjnfTNqFDg5FWpXeYhubsFKnX8zLNiBsb3D32k3"
},
"issuer": {
"id": "did:dock:5FfmGmkY1BqEqRQhRLCLDLHPBFvhSbEBK3DJhEk9mbkpfAXT",
"name": "my issuer"
}
}'
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://www.w3.org/2018/credentials/examples/v1"
],
"id": "https://creds.dock.io/credential/93a1cd57a46fd5e6e641f0288e2f8b44",
"type": [
"VerifiableCredential"
],
"credentialSubject": [
{
"id": "did:dock:5Gwh4PxDjLUXnfqExALYTju9UpZTHzBLNb7j8Ug8NhTKivUe"
}
],
"issuanceDate": "2021-11-18T19:28:49.840Z",
"proof": {
"type": "EcdsaSecp256k1Signature2019",
"created": "2021-11-18T19:28:51Z",
"verificationMethod": "did:dock:5FfmGmkY1BqEqRQhRLCLDLHPBFvhSbEBK3DJhEk9mbkpfAXT#keys-1",
"proofPurpose": "assertionMethod",
"proofValue": "zAN1rKvtics5d8AZ5rvm9n9DNjfXGtFegv48PorsWvQdeVKPkzSSyKJzdN3jjnfTNqFDg5FWpXeYhubsFKnX8zLNiBsb3D32k3"
},
"issuer": {
"id": "did:dock:5FfmGmkY1BqEqRQhRLCLDLHPBFvhSbEBK3DJhEk9mbkpfAXT",
"name": "my issuer"
}
}
A verifier upon receiving a verifiable presentation verifies the validity of each credential in the presentation. This includes checking the correctness of the data model of the credential, the authenticity by verifying the issuer's signature and revocation status if the credential is revocable. It then checks whether the presentation contains the signature from the holder on the presentation, including his given challenge.
You can verify issued/received credentials and presentations using this route. Verification will check that the JSON-LD document's cryptographic proof is correct and that it has not been revoked. It will return a verification status with a boolean verified result.
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | VerifiableCredential or VerifiablePresentation | true | Provide as the body a Verifiable Credential or Verifiable Presentation JSON-LD document. |
200 Response
{
"verified": true,
"results": [...]
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | The request was successful and will return the verification result. | VerificationResponse |
400 | Bad Request | The request was unsuccessful, because of invalid credential params. | Error |
402 | Payment required | Transaction limit reached or upgrade required to proceed | Error |
Sub-Accounts
Sub-accounts are a feature of the Dock Certs API that allows Dock enterprise customers to segregate their data within Dock's platform based on their own customers. Each sub-account can have its own keys, organization profiles, credential designs and verification templates conviently organized to help with tracking and auditing of the activity performed by each.
When using a sub-account the root account can set up separate API keys for each sub-account. By using the sub-account specific API key it will ensure all the transactions are attributed to that sub-account.
Create Sub-Account
POST /subaccounts REQUEST
curl -X POST https://api-testnet.dock.io/subaccounts \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"name": "string",
"image": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | Subaccount object |
» name | body | string | true | The sub account name |
» image | body | string | false | The sub account image |
Example responses
200 Response
{
"id": 0,
"name": "string",
"email": "string",
"image": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Subaccount has been created | Subaccount |
400 | Bad Request | Error creating subaccount | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
List Sub-Accounts
GET /subaccounts REQUEST
Code samples
curl -X GET https://api-testnet.dock.io/subaccounts \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
offset | query | integer(int32) | false | How many items to offset by for pagination |
limit | query | integer(int32) | false | How many items to return at one time (max 64) |
Example responses
200 Response
[
{
"id": 0,
"name": "string",
"email": "string",
"image": "string"
}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | A paged array of subaccounts | Subaccounts |
Get Sub-Account by ID
GET /subaccounts/{id} REQUEST
Code samples
curl -X GET https://api-testnet.dock.io/subaccounts/{id} \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
Example responses
200 Response
{
"id": 0,
"name": "string",
"email": "string",
"image": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Expected response to a valid request | Subaccount |
400 | Bad Request | Error getting subaccount | Error |
401 | Unauthorized | You do not own this subaccount | Error |
404 | Not Found | Subaccount was not found | Error |
PATCH /subaccounts/{id} REQUEST
Update the specified sub-account.
Code samples
curl -X PATCH https://api-testnet.dock.io/subaccounts/{id} \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"name": "string",
"image": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
body | body | object | true | Subaccount properties |
» name | body | string | true | The sub account name |
» image | body | string | false | The sub account image |
Example responses
200 Response
{
"id": 0,
"name": "string",
"email": "string",
"image": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Subaccount has been updated | Subaccount |
400 | Bad Request | Error creating subaccount | Error |
401 | Unauthorized | You do not own this subaccount | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
DELETE /subaccounts/{id} REQUEST
Deletes the specified sub-account.
Code samples
curl -X DELETE https://api-testnet.dock.io/subaccounts/{id} \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
Example responses
400 Response
{
"status": 0,
"type": "string",
"message": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Subaccount deleted | None |
400 | Bad Request | Error deleting subaccount | Error |
401 | Unauthorized | You do not own this subaccount | Error |
404 | Not Found | Subaccount was not found | Error |
Get Sub-Account Usage
GET /subaccounts/{id}/usage REQUEST
Get details about the activity that this sub-account has performed against the system.
Code samples
curl -X GET https://api-testnet.dock.io/subaccounts/{id}/usage \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
startTime | query | string(date-time) | false | Timestamp for the start of the range (ISO 8601) |
endTime | query | string(date-time) | false | Timestamp for the end of the range (ISO 8601) |
offset | query | integer(int32) | false | How many items to offset by for pagination |
limit | query | integer(int32) | false | How many items to return at one time (max 64) |
Example responses
200 Response
[
{}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | A paged array of subaccount transaction usage metadata | ArrayResponse |
401 | Unauthorized | You do not own this subaccount | Error |
Create Sub-Account API Key
POST /subaccounts/{id}/keys REQUEST
Creates an API key for a subaccount. In order for activity to be associated with the given sub-account an API key needs to be created for that sub-account and then that key must be used for all transactions related to that sub-account.
Code samples
curl -X POST https://api-testnet.dock.io/subaccounts/{id}/keys \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
body | body | object | false | Subaccount properties |
Example responses
200 Response
{
"code": 0
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Subaccount API key created | Response |
400 | Bad Request | Error creating subaccount API key | Error |
401 | Unauthorized | You do not own this subaccount | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
List Sub-Account API Keys
GET /subaccounts/{id}/keys REQUEST
Code samples
curl -X GET https://api-testnet.dock.io/subaccounts/{id}/keys \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
offset | query | integer(int32) | false | How many items to offset by for pagination |
limit | query | integer(int32) | false | How many items to return at one time (max 64) |
Example responses
200 Response
[
{}
]
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | A paged array of subaccount key metadata | ArrayResponse |
401 | Unauthorized | You do not own this subaccount | Error |
Delete a Sub-Account API Key
DELETE /subaccounts/{id}/keys/{keyId} REQUEST
Delete the specified API key for the given sub-account.
Code samples
curl -X DELETE https://api-testnet.dock.io/subaccounts/{id}/keys/{keyId} \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
id | path | string | true | An ID |
keyId | path | string | true | An API key ID |
Example responses
400 Response
{
"status": 0,
"type": "string",
"message": "string"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Subaccount API key deleted | None |
400 | Bad Request | Error deleting subaccount API key | Error |
401 | Unauthorized | You do not own this subaccount | Error |
404 | Not Found | Subaccount API key was not found | Error |
Messaging
Operations about DIDComm messaging. DIDComm messages are addressed by DID using Dock's relay service.
The current most common use case for the messaging service is to send credentials and presentation requests to the Dock Wallet, but other clients can use it too.
Encrypt Message
POST /messaging/encrypt REQUEST
In most cases you'll want to ensure the privacy of the message by encrypting it before sending.
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/messaging/encrypt \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"type": "https://didcomm.org/issue-credential/2.0/issue-credential",
"payload": {
"domain": "api.dock.io",
"credentials": [{ ...vcJSON }]
},
"senderDid": "did:dock:xyz",
"algorithm": "ECDH-1PU+A256KW",
"recipientDids": [
"did:dock:xyz"
]
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | The recipients, sender and message |
» type | body | string | false | none |
» payload | body | object | true | none |
» senderDid | body | string | true | none |
» algorithm | body | string | false | none |
» recipientDids | body | [oneOf] | true | none |
Enumerated Values
Parameter | Value |
---|---|
» algorithm | ECDH-1PU+A256KW |
» algorithm | ECDH-ES+A256KW |
Example responses
200 Response
{
"code": 0
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Message has been encrypted, returning an encrypted DIDComm Message | Response |
400 | Bad Request | Message failed to encrypt | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | DID was not found | Error |
Decrypt Message
POST /messaging/decrypt REQUEST
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/messaging/decrypt \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"jwe": {}
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | The JWM |
» jwe | body | object | true | none |
Example responses
200 Response
{
"code": 0
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Message has been decrypted, returning a DIDComm message | Response |
400 | Bad Request | Message failed to decrypt | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | DID was not found | Error |
Signing Messages
POST /messaging/sign REQUEST
Signing a message helps to prove to the recipient that the message is valid and unaltered. The message will be signed as a Base64 encoded JWT.
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/messaging/sign \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"payload": {},
"senderDid": "string",
"type": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | The message payload |
» payload | body | object | true | none |
» senderDid | body | string | true | none |
» type | body | string | false | none |
Example responses
200 Response
"eyJhRU...p6byJ9.eyJpZ...em8iXV19.RIHJunaOq0SnQqYjG...BXo4ozHjWAMfqR0czB0rR4emWF0MeWOCXXSJra4ttCFAQ"
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Message has been signed | Response |
400 | Bad Request | Message failed to sign | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | DID was not found | Error |
Verifying a Message
POST /messaging/verify REQUEST
Verify that the message is valid.
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/messaging/verify \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"jws": "string"
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | The message payload |
» jws | body | string | true | none |
Example responses
200 Response
{
"verified": true,
"payload": {
"id": "14a31880-e864-11ed-ab4c-3f9fbca4f00d",
"type": "https://example.com/protocols/lets_do_lunch/1.0/proposal",
"created_time": 1682975205,
"from": "did:example:alice",
"body": {
"some": "test-value"
},
"reply_to": [
[
"did:example:alice"
]
]
}
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Message is verified | Response |
400 | Bad Request | Message failed to verify | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | DID was not found | Error |
Send Message
POST /messaging/send REQUEST
Sends a DIDComm message using our relay service and DID service endpoints, it also returns a URL for QR code scanning. Supports encrypted, plaintext and signed DIDComm messages. You can generate an encrypted DIDComm message by calling the /messaging/encrypt
route.
The typ
attribute must be a DIDComm type (i.e. starts with "application/didcomm").
Code samples
# You can also use wget
curl -X POST https://api-testnet.dock.io/messaging/send \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'DOCK-API-TOKEN: API_KEY'
Body parameter
{
"to": "string",
"message": {
"typ": "string"
}
}
Parameters
Name | In | Type | Required | Description |
---|---|---|---|---|
body | body | object | true | The message payload |
» to | body | string | true | none |
» message | body | Message | true | none |
Example responses
200 Response
{
"sent": true,
"qrUrl": "didcomm://https://relay.dock.io/read/64502e3243455b67f93f95557"
}
Responses
Status | Meaning | Description | Schema |
---|---|---|---|
200 | OK | Message has been sent | Response |
400 | Bad Request | Message failed to send | Error |
402 | Payment Required | Transaction limit reached or upgrade required to proceed | Error |
404 | Not Found | DID was not found | Error |
Schemas
Object Schemas
Data Schemas are useful when enforcing a specific structure on a collection of data like a Verifiable Credential. Other than that, Data Verification schema and Data Encoding Schemas are used to verify and map the structure and contents of a Verifiable Credential.
These are the schemas used in all API operations mentioned before, such as Error, Credential, Jobs, Anchor, Registry, and so on.
For a detailed example of the schema workflow. Please refer here.
Error
{
"status": 0,
"type": "string",
"message": "string"
}
This is a schema for an API Error.
Properties
Name | Type | Required | Description |
---|---|---|---|
status | integer | false | Status of the error. |
type | string | false | Type of the error. |
message | string | false | Message of the error. |
Hex32
"string"
32 byte hex string. Ignoring higher base (base64) for simplicity.
Properties
Name | Type | Required | Description |
---|---|---|---|
Hex32 | string | false | 32 byte hex string. Ignoring higher base (base64) for simplicity. |
JobStartedResult
{
"id": "string",
"data": {
"did": "did:dock:xyz",
"hexDid": "0x00",
}
}
Object containing unique id of the background task and associated data. This id can be used to query the job status.
Properties
Name | Type | Description |
---|---|---|
id | JobId | Unique id of the background task. This id can be used to query the job status. |
data | object | Data of the object. |
JobId
"string"
Unique id of the background task. This id can be used to query the job status
JobStatus
"in_progress"
This is a schema used in Job operation to get a status of the job.
Enumerated Values
Property | Value | Description |
---|---|---|
JobStatus | todo or finalized or in_progress or error. | Job Status variants. |
JobDesc
{
"id": "string",
"result": {},
"status": "todo",
}
This is a schema used in Job operation to get description of the job including the result if it is available.
Properties
Name | Type | Description |
---|---|---|
id | JobId | Unique id of the background task. This id can be used to query the job status. |
status | JobStatus | Status of the job. |
result | object | false |
DIDDock
"did:dock:xyz"
DID as fully qualified, e.g., did:dock:
.
Properties
Name | Type | Required | Description |
---|---|---|---|
DID | string | false | DID as fully qualified, e.g., did:dock: . You cannot specify your own DID, the DID value will be randomly generated. |
KeyType
"sr25519"
This is a schema type of public key for DID.
Enumerated Values
Property | Value | Description |
---|---|---|
KeyType | sr25519 or ed25519 or secp256k1 | keyType DID variants. |
SigType
"Sr25519Signature2020"
This is a schema used in Presentation operation that represents a type of signature.
Enumerated Values
Property | Value | Description |
---|---|---|
SigType | Sr25519Signature2020 or Ed25519Signature2018 or EcdsaSecp256k1Signature2019 | SigType signature variants. |
ProofPurpose
"assertionMethod"
This is a schema that represents a purpose of credential.
Enumerated Values
Property | Value | Description |
---|---|---|
ProofPurpose | assertionMethod or authentication | Purpose of credential. |
Context
[
"string"
]
This is a schema that represents a JSON-LD context used in DID and Presentation.
DIDDoc
{
"@context": [
"string"
],
"id": "did:dock:xyz",
"authentication": [
{}
]
}
This is a schema that represents a DID document. The current set of properties is incomplete
Properties
Name | Type | Required | Description |
---|---|---|---|
@context | Context | false | JSON-LD context. |
id | DIDDock | false | DID as fully qualified, e.g., did:dock: . |
authentication | array | false | DID authentication. |
Credential
{
"context": [
"string"
],
"type": [
"string"
],
"subject": {},
"issuer": "did:dock:xyz",
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"status": "90b7dc6e8642bf1425c5a5ef2c3ff62bb689770843fdc0e2d79b97beb6c73311"
}
This is a schema that represents a credential format expected by API caller when issuing a credential.
Properties
Name | Type | Required | Description |
---|---|---|---|
id | string(uri) | false | Credential ID. The default value is a creds.dock.io uri with random ID. |
context | [string or object] | false | Credential context array of string URIs and/or embedded JSON-LD context objects. If no context parameter is supplied, we will auto generate contexts for you. If you do supply this parameter, you must ensure that all JSON-LD terms are defined. This is for advanced users. |
type | [string] | false | Credential type. The default value is ['VerifiableCredential'] |
subject | object or [object] | true | Credential subject or subjects array. |
schema | string | false | Schema ID returned by create schema route or a valid URI |
issuer | DIDDock | false | Credential issuer. DID as fully qualified, e.g., did:dock: . If not supplied the credential will not be signed. |
issuanceDate | string(date-time[RFC3339]) | false | The date and time in GMT that the credential was issued specified in RFC 3339 format. The issuanceDate will be automatically set if not provided. |
expirationDate | string(date-time[RFC3339]) | false | The date and time in GMT that the credential expired is specified in RFC 3339 format. The default value of the expirationDate will be empty if the user does not provide it. |
status | object or string | false | Revocation registry id or user supplied status object containg a Dock revocation registry identifier. |
VerifiablePresentation
{
"@context": [
"string"
],
"id": "http://example.com",
"type": [
"string"
],
"verifiableCredential": {
"@context": [
"string"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"string"
],
"credentialSubject": {},
"issuer": "did:dock:xyz",
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"credentialStatus": {},
"proof": {
"type": "Sr25519Signature2020",
"proofPurpose": "assertionMethod",
"verificationMethod": "string",
"created": "2019-08-24T14:15:22Z",
"proofValue": "string"
}
},
"proof": {
"type": "Sr25519Signature2020",
"proofPurpose": "assertionMethod",
"verificationMethod": "string",
"created": "2019-08-24T14:15:22Z",
"proofValue": "string"
}
}
This is a schema that represents a Verifiable (signed) Presentation returned by API. The current set of properties is almost complete
Properties
Name | Type | Required | Description |
---|---|---|---|
@context | Context | true | JSON-LD context. |
id | string(uri) | true | Verifiable (signed) presentation id. |
type | string | true | Verifiable (signed) presentation type. |
verifiableCredential | VerifiableCredential | true | Verifiable (signed) Credential returned by API. The current set of properties is almost complete. |
proof | object | true | Proof of credential. |
Child Properties of Proof
Name | Type | Required | Description |
---|---|---|---|
type | SigType | true | Type of signature. |
proofPurpose | ProofPurpose | true | Purpose of credential. |
verificationMethod | string | true | Verification method. |
created | string(date-time[RFC3339]) | true | The date and time in GMT that the credential was created specified in RFC 3339 format. |
proofValue | string | true | none |
VerifiableCredential
{
"@context": [
"string"
],
"id": "https://creds.dock.io/f087cbfabc90f8b996971ba47598e82b1a03523cb9460217ad58a819cd9c09eb",
"type": [
"string"
],
"credentialSubject": {},
"issuer": "did:dock:xyz",
"issuanceDate": "2019-08-24T14:15:22Z",
"expirationDate": "2019-08-24T14:15:22Z",
"credentialStatus": {},
"proof": {
"type": "Sr25519Signature2020",
"proofPurpose": "assertionMethod",
"verificationMethod": "string",
"created": "2019-08-24T14:15:22Z",
"proofValue": "string"
}
}
This is a schema that represents a verifiable (signed) Credential returned by API. The current set of properties is almost complete.
Properties
Name | Type | Required | Description |
---|---|---|---|
@context | Context | false | JSON-LD context. |
id | string(uri) | false | Credential id. |
type | [string] | false | Credential type. |
credentialSubject | any | false | Credential subject. |
issuer | DIDDock | false | Credential issuer or DID as fully qualified, e.g., did:dock: . |
issuanceDate | string(date-time[RFC3339]) | false | The date and time in GMT that the credential was issued specified in RFC 3339 format. The issuanceDate will be automatically set if not provided. |
expirationDate | string(date-time[RFC3339]) | false | The date and time in GMT that the credential expired is specified in RFC 3339 format. The default value of the expirationDate will be empty if the user does not provide it. |
credentialStatus | any | false | Revocation registry id or user supplied status object. |
proof | object | false | Proof of credential. |
Child Properties of Proof
Name | Type | Required | Description |
---|---|---|---|
type | SigType | false | Type of signature. |
proofPurpose | ProofPurpose | false | Purpose of credential. |
verificationMethod | string | false | Verification method. |
created | string(date-time[RFC3339]) | false | The date and time in GMT that the credential was created specified in RFC 3339 format. |
proofValue | string | false | Value of credential. |
Anchor
{
"type": "single/batch",
"proofs": [],
"blockHash": "string",
"root": "string",
"created_at": "YYYY-"
}
An anchor, either a batched or single is the information that constitutes the credentials' proof of existence. The schema includes anchor, type (single, batch), block hash, block number and accompanying data (root, proofs) if any. It depends if the anchor was created using API or not.
Registry
{
"addOnly": true,
"policy": [
"did:dock:xyz"
]
}
This is a schema that represents a Revocation registry used in Revocation or Unrevocation.
Properties
Name | Type | Required | Description |
---|---|---|---|
addOnly | boolean | false | If the addOnly value is true, they cannot unrevoke and delete the registry. The default value for this is false . |
policy | [DIDDock] | false | Only one policy supported as of now called OneOf . |
VerificationResponse
{
"verified": true,
"results": [...]
}
This is a schema that is used to define whether a credential/presentation is verified or not
Response
{
"code": 0
}
This is a schema that represents a default response for a request made.
Message
{
"to": ["did:example:bob"],
"ciphertext": "eyJhsad...AQ",
"typ":"application/didcomm..."
}
This is a schema that represents a message send request. If the message is signed or encrypted use the ciphertext
field. The typ
field must be a valid DIDComm message type.