Mensagens
Enviar Contato
Envia um ou múltiplos contatos como vCard
POST
Enviar Contato
Auth:
Envelope de erro:
TokenAccount ou TokenInstance • Rate-limit: Global (100/min) • Idempotente: não
Descrição
Envia um ou mais contatos como vCard. O destinatário recebe um card clicável que pode adicionar o contato direto à agenda. O campovcard aceita um array de objetos VCard (envio múltiplo) ou um único objeto (compatibilidade retroativa, o servidor aceita ambos os formatos). Suporta replyTo, replyPrivate, delay (em segundos) e source. Não suporta menções.
Exemplos
Contato único
Envia um vCard com o mínimo necessário (fullName e phone). O destinatário recebe um único card clicável com o contato “João Silva” pronto para ser adicionado à agenda.
Múltiplos contatos
Passa três contatos no arrayvcard. O servidor envia tudo como um ContactsArrayMessage único, o destinatário visualiza um card agrupado e escolhe quais nomes deseja adicionar à agenda.
Contato com organização, e-mail e site
Inclui os campos opcionaisorganization, email e url no vCard. O card resultante exibe a empresa, o e-mail de contato e o site abaixo do nome, ideal para apresentar contatos comerciais completos.
Resposta de sucesso
O arrayvcard da resposta ecoa exatamente o que você enviou (com todos os contatos). Quando há mais de um contato, a message vira "X contacts sent successfully in one message".
200 OK
Quando o
vcard contém apenas um item, o servidor envia como ContactMessage. Para múltiplos itens, é enviado como ContactsArrayMessage (uma única mensagem agrupando vários cards).Parâmetros de rota
Nome da instância (ex.:
$Instance_Name).Headers
TokenAccount ou TokenInstance.application/jsonRequest body
Destino: telefone (
5511999999999) ou JID (@s.whatsapp.net, @lid, @g.us, @newsletter).Array de contatos a enviar. Cada item segue a estrutura abaixo. O handler também aceita um único objeto
VCard (sem array) por compatibilidade retroativa, convertendo internamente para um array de um item. Pelo menos um contato é obrigatório.Nome completo do contato. Aparece como rótulo principal do card.
Número de telefone do contato (com código do país, ex.:
5511888888888).Organização/empresa do contato (opcional).
E-mail do contato (opcional).
URL/website do contato (opcional).
Tempo em segundos para aguardar antes de enviar. Durante o intervalo, o servidor envia o indicador de “digitando…” ao destinatário e dispara o “paused” antes do envio real.
ID da mensagem a ser citada (reply). A mensagem original precisa pertencer à mesma instância e ter sido salva no banco.
Quando
true e replyTo aponta para uma mensagem originária de um grupo, a resposta é redirecionada para o privado do autor original (mantendo a citação). Ignorado se a mensagem original não for de grupo. Advisory: este campo está definido na struct mas o handler de contatos faz parsing manual do JSON e não está extraindo o replyPrivate do payload, então atualmente é tratado como false.Identificador de origem para rastreabilidade (ex.:
crm, bot-suporte, n8n). Salvo no registro da mensagem no banco e propagado para webhooks. Quando omitido, assume "api".Notas
delayé em segundos, não milissegundos.- O campo
vcardaceita tanto array quanto objeto único. Recomendado usar sempre array ([ {...} ]) para evitar ambiguidade. - Cada contato exige
fullNameephonepreenchidos.organization,emaileurlsão opcionais. - Para envios múltiplos, o WhatsApp agrupa os contatos em um único card no chat, o destinatário pode escolher quais adicionar.
- Mensagens de contato não suportam
mentionnemmentionAll. - Para números BR (começando com
55), o serviço tenta automaticamente variações com e sem o 9º dígito. - Cada contato no array passa por validação individual; se o item
Nfalha, a resposta é400 Contact full name is required for contact Nou400 Contact phone number is required for contact N.
Erros
| HTTP | Status interno | Mensagem |
|---|---|---|
| 400 | , | Instance name is required |
| 400 | , | Invalid JSON format: <detalhe> |
| 400 | , | Failed to read request body: <detalhe> |
| 400 | , | Number is required |
| 400 | , | At least one contact (vcard) is required |
| 400 | , | Contact full name is required for contact N |
| 400 | , | Contact phone number is required for contact N |
| 400 | invalid_number | Invalid phone number format: <detalhe> |
| 500 | send_failed | Failed to send message: <reason> |
| 404 | , | Instance not found |
| 503 | disconnected | Instance is not connected to WhatsApp |