Skip to content

Awards API

Ustvarjanje in upravljanje podelitev značk (assertions) — značk, izdanih določenim prejemnikom.

Vsi endpointi zahtevajo avtentikacijo prek glave X-Api-Key. Glej Avtentikacija.

Ustvari podelitev

Izdajte značko prejemniku.

POST /awards

Parametri

ParameterTipObveznoOpis
badgeIdstringDaID značke za podelitev
recipientobjectDaPodrobnosti prejemnika (glej spodaj)
recipient.namestringDaPolno ime prejemnika (najmanj 5 znakov)
recipient.emailstringDaE-poštni naslov prejemnika
issuedOnstringDaDatum izdaje v obliki ISO 8601 (npr. 2025-01-15)
expiresstringNeDatum poteka v obliki ISO 8601
blockchainstringNeVeriga blokov za on-chain preverjanje. Podprta je le matchain. Na voljo v paketu Pro.

Primer

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"
    }
  }'

Odgovor

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

Opombe

  • Šteje se kot ena podelitev proti vaši mesečni kvoti (Free: 100/mes, Starter: 1.000/mes, Pro: 10.000/mes). Kvota se ponastavi vsako obračunsko obdobje.
  • Parameter blockchain je na voljo le v paketu Pro.

Naštej podelitve

Pridobite podelitve z izbirnim filtriranjem in razdelitvijo na strani.

GET /awards

Parametri poizvedbe

ParameterTipObveznoOpis
filterJSON stringNeObjekt filtra (glej spodaj)
lastEvaluatedKeystringNeŽeton razdelitve na strani iz prejšnjega odgovora

Objekt filtra

Parameter filter sprejema niz JSON s temi polji:

PoljeTipOpis
badgeIdstringFilter po ID značke.
searchstringPodniz za iskanje v imenih ali e-poštnih naslovih prejemnikov (glej searchField).
searchFieldstringBodisi name (privzeto) bodisi email — kateri stolpec iskati.

Razdelitev na strani prek lastEvaluatedKey deluje s filtri ali brez. Velikost strani je 50.

Primer — Naštej vse podelitve

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

Primer — Filtriraj po znački

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"

Odgovor

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..."
  }
}

Če je lastEvaluatedKey prisoten v odgovoru, obstaja več rezultatov. Posredujte ga kot parameter poizvedbe v naslednji zahtevi za pridobitev naslednje strani.


Pošlji e-pošto podelitve

Pošljite e-poštno obvestilo prejemniku o njegovi podelitvi.

POST /awards/{awardId}/send

Parametri

ParameterTipObveznoOpis
awardIdstringDaID podelitve (parameter poti in telesa)
emailstringDaE-poštni naslov prejemnika

Primer

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"
    }
  }'

Odgovor

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

Deli podelitev

Delite podelitev z več prejemniki prek e-pošte.

POST /awards/{awardId}/share

Parametri

ParameterTipObveznoOpis
awardIdstringDaID podelitve (parameter poti in telesa)
recipientsstringDaSeznam e-poštnih naslovov, ločenih z vejicami
subjectstringDaVrstica zadeve e-pošte
messagestringDaTelo sporočila e-pošte

Primer

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."
    }
  }'

Odgovor

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

Prenesi PDF spričevalo

Ustvarite spričevalo A4 PDF, pripravljeno za tisk, za podelitev.

GET /awards/{awardGuid}/pdf

Brez avtentikacije — ta endpoint je javen, da lahko prejemniki prenesejo svoje lastno spričevalo.

Primer

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

Odgovor je binarni PDF z glavo Content-Type: application/pdf.


Sledi dogodek podelitve

Zabeleži dogodek angažiranosti (ogled, deljenje, prenos, LinkedIn add). Uporablja ga javna stran podelitve za polnjenje statistike angažiranosti. Brez avtentikacije.

POST /awards/{awardGuid}/event

Parametri

ParameterTipObveznoOpis
kindstringDaEden izmed view, share, download, linkedin_add.
networkstringNeKo je kind=share, družbeno omrežje: linkedin, twitter, facebook, whatsapp, telegram, email, copy.

Potlačitev podvojenosti glede na IP: enak kind iz istega IP se šteje enkrat na 24 ur.

Primer

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"}}'

Pridobi statistiko podelitve

Pridobite kumulativne števce angažiranosti za podelitev.

GET /awards/{awardGuid}/stats

Brez avtentikacije.

Odgovor

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

badges.ninja Documentation