# Inicio rápido

Esto recorre el ciclo completo con `curl`. Necesitas una [clave de API](https://docs.accessful.de/es/authentication/)
y un PDF. Exporta primero la clave:

```bash
export ACCESSFUL_API_KEY="ak_tu_clave_aqui"
export BASE="https://api.accessful.de/api/v1/upload-service"
```

1. **Sube el PDF.** Envíalo como campo multipart `files`:

   ```bash
   curl -X POST "$BASE/pdf/upload" \
     -H "X-API-Key: $ACCESSFUL_API_KEY" \
     -F "files=@documento.pdf"
   ```

   La respuesta lista un `caseId` por cada archivo aceptado:

   ```json
   {
     "successfulUploads": ["7c2f1e4a-9b0d-4a1e-8f3c-2d6b5a9e1c40"],
     "duplicateFiles": [],
     "message": "Upload completed successfully. Uploaded 1 files. 0 duplicates found.",
     "callbackUrl": null
   }
   ```

2. **Sondea el estado del trabajo** con ese `caseId` hasta que sea `completed`:

   ```bash
   curl "$BASE/job-status/7c2f1e4a-9b0d-4a1e-8f3c-2d6b5a9e1c40" \
     -H "X-API-Key: $ACCESSFUL_API_KEY"
   ```

   ```json
   { "jobStatus": "completed", "stage": "finished", "score": 87 }
   ```

   `score` es la calidad de accesibilidad del resultado (0–100). Consulta todos los
   [valores de `jobStatus`](https://docs.accessful.de/es/reference/api/).

3. **Descarga** el PDF/UA convertido:

   ```bash
   curl -L "$BASE/download/7c2f1e4a-9b0d-4a1e-8f3c-2d6b5a9e1c40" \
     -H "X-API-Key: $ACCESSFUL_API_KEY" \
     -o documento-pdfua.pdf
   ```

4. **Elimina el caso** cuando ya no lo necesites (opcional, pero recomendado — es un
   borrado permanente):

   ```bash
   curl -X DELETE "$BASE/delete/7c2f1e4a-9b0d-4a1e-8f3c-2d6b5a9e1c40" \
     -H "X-API-Key: $ACCESSFUL_API_KEY"
   ```
**Sáltate el sondeo:** En lugar del paso&nbsp;2, registra un [webhook](https://docs.accessful.de/es/webhooks/) al subir el archivo y
enviaremos un evento firmado por POST a tu URL en cuanto el trabajo termine.

## Ejemplo completo

```js
const BASE = 'https://api.accessful.de/api/v1/upload-service';
const headers = { 'X-API-Key': process.env.ACCESSFUL_API_KEY };

// 1. Subir
const form = new FormData();
form.append('files', new Blob([await readFile('documento.pdf')], { type: 'application/pdf' }), 'documento.pdf');
const up = await fetch(`${BASE}/pdf/upload`, { method: 'POST', headers, body: form });
const { successfulUploads: [caseId] } = await up.json();

// 2. Sondear hasta el estado final
const terminal = new Set(['completed', 'failed', 'analyzer_failed', 'canceled', 'quota_exceeded']);
let status;
do {
  await new Promise((r) => setTimeout(r, 2000));
  status = await (await fetch(`${BASE}/job-status/${caseId}`, { headers })).json();
} while (!terminal.has(status.jobStatus));

if (status.jobStatus !== 'completed') throw new Error(`Job ${status.jobStatus}`);

// 3. Descargar
const pdf = await (await fetch(`${BASE}/download/${caseId}`, { headers })).arrayBuffer();
await writeFile('documento-pdfua.pdf', Buffer.from(pdf));
console.log(`Listo — score ${status.score}`);
```
¿Prefieres hacer clic en vez de teclear? Ejecuta el mismo flujo en el navegador en la página
[Pruébalo](https://docs.accessful.de/es/try-it-out/).