Tudo Envio

Documentação da API

API REST v1 • https://tudoenvio.com.br/api/public/v1

1. Começando

A API Tudo Envio permite que você integre cotação de frete, emissão de etiquetas dos Correios, rastreamento de objetos e gestão de clientes diretamente no seu sistema. Todas as respostas são em JSON e o servidor utiliza HTTPS obrigatório.

1.1. Autenticação

Todas as chamadas exigem o cabeçalho Authorization com seu token:

http
Authorization: Bearer seu_token_aqui

1.2. Passo a passo para começar

  1. 1
    Solicite acesso à API
    Acesse Integrações → API no painel e clique em Solicitar acesso. Informe nome da empresa e documento (CNPJ ou CPF).
  2. 2
    Aguarde aprovação do administrador
    Você receberá um e-mail assim que sua solicitação for aprovada (em geral em até 1 dia útil).
  3. 3
    Gere seu token de acesso
    Após aprovado, volte a Integrações → API e clique em Gerar novo token. Copie e guarde em local seguro — o token completo só é mostrado uma vez.
  4. 4
    Teste sua primeira chamada
    Use o exemplo abaixo para validar o token consultando /me:
  5. 5
    Integre nos seus fluxos
    Use os endpoints da seção 2 para cotar frete, emitir etiquetas e rastrear pedidos.
curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/me" \
  -H "Authorization: Bearer seu_token_aqui"

1.3. Rate limit

O limite padrão é de 60 requisições por minuto por token. Ao atingir o limite, o servidor responde

429 RATE_LIMITED
e os cabeçalhosX-RateLimit-Remaining eX-RateLimit-Reset indicam quando reativar.

2. Endpoints

2.1. Dados do usuário

GET/me

Retorna informações do usuário autenticado pelo token.

Exemplo com cURL

curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/me" \
  -H "Authorization: Bearer seu_token_aqui"

Resposta

json
{
  "user": {
    "id": "uuid-do-usuario",
    "name": "João da Silva",
    "email": "joao@empresa.com.br"
  }
}

2.2. Consultar saldo

GET/saldo

Retorna o saldo disponível em reais (BRL) para emissão de etiquetas.

Exemplo com cURL

curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/saldo" \
  -H "Authorization: Bearer seu_token_aqui"

Resposta

json
{
  "saldo": 152.40,
  "currency": "BRL"
}

2.3. Cotar frete

POST/frete/cotacao

Calcula o valor e prazo para todos os serviços Correios disponíveis (PAC, SEDEX, etc).

Parâmetros

NomeTipoObrigatórioDescrição
cep_origemstringSimCEP de origem (8 dígitos).
cep_destinostringSimCEP de destino (8 dígitos).
pesonumberSimPeso em kg (máx. 30).
comprimentonumberNãoComprimento em cm.
larguranumberNãoLargura em cm.
alturanumberNãoAltura em cm.
valor_declaradonumberNãoValor declarado em reais.

Exemplo de requisição

json
{
  "cep_origem": "01310100",
  "cep_destino: "20040020",
  "peso": 1.5,
  "comprimento": 20,
  "largura": 15,
  "altura": 10
}

Exemplo com cURL

curl
curl -X POST "https://tudoenvio.com.br/api/public/v1/frete/cotacao" \
  -H "Authorization: Bearer seu_token_aqui" \
  -H "Content-Type: application/json" \
  -d '{ "cep_origem": "01310100", "cep_destino: "20040020", "peso": 1.5, "comprimento": 20, "largura": 15, "altura": 10 }'

Resposta

json
{
  "cotacoes": [
    { "servico": "PAC", "codigo_servico": "03298", "valor": 18.50, "prazo": 7, "erro": null },
    { "servico": "SEDEX", "codigo_servico": "03220", "valor": 32.90, "prazo": 2, "erro": null }
  ]
}

2.4. Emitir etiqueta

POST/etiquetas

Cria uma nova etiqueta de postagem. O valor é debitado do saldo do usuário.

Parâmetros

NomeTipoObrigatórioDescrição
servicostringSimCódigo do serviço (ex: 03220 para SEDEX).
remetenteobjectSimDados do remetente (nome, documento, endereço completo).
destinatarioobjectSimDados do destinatário (nome, documento, endereço completo).
pesonumberSimPeso em kg.
dimensoesobjectSimObjeto com altura, largura e comprimento em cm.
valor_declaradonumberNãoValor declarado em reais.

Exemplo de requisição

json
{
  "servico": "03220",
  "remetente": {
    "nome": "Loja XYZ",
    "documento": "12345678000190",
    "cep": "01310100",
    "logradouro": "Av. Paulista",
    "numero": "1000",
    "bairro": "Bela Vista",
    "cidade": "São Paulo",
    "uf": "SP"
  },
  "destinatario": {
    "nome": "Maria Souza",
    "documento": "12345678900",
    "cep": "20040020",
    "logradouro": "Rua da Quitanda",
    "numero": "50",
    "bairro": "Centro",
    "cidade": "Rio de Janeiro",
    "uf": "RJ"
  },
  "peso": 1.5,
  "dimensoes": { "altura": 10, "largura": 15, "comprimento": 20 }
}

Exemplo com cURL

curl
curl -X POST "https://tudoenvio.com.br/api/public/v1/etiquetas" \
  -H "Authorization: Bearer seu_token_aqui" \
  -H "Content-Type: application/json" \
  -d '{ "servico": "03220", "remetente": { "nome": "Loja XYZ", "documento": "12345678000190", "cep": "01310100", "logradouro": "Av. Paulista", "numero": "1000", "bairro": "Bela Vista", "cidade": "São Paulo", "uf": "SP" }, "destinatario": { "nome": "Maria Souza", "documento": "12345678900", "cep": "20040020", "logradouro": "Rua da Quitanda", "numero": "50", "bairro": "Centro", "cidade": "Rio de Janeiro", "uf": "RJ" }, "peso": 1.5, "dimensoes": { "altura": 10, "largura": 15, "comprimento": 20 } }'

Resposta

json
{
  "etiqueta": {
    "id": "uuid-da-etiqueta",
    "codigo_rastreamento": "BR123456789BR",
    "servico": "SEDEX",
    "status": "emitida",
    "valor": 32.90,
    "url_pdf": "https://..."
  }
}

2.5. Consultar etiqueta

GET/etiquetas/{id}

Retorna os dados de uma etiqueta já emitida.

Exemplo com cURL

curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/etiquetas/{id}" \
  -H "Authorization: Bearer seu_token_aqui"

Resposta

json
{
  "etiqueta": {
    "id": "uuid-da-etiqueta",
    "codigo_rastreamento": "BR123456789BR",
    "servico": "SEDEX",
    "status": "emitida",
    "valor": 32.90,
    "created_at": "2026-06-11T02:00:00Z"
  }
}

2.6. Rastrear objeto

GET/rastreamento/{codigo}

Consulta os eventos de rastreio de um código dos Correios.

Exemplo com cURL

curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/rastreamento/{codigo}" \
  -H "Authorization: Bearer seu_token_aqui"

Resposta

json
{
  "codigo": "BR123456789BR",
  "eventos": [
    { "data": "2026-06-11T08:30:00Z", "local": "São Paulo / SP", "descricao": "Objeto postado" },
    { "data": "2026-06-12T14:00:00Z", "local": "Rio de Janeiro / RJ", "descricao": "Objeto entregue" }
  ]
}

2.7. Listar clientes

GET/clientes

Retorna a lista de clientes cadastrados pelo usuário.

Exemplo com cURL

curl
curl -X GET "https://tudoenvio.com.br/api/public/v1/clientes" \
  -H "Authorization: Bearer seu_token_aqui"

Resposta

json
{
  "clientes": [
    { "id": "uuid", "nome": "Maria Souza", "documento": "12345678900", "email": "maria@email.com" }
  ]
}

2.8. Criar cliente

POST/clientes

Cadastra um novo cliente no catálogo.

Exemplo de requisição

json
{
  "nome": "Maria Souza",
  "documento": "12345678900",
  "email": "maria@email.com",
  "telefone": "11999999999",
  "cep": "20040020",
  "logradouro": "Rua da Quitanda",
  "numero": "50",
  "bairro": "Centro",
  "cidade": "Rio de Janeiro",
  "uf": "RJ"
}

Exemplo com cURL

curl
curl -X POST "https://tudoenvio.com.br/api/public/v1/clientes" \
  -H "Authorization: Bearer seu_token_aqui" \
  -H "Content-Type: application/json" \
  -d '{ "nome": "Maria Souza", "documento": "12345678900", "email": "maria@email.com", "telefone": "11999999999", "cep": "20040020", "logradouro": "Rua da Quitanda", "numero": "50", "bairro": "Centro", "cidade": "Rio de Janeiro", "uf": "RJ" }'

Resposta

json
{ "cliente": { "id": "uuid", "nome": "Maria Souza" } }

3. Códigos de erro

Toda resposta de erro segue o formato padrão abaixo:

json
{
  "error": {
    "code": "VALIDATION_ERROR",
    "message": "Descrição amigável do problema."
  }
}
CódigoHTTPDescrição
UNAUTHORIZED401Token ausente, inválido ou revogado.
FORBIDDEN403Acesso não autorizado a este recurso.
VALIDATION_ERROR400Dados de entrada inválidos.
CLIENT_NOT_FOUND404Recurso não encontrado.
INSUFFICIENT_BALANCE402Saldo insuficiente para emitir a etiqueta.
RATE_LIMITED429Limite de chamadas excedido.
INTERNAL_ERROR500Erro interno do servidor.

4. Suporte

Dúvidas ou problemas? Entre em contato em contato@tudoenvio.com.br ou pela página Ajuda.

Tudo Envio • Documentação da API v1 • Gerado em 28/06/2026