Skip to content

Vergaben-API

Erstelle und verwalte Vergaben (Assertions) — Auszeichnungen, die an konkrete Empfänger:innen ausgestellt sind.

Alle Endpunkte erfordern Authentifizierung über den X-Api-Key-Header. Siehe Authentifizierung.

Vergabe erstellen

Stellt einer Empfängerin / einem Empfänger eine Auszeichnung aus.

POST /awards

Parameter

ParameterTypErforderlichBeschreibung
badgeIdstringJaDie zu vergebende Auszeichnungs-ID
recipientobjectJaEmpfängerdetails (siehe unten)
recipient.namestringJaVollständiger Name des Empfängers (mindestens 5 Zeichen)
recipient.emailstringJaE-Mail-Adresse des Empfängers
issuedOnstringJaAusstellungsdatum im ISO-8601-Format (z. B. 2025-01-15)
expiresstringNeinAblaufdatum im ISO-8601-Format
blockchainstringNeinBlockchain für On-Chain-Verifizierung. Nur matchain wird unterstützt. Im Pro-Plan verfügbar.

Beispiel

bash
curl -X POST https://api.badges.ninja/awards \
  -H "X-Api-Key: bws_your_api_key_here" \
  -H "Content-Type: application/json" \
  -d '{
    "parameters": {
      "badgeId": "b1c2d3e4-f5a6-7890-bcde-f12345678901",
      "recipient": {
        "name": "Jane Smith",
        "email": "jane@example.com"
      },
      "issuedOn": "2025-01-15"
    }
  }'

Antwort

json
{
  "statusCode": 200,
  "info": {
    "awardId": "https://api.badges.ninja/certify-badge/award/c1d2e3f4-a5b6-7890-cdef-123456789012"
  }
}

Hinweise

  • Zählt einmal gegen dein Monatskontingent (Free: 100/Monat, Starter: 1.000/Monat, Pro: 10.000/Monat). Das Kontingent wird zu jeder Abrechnungsperiode zurückgesetzt.
  • Der blockchain-Parameter ist nur im Pro-Plan verfügbar.

Vergaben auflisten

Ruft Vergaben mit optionaler Filterung und Paginierung ab.

GET /awards

Query-Parameter

ParameterTypErforderlichBeschreibung
filterJSON-StringNeinFilterobjekt (siehe unten)
lastEvaluatedKeystringNeinPaginierungs-Token aus einer vorherigen Antwort

Filterobjekt

Der filter-Parameter akzeptiert einen JSON-String mit diesen Feldern:

FeldTypBeschreibung
badgeIdstringFiltert nach Auszeichnungs-ID.
searchstringTeilstring zum Suchen in Empfängernamen oder -E-Mails (siehe searchField).
searchFieldstringEntweder name (Standard) oder email — welche Spalte durchsucht wird.

Paginierung über lastEvaluatedKey funktioniert mit oder ohne Filter. Seitengröße ist 50.

Beispiel — alle Vergaben auflisten

bash
curl -X GET https://api.badges.ninja/awards \
  -H "X-Api-Key: bws_your_api_key_here"

Beispiel — nach Auszeichnung filtern

bash
curl -X GET "https://api.badges.ninja/awards?filter=%7B%22badgeId%22%3A%22b1c2d3e4%22%7D" \
  -H "X-Api-Key: bws_your_api_key_here"

Antwort

json
{
  "statusCode": 200,
  "info": {
    "awards": [
      {
        "id": "https://api.badges.ninja/certify-badge/award/c1d2e3f4-...",
        "badge": {
          "id": "https://api.badges.ninja/certify-badge/badge/b1c2d3e4-...",
          "name": "JavaScript Fundamentals",
          "image": "https://ipfs.ninja/ipfs/Qm..."
        },
        "recipient": {
          "name": "Jane Smith",
          "email": "jane@example.com"
        },
        "issuedOn": "2025-01-15T00:00:00.000Z",
        "timestamp": "2025-01-15T10:30:00.000Z"
      }
    ],
    "lastEvaluatedKey": "eyJ..."
  }
}

Wenn lastEvaluatedKey in der Antwort vorhanden ist, gibt es weitere Ergebnisse. Übergib ihn als Query-Parameter in der nächsten Anfrage, um die nächste Seite zu erhalten.


Vergabe-E-Mail senden

Sendet einer empfangenden Person eine E-Mail-Benachrichtigung zu ihrer Vergabe.

POST /awards/{awardId}/send

Parameter

ParameterTypErforderlichBeschreibung
awardIdstringJaDie Vergabe-ID (Pfadparameter und Body)
emailstringJaE-Mail-Adresse des Empfängers

Beispiel

bash
curl -X POST https://api.badges.ninja/awards/c1d2e3f4-a5b6-7890-cdef-123456789012/send \
  -H "X-Api-Key: bws_your_api_key_here" \
  -H "Content-Type: application/json" \
  -d '{
    "parameters": {
      "awardId": "c1d2e3f4-a5b6-7890-cdef-123456789012",
      "email": "jane@example.com"
    }
  }'

Antwort

json
{
  "statusCode": 200,
  "info": {
    "sent": true
  }
}

Vergabe teilen

Teilt eine Vergabe per E-Mail mit mehreren Empfänger:innen.

POST /awards/{awardId}/share

Parameter

ParameterTypErforderlichBeschreibung
awardIdstringJaDie Vergabe-ID (Pfadparameter und Body)
recipientsstringJaKommagetrennte Liste von E-Mail-Adressen
subjectstringJaE-Mail-Betreff
messagestringJaNachrichtentext

Beispiel

bash
curl -X POST https://api.badges.ninja/awards/c1d2e3f4-a5b6-7890-cdef-123456789012/share \
  -H "X-Api-Key: bws_your_api_key_here" \
  -H "Content-Type: application/json" \
  -d '{
    "parameters": {
      "awardId": "c1d2e3f4-a5b6-7890-cdef-123456789012",
      "recipients": "manager@example.com,hr@example.com",
      "subject": "Check out my new badge!",
      "message": "I just earned the JavaScript Fundamentals badge."
    }
  }'

Antwort

json
{
  "statusCode": 200,
  "info": {
    "shared": true
  }
}

PDF-Zertifikat herunterladen

Erzeugt für eine Vergabe ein druckfertiges A4-PDF-Zertifikat.

GET /awards/{awardGuid}/pdf

Keine Authentifizierung erforderlich — dieser Endpunkt ist öffentlich, damit Empfänger:innen ihr eigenes Zertifikat herunterladen können.

Beispiel

bash
curl -OJ https://api.badges.ninja/awards/c1d2e3f4-a5b6-7890-cdef-123456789012/pdf

Die Antwort ist das binäre PDF mit einem Content-Type: application/pdf-Header.


Vergabe-Ereignis erfassen

Zeichnet ein Engagement-Ereignis auf (Aufruf, Teilen, Download, LinkedIn-Add). Wird von der öffentlichen Vergabeseite genutzt, um Engagement-Statistiken zu füllen. Keine Authentifizierung erforderlich.

POST /awards/{awardGuid}/event

Parameter

ParameterTypErforderlichBeschreibung
kindstringJaEiner von view, share, download, linkedin_add.
networkstringNeinWenn kind=share, das soziale Netzwerk: linkedin, twitter, facebook, whatsapp, telegram, email, copy.

Duplikat-Unterdrückung pro IP: derselbe kind von derselben IP wird einmal pro 24 Stunden gezählt.

Beispiel

bash
curl -X POST https://api.badges.ninja/awards/c1d2e3f4-a5b6-7890-cdef-123456789012/event \
  -H "Content-Type: application/json" \
  -d '{"parameters": {"kind": "share", "network": "linkedin"}}'

Vergabe-Statistik abrufen

Ruft die kumulierten Engagement-Zähler einer Vergabe ab.

GET /awards/{awardGuid}/stats

Keine Authentifizierung erforderlich.

Antwort

json
{
  "statusCode": 200,
  "info": {
    "stats": {
      "views": 142,
      "shares": { "linkedin": 8, "twitter": 2, "email": 1, "copy": 5 },
      "downloads": 3,
      "linkedin_adds": 4
    }
  }
}

badges.ninja Documentation