API PDFThin

Carica PDF, comprimi per dimensione o qualita e scarica i risultati tramite API REST.

100req/min
200 MBmax upload
1000max pages
60 orefile TTL

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) obbligatorio
File PDF da elaborare.
mode
string opzionale
optimize (predefinito) o split.
preset
string opzionale
gmail25 | outlook20 | outlook25 | custom. Obbligatorio per obiettivi di dimensione se quality non e impostato.
custom_mb
int opzionale
Obbligatorio quando preset=custom. Dimensione target in MB.
quality
string opzionale
screen | ebook | printer | prepress o 1-100. Non consentito per split.
quality_mode
string opzionale
Usa "smart" per raggiungere la dimensione target provando le qualita; richiede preset/custom_mb.
watermark
file (PNG/JPG) opzionale
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
file (PDF) obbligatorio
Uno o piu file PDF (multipli consentiti).
mode
string obbligatorio
organize.
rotate_angle
int opzionale
90 | 180 | 270.
rotate_pages
string opzionale
Lista pagine come 1,3-5.
delete_pages
string opzionale
Pagine da rimuovere, es. 2,4,7-9.
order_pages
string opzionale
Ordine pagine esplicito, es. 3,1,2.
split_after
string opzionale
Dividere dopo pagine, es. 2,4,7.
watermark
file (PNG/JPG) opzionale
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