API Specifications
Staging (Sandbox) OCA Issuance Endpoint:
POST <https://api.vc.staging.opencampus.xyz/issuer/vc>
Production OCA Issuance Endpoint
POST <https://api.vc.opencampus.xyz/issuer/vc>
Authorization
Header: { X-API-KEY: <your api key> }
Body (raw JSON)
{
"credentialPayload": { ... },
"holderOcId": "bob.edu"
}
credentialPayload
object
{
"validFrom": "2023-12-10T16:00:00.000Z",
"awardedDate": "2023-12-10T16:00:00.000Z",
"description": "An achievement for achieving outstanding results in mathematics course",
"credentialSubject": {
"name": "John Doe",
"type": "Person",
"email": "[[email protected]](mailto:[email protected])",
"image": "[https://img.freepik.com/premium-vector/gold-medal-with-gold-ribbon-that-says-gold_1134661-43944.jpg](https://img.freepik.com/premium-vector/gold-medal-with-gold-ribbon-that-says-gold_1134661-43944.jpg)",
"profileUrl": "[https://mycourse.xyz/profile/johndoe](https://mycourse.xyz/profile/johndoe)",
"achievement": {
"name": "Gold Medal Achievements",
"identifier": "tt:1111222333",
"description": "Reached 200 points in the intermediate mathematics",
"achievementType": "Achievement"
}
}
holderOcId
string
bob.edu
More on Credential Payload
Credential Payload is what you would use to represent the credential that you are issuing. We accept the following fields. Some of them are required and some of them are optional. Here we list the specifications for the credential payload based on the OpenBadge standard.
Please refer to Schema Definition Section for explanation of specific fields. This section is dedicated to technical specification for the properties.
credentialPayload
awardedDate
string
Y
Y
2023-09-08T16:00:00.000Z
ISO 8601 Date Format
description
string
Y
Y
my school certification
validFrom
string
Y
Y
2023-09-08T16:00:00.000Z
ISO 8601 Date Format
validUntil
string
N
Y
2023-09-08T16:00:00.000Z
ISO 8601 Date Format
image
string
N
Y
https://image.com/img/11111.jpg
Valid http uri
credentialSubject
object
Y
Y
{ … }
see below details
credentialSubject
achievement
object
Y
Y
{ … }
see below details
name
string
Y
N
Bob
stored but not exposed to public
profileUrl
string
N
Y
https://mycompany.xyz/profiles/public/11223344
this should be users public profile
image
string
N
Y
https://image.com/img/11111.jpg
Valid http uri
ext:OC_CUSTOM:custom
object
N
Y
{ … }
unspecified blob of custom data
achievement
identifier
string
Y
Y
a8505caa-8e3a-4c07-aae2-94944c6b52fc
stored on-chain maxLength 50 characters
achievementType
string
Y
Y
Certificate
see appendix for valid achievement types
name
string
Y
Y
Blockchain Certification
description
string
Y
Y
An introductory blockchain bootcamp class
attachments
array
N
Y
[ { pdf: “….” , png: “….“ }, { … } ]
no standard for internal objects
Last updated