Complete guide for integrating with the SA Verifiable Credential Platform
https://issuer.wyzetree.tech with NO trailing slash and NO path. Your code should append the path.
# Set ONLY the base domain (no path, no trailing slash)
SARB_API_URL=https://issuer.wyzetree.tech
# Then in your code, append the path:
url = SARB_API_URL + "/api/offers/"
# Result: https://issuer.wyzetree.tech/api/offers/ ✓
# DO NOT include the path in base URL!
SARB_API_URL=https://issuer.wyzetree.tech/api/offers/
# This causes double paths:
url = SARB_API_URL + "/api/offers/"
# Result: https://issuer.wyzetree.tech/api/offers//api/offers/ ✗
# If you prefer full URLs without code concatenation:
SARB_OFFERS_ENDPOINT=https://issuer.wyzetree.tech/api/offers/
SARB_TEMPLATES_ENDPOINT=https://issuer.wyzetree.tech/api/templates/
SARB_ISSUERS_ENDPOINT=https://issuer.wyzetree.tech/api/issuers/
# Use directly (no concatenation):
url = SARB_OFFERS_ENDPOINT # Already complete
| Method | Endpoint | Purpose |
|---|---|---|
POST |
/api/offers/ |
Create credential offer (primary endpoint) |
GET |
/api/templates/ |
List available credential templates |
GET |
/api/issuers/ |
List available issuers |
GET |
/api/offers/{offer_id} |
Get specific offer details |
# Required IDs
Template ID: 4
Issuer ID: 4
# Required credential_data fields
{
"full_names": "First Name", # User's first name
"surname": "Last Name", # User's surname
"bank_acc_type": "Savings", # Account type
"bank_account_number": "123456", # Account number
"credit_risk": "low" # Risk profile (low/medium/high)
}
# 1. Test basic connectivity
curl https://issuer.wyzetree.tech/
# 2. List templates (requires API key)
curl https://issuer.wyzetree.tech/api/templates/ \
-H "Authorization: Bearer YOUR_API_KEY"
# 3. List issuers (requires API key)
curl https://issuer.wyzetree.tech/api/issuers/ \
-H "Authorization: Bearer YOUR_API_KEY"
# 4. Create test banking credential offer
curl -X POST https://issuer.wyzetree.tech/api/offers/ \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"template_id": 4,
"issuer_id": 4,
"credential_data": {
"full_names": "Test User",
"surname": "Example",
"bank_acc_type": "Savings",
"bank_account_number": "123456789",
"credit_risk": "low"
},
"expires_in_days": 30
}'
| Field | Type | Description |
|---|---|---|
qr_code_data |
Base64 PNG | Ready-to-use QR code image. No generation needed - just display it! |
offer_uri |
String | OpenID4VCI credential offer URI (embedded in QR code) |
pre_authorized_code |
String | Authorization code for wallet to retrieve credential |
status |
String | Offer status: pending, claimed, or expired |
template_id and issuer_id to use. Use the GET endpoints below to discover available options.
Get all credential templates with their IDs, names, and associated issuer IDs:
curl https://issuer.wyzetree.tech/api/templates/ \
-H "Authorization: Bearer YOUR_API_KEY"
Example Response:
[
{
"id": 8, // ← Use this as template_id
"name": "sarb_dfid",
"display_name": "SARB DFID",
"issuer_id": 2, // ← Use this as issuer_id
"credential_type": "W3C_VC",
"credential_format": "jwt_vc_json",
"requires_photo": "true"
},
{
"id": 9,
"name": "capitec_proof_of_account",
"display_name": "Capitec Proof of account",
"issuer_id": 5,
"credential_type": "W3C_VC",
"credential_format": "jwt_vc_json",
"requires_photo": "false"
}
]
Get all credential issuers with their IDs and names:
curl https://issuer.wyzetree.tech/api/issuers/ \
-H "Authorization: Bearer YOUR_API_KEY"
Example Response:
[
{
"id": 2,
"name": "sarb_dfid_issuer",
"display_name": "SARB DFID Issuer",
"status": "active"
},
{
"id": 5,
"name": "capitec",
"display_name": "Capitec Credential Issuer",
"status": "active"
}
]
template_id and issuer_id in your request must match. Each template belongs to a specific issuer. Use the issuer_id field from the template response.
{"template_id": 8, "issuer_id": 2}{"template_id": 8, "issuer_id": 5}
Current production templates (verify via API as IDs may change):
curl -X POST https://issuer.wyzetree.tech/api/offers/ \
-H "Authorization: Bearer YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"template_id": 4,
"issuer_id": 4,
"credential_data": {
"full_names": "John",
"surname": "Doe",
"bank_acc_type": "Savings",
"bank_account_number": "1234567890",
"credit_risk": "low"
},
"expires_in_days": 30
}'
<!-- In your HTML -->
<img src="_QR_CODE_DATA"
alt="Scan to claim credential"
style="width: 300px; height: 300px;" />
For complete API documentation including all endpoints, request/response schemas, and authentication details:
View Interactive API Documentation →