API PDFThin
Envie PDFs, comprima por tamanho ou qualidade e baixe resultados via API REST.
Visao geral
Todos os uploads usam multipart/form-data. As respostas sao JSON.
- URL base: https://pdfthin.com (ou seu SITE_URL).
- Limite de taxa: RATE_LIMIT_RPM por IP (padrao 60/min).
- Upload maximo: MAX_UPLOAD_MB (padrao 200 MB).
- Os ficheiros são eliminados após 60 horas.
- Entradas suportadas: arquivo PDF; marca d'agua PNG/JPG ate 5MB.
- Variantes de upload: arquivo unico (optimize/split) ou varios arquivos (organize).
Configuracao do servidor
Variaveis de ambiente-chave que afetam o comportamento da API.
- REDIS_URL: fila de jobs e armazenamento de status.
- S3_ENDPOINT/S3_BUCKET/S3_ACCESS_KEY/S3_SECRET_KEY: armazenamento de objetos (opcional, senao local).
- Os ficheiros são eliminados após 60 horas.
- RATE_LIMIT_RPM e DOWNLOAD_TOKEN_TTL_MIN.
Criar job (optimize ou split)
POST /api/jobs com multipart/form-data.
- mode=split ignora quality e retorna partes se necessario.
- Quando quality esta definido, preset/custom_mb sao ignorados.
- Com quality_mode=smart, a API tenta de qualidade alta para baixa para caber no tamanho.
file
Arquivo PDF a processar.
mode
optimize (padrao) ou split.
preset
gmail25 | outlook20 | outlook25 | custom. Obrigatorio para objetivos de tamanho se quality nao estiver definido.
custom_mb
Obrigatorio quando preset=custom. Tamanho alvo em MB.
quality
screen | ebook | printer | prepress ou 1-100. Nao permitido para split.
quality_mode
Use "smart" para atingir o tamanho alvo testando niveis de qualidade; requer preset/custom_mb.
watermark
Imagem de marca d'agua ate 5MB.
cURL: preset de tamanho
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "preset=gmail25" -F "mode=optimize"
cURL: qualidade smart (tamanho alvo)
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "preset=custom" -F "custom_mb=12" -F "quality_mode=smart" -F "mode=optimize"
cURL: qualidade fixa
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "quality=printer" -F "mode=optimize"
Criar job (organize)
Use mode=organize para unir, girar, excluir, reordenar e dividir paginas.
- Se varios arquivos forem enviados, eles sao mesclados na ordem de upload.
- E necessario ao menos uma operacao ou varios arquivos.
file
Um ou mais arquivos PDF (multiplos permitidos).
mode
organize.
rotate_angle
90 | 180 | 270.
rotate_pages
Lista de paginas como 1,3-5.
delete_pages
Paginas para remover, ex. 2,4,7-9.
order_pages
Ordem explicita de paginas, ex. 3,1,2.
split_after
Dividir apos paginas, ex. 2,4,7.
watermark
Imagem de marca d'agua ate 5MB.
cURL: mesclar + girar
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "[email protected]" -F "mode=organize" -F "rotate_angle=90" -F "rotate_pages=1-2"
Consultar status
GET /api/jobs/{id} retorna o status do job e arquivos de resultado.
- Valores de status: queued | processing | done | failed.
Resposta de exemplo
{
"id": "job-id",
"status": "done",
"progress_pct": 100,
"expires_at": "2026-01-22T11:02:51Z",
"result": {
"kind": "single",
"files": [
{
"name": "output.pdf",
"size": 503937,
"download_url": "/api/jobs/job-id/download?index=0"
}
]
}
}
Baixar resultados
GET /api/jobs/{id}/download?index=0
- Use index=0..n para saidas em varias partes.
- Se chamado sem token, a API retorna um redirecionamento com token de curta duracao.
- TTL do token: DOWNLOAD_TOKEN_TTL_MIN minutos.
cURL: download
curl -L "https://pdfthin.com/api/jobs/job-id/download?index=0" -o output.pdf
Excluir job
DELETE /api/jobs/{id} remove arquivos e status.
- Retorna 204 No Content.
cURL: excluir
curl -X DELETE https://pdfthin.com/api/jobs/job-id
Codigos de erro
Os erros usam JSON: {"error":{"code":"...","message":"..."}}
- ERR_INVALID_FILE
- ERR_TOO_LARGE
- ERR_PASSWORD_PROTECTED
- ERR_CANNOT_FIT_SINGLE_PAGE
- ERR_TIMEOUT
- ERR_INTERNAL
- ERR_NOT_FOUND
- ERR_NOT_READY
- ERR_TOKEN_USED
- ERR_FORBIDDEN
OpenAPI (rascunho)
Trecho minimo de OpenAPI 3.0 para integracao rapida.
openapi.yaml
openapi: 3.0.3
info:
title: PDFThin API
version: "1.0"
paths:
/api/jobs:
post:
summary: Create a job
requestBody:
required: true
content:
multipart/form-data:
schema:
type: object
properties:
file:
type: string
format: binary
mode:
type: string
preset:
type: string
custom_mb:
type: integer
quality:
type: string
quality_mode:
type: string
watermark:
type: string
format: binary
responses:
"202":
description: Accepted
/api/jobs/{id}:
get:
summary: Get job status
parameters:
- in: path
name: id
required: true
schema:
type: string
responses:
"200":
description: OK
delete:
summary: Delete job
parameters:
- in: path
name: id
required: true
schema:
type: string
responses:
"204":
description: No Content
/api/jobs/{id}/download:
get:
summary: Download result
parameters:
- in: path
name: id
required: true
schema:
type: string
- in: query
name: index
schema:
type: integer
responses:
"303":
description: See Other