Skip to content

颁发 API

创建并管理徽章颁发(assertion)— 即发给具体接收者的徽章。

所有端点都需要通过 X-Api-Key 头进行认证。参阅 认证

创建颁发

向接收者发放一枚徽章。

POST /awards

参数

参数类型必填说明
badgeIdstring要颁发的徽章 ID
recipientobject接收者详情(见下)
recipient.namestring接收者全名(至少 5 个字符)
recipient.emailstring接收者邮箱地址
issuedOnstring颁发日期,ISO 8601 格式(例如 2025-01-15)
expiresstring到期日期,ISO 8601 格式
blockchainstring用于链上验证的区块链。仅支持 matchain。Pro 套餐可用。

示例

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

响应

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

说明

  • 从你的月度配额中扣 1 次(Free:100/月,Starter:1,000/月,Pro:10,000/月)。配额在每个计费周期重置。
  • blockchain 参数仅 Pro 套餐可用。

列出颁发

可选地按筛选与分页获取颁发。

GET /awards

Query 参数

参数类型必填说明
filterJSON string过滤对象(见下)
lastEvaluatedKeystring上一次响应中的分页 token

过滤对象

filter 参数接收包含以下字段的 JSON 字符串:

字段类型说明
badgeIdstring按徽章 ID 过滤。
searchstring在接收者姓名或邮箱中查找的子串(参见 searchField)。
searchFieldstringname(默认)或 email — 搜索哪一列。

通过 lastEvaluatedKey 的分页在有或没有过滤器时均可用。每页大小为 50。

示例 — 列出所有颁发

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

示例 — 按徽章筛选

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"

响应

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

如果响应中存在 lastEvaluatedKey,说明还有更多结果。将其作为下一次请求的 query 参数即可获取下一页。


发送颁发邮件

向接收者发送关于其颁发的邮件通知。

POST /awards/{awardId}/send

参数

参数类型必填说明
awardIdstring颁发 ID(路径参数与请求体)
emailstring接收者邮箱地址

示例

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

响应

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

分享颁发

通过邮件与多位接收者分享某条颁发。

POST /awards/{awardId}/share

参数

参数类型必填说明
awardIdstring颁发 ID(路径参数与请求体)
recipientsstring以逗号分隔的邮箱列表
subjectstring邮件主题
messagestring邮件正文

示例

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

响应

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

下载 PDF 证书

为颁发生成可打印的 A4 PDF 证书。

GET /awards/{awardGuid}/pdf

无需认证 — 该端点公开,以便接收者可下载自己的证书。

示例

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

响应是带有 Content-Type: application/pdf 头的二进制 PDF。


记录颁发事件

记录一次互动事件(浏览、分享、下载、LinkedIn 添加)。公开颁发页用它来填充互动统计。无需认证。

POST /awards/{awardGuid}/event

参数

参数类型必填说明
kindstringviewsharedownloadlinkedin_add 之一。
networkstringkind=share 时,社交网络:linkedintwitterfacebookwhatsapptelegramemailcopy

按 IP 去重:相同 kind 自同一 IP 每 24 小时仅计 1 次。

示例

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

获取颁发统计

获取某条颁发的累计互动计数。

GET /awards/{awardGuid}/stats

无需认证。

响应

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

badges.ninja Documentation