API PDFThin
Carica PDF, comprimi per dimensione o qualita e scarica i risultati tramite API REST.
Panoramica
Tutti gli upload usano multipart/form-data. Le risposte sono JSON.
- URL base: https://pdfthin.com (o il tuo SITE_URL).
- Limite di velocita: RATE_LIMIT_RPM per IP (predefinito 60/min).
- Upload massimo: MAX_UPLOAD_MB (predefinito 200 MB).
- I file vengono eliminati dopo 60 ore.
- Input supportati: file PDF; filigrana PNG/JPG fino a 5MB.
- Varianti di upload: file singolo (optimize/split) o piu file (organize).
Configurazione del server
Variabili d'ambiente chiave che influenzano il comportamento dell'API.
- REDIS_URL: coda job e archivio stato.
- S3_ENDPOINT/S3_BUCKET/S3_ACCESS_KEY/S3_SECRET_KEY: storage oggetti (opzionale, altrimenti locale).
- I file vengono eliminati dopo 60 ore.
- RATE_LIMIT_RPM e DOWNLOAD_TOKEN_TTL_MIN.
Crea job (optimize o split)
POST /api/jobs con multipart/form-data.
- mode=split ignora quality e restituisce parti se necessario.
- Quando quality e impostato, preset/custom_mb vengono ignorati.
- Con quality_mode=smart, l'API prova da qualita alta a bassa per rispettare la dimensione.
file
File PDF da elaborare.
mode
optimize (predefinito) o split.
preset
gmail25 | outlook20 | outlook25 | custom. Obbligatorio per obiettivi di dimensione se quality non e impostato.
custom_mb
Obbligatorio quando preset=custom. Dimensione target in MB.
quality
screen | ebook | printer | prepress o 1-100. Non consentito per split.
quality_mode
Usa "smart" per raggiungere la dimensione target provando le qualita; richiede preset/custom_mb.
watermark
Immagine filigrana fino a 5MB.
cURL: preset dimensione
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "preset=gmail25" -F "mode=optimize"
cURL: qualita smart (dimensione target)
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: qualita fissa
curl -X POST https://pdfthin.com/api/jobs -F "[email protected]" -F "quality=printer" -F "mode=optimize"
Crea job (organize)
Usa mode=organize per unire, ruotare, eliminare, riordinare e dividere pagine.
- Se vengono caricati piu file, vengono uniti nell'ordine di upload.
- E richiesta almeno un'operazione o piu file.
file
Uno o piu file PDF (multipli consentiti).
mode
organize.
rotate_angle
90 | 180 | 270.
rotate_pages
Lista pagine come 1,3-5.
delete_pages
Pagine da rimuovere, es. 2,4,7-9.
order_pages
Ordine pagine esplicito, es. 3,1,2.
split_after
Dividere dopo pagine, es. 2,4,7.
watermark
Immagine filigrana fino a 5MB.
cURL: unisci + ruota
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"
Verifica stato
GET /api/jobs/{id} restituisce stato del job e file risultato.
- Valori di stato: queued | processing | done | failed.
Risposta di esempio
{
"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"
}
]
}
}
Scarica risultati
GET /api/jobs/{id}/download?index=0
- Usa index=0..n per output multi-parte.
- Se chiamato senza token, l'API restituisce un redirect con token a breve durata.
- TTL del token: DOWNLOAD_TOKEN_TTL_MIN minuti.
cURL: download
curl -L "https://pdfthin.com/api/jobs/job-id/download?index=0" -o output.pdf
Elimina job
DELETE /api/jobs/{id} rimuove file e stato.
- Restituisce 204 No Content.
cURL: elimina
curl -X DELETE https://pdfthin.com/api/jobs/job-id
Codici di errore
Gli errori usano 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 (bozza)
Snippet minimo OpenAPI 3.0 per integrazione 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