Português (PT)
Português (PT)
Appearance
Português (PT)
Português (PT)
Appearance
Crie e faça a gestão de atribuições de distintivos (assertions) — distintivos emitidos a destinatários específicos.
Todos os endpoints requerem autenticação através do cabeçalho X-Api-Key. Consulte Autenticação.
Emita um distintivo a um destinatário.
POST /awards| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
badgeId | string | Sim | ID do distintivo a atribuir |
recipient | object | Sim | Dados do destinatário (ver abaixo) |
recipient.name | string | Sim | Nome completo do destinatário (mínimo de 5 caracteres) |
recipient.email | string | Sim | Endereço de e-mail do destinatário |
issuedOn | string | Sim | Data de emissão no formato ISO 8601 (por exemplo, 2025-01-15) |
expires | string | Não | Data de expiração no formato ISO 8601 |
blockchain | string | Não | Blockchain para verificação em cadeia. Só matchain é suportado. Disponível no plano Pro. |
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"
}
}'{
"statusCode": 200,
"info": {
"awardId": "https://api.badges.ninja/certify-badge/award/c1d2e3f4-a5b6-7890-cdef-123456789012"
}
}blockchain está disponível apenas no plano Pro.Obtenha atribuições com filtragem e paginação opcionais.
GET /awards| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
filter | string JSON | Não | Objecto de filtro (ver abaixo) |
lastEvaluatedKey | string | Não | Token de paginação devolvido por uma resposta anterior |
O parâmetro filter aceita uma string JSON com os seguintes campos:
| Campo | Tipo | Descrição |
|---|---|---|
badgeId | string | Filtra por ID do distintivo. |
search | string | Sub-cadeia a procurar em nomes ou e-mails dos destinatários (ver searchField). |
searchField | string | name (predefinição) ou email — coluna onde procurar. |
A paginação via lastEvaluatedKey funciona com ou sem filtros. O tamanho da página é 50.
curl -X GET https://api.badges.ninja/awards \
-H "X-Api-Key: bws_your_api_key_here"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"{
"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..."
}
}Se lastEvaluatedKey estiver presente na resposta, existem mais resultados. Passe-o como parâmetro de consulta no próximo pedido para obter a página seguinte.
Envia uma notificação por e-mail ao destinatário sobre a sua atribuição.
POST /awards/{awardId}/send| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
awardId | string | Sim | ID da atribuição (parâmetro de caminho e corpo) |
email | string | Sim | Endereço de e-mail do destinatário |
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"
}
}'{
"statusCode": 200,
"info": {
"sent": true
}
}Partilhe uma atribuição com vários destinatários por e-mail.
POST /awards/{awardId}/share| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
awardId | string | Sim | ID da atribuição (parâmetro de caminho e corpo) |
recipients | string | Sim | Lista de endereços separados por vírgulas |
subject | string | Sim | Assunto do e-mail |
message | string | Sim | Corpo da mensagem |
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."
}
}'{
"statusCode": 200,
"info": {
"shared": true
}
}Gera um certificado A4 em PDF pronto a imprimir para uma atribuição.
GET /awards/{awardGuid}/pdfNão requer autenticação — este endpoint é público para que os destinatários possam transferir o seu próprio certificado.
curl -OJ https://api.badges.ninja/awards/c1d2e3f4-a5b6-7890-cdef-123456789012/pdfA resposta é o PDF binário com o cabeçalho Content-Type: application/pdf.
Regista um evento de envolvimento (visualização, partilha, transferência, adição ao LinkedIn). Utilizado pela página pública de atribuição para preencher as estatísticas de envolvimento. Não requer autenticação.
POST /awards/{awardGuid}/event| Parâmetro | Tipo | Obrigatório | Descrição |
|---|---|---|---|
kind | string | Sim | Um de view, share, download, linkedin_add. |
network | string | Não | Quando kind=share, a rede social: linkedin, twitter, facebook, whatsapp, telegram, email, copy. |
Supressão de duplicados por IP: o mesmo kind do mesmo IP é contabilizado uma vez a cada 24 horas.
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"}}'Obtém contadores cumulativos de envolvimento para uma atribuição.
GET /awards/{awardGuid}/statsNão requer autenticação.
{
"statusCode": 200,
"info": {
"stats": {
"views": 142,
"shares": { "linkedin": 8, "twitter": 2, "email": 1, "copy": 5 },
"downloads": 3,
"linkedin_adds": 4
}
}
}