---
title: Archiviare un passaporto (irreversibile)
description: Archiviazione irreversibile. Viewer pubblico restituisce 404, GS1 Digital Link non risolve. Webhook passport.archived. Solo per prodotti mai spediti.
canonical: "https://www.tracepass.eu/it/docs/archive-passport"
locale: it
source: "https://www.tracepass.eu/it/docs/archive-passport"
---

# Archiviare un passaporto (irreversibile)

> Archiviazione irreversibile. Viewer pubblico restituisce 404, GS1 Digital Link non risolve. Webhook passport.archived. Solo per prodotti mai spediti.

```http
POST /api/v1/passports/{id}/archive
```

**Irreversibile.** Il visualizzatore pubblico restituisce 404, l'URL GS1 Digital Link smette di risolvere, il codice QR muore definitivamente. Usatelo SOLO per prodotti mai spediti — archiviare il passaporto di un prodotto già nelle mani dei clienti rompe ogni scansione QR che ne faranno.

Non c'è un verbo DELETE di proposito: troppo facile attivarlo per errore come azione distruttiva tramite un refuso in curl o un client mal configurato. Il metodo HTTP è POST e il percorso include il segmento letterale `archive` — entrambi un attrito intenzionale. Conta come una scrittura v1. Rispetta `Idempotency-Key`. Attiva il webhook `passport.archived`.

## Parameters

| Name | In | Type | Required | Description |
| --- | --- | --- | --- | --- |
| `Authorization` | header | string | yes | `Bearer <token>` — una chiave API `tp_` (Developer → API Keys; più semplice, per server-to-server) oppure un access token OAuth 2.0 (Developer → OAuth Apps; per app autorizzate dall'utente, scoped e revocabili). La pagina Authentication contiene il flusso OAuth completo e l'elenco degli scopes. |
| `Idempotency-Key` | header | string | no | UUID v4. |
| `id` | path | ObjectId | yes | ID del passaporto. |

## Examples

```bash
curl -sS -X POST \
  https://app.tracepass.eu/api/v1/passports/6650b2c3d4e5f6a7b8c9d0e1/archive \
  -H "Authorization: Bearer tp_REDACTED_xxxxxxxxxxxx"
```

```typescript
await fetch(
  `https://app.tracepass.eu/api/v1/passports/${id}/archive`,
  {
    method: "POST",
    headers: { Authorization: `Bearer ${process.env.TRACEPASS_API_KEY}` },
  },
);
```

```python
import os, requests
res = requests.post(
    f"https://app.tracepass.eu/api/v1/passports/{passport_id}/archive",
    headers={"Authorization": f"Bearer {os.environ['TRACEPASS_API_KEY']}"},
)
res.raise_for_status()
```

## Responses

### 200 — Archiviato

```json
{
  "_id": "6650b2c3d4e5f6a7b8c9d0e1",
  "status": "archived",
  "archivedAt": "2026-05-09T17:00:00.000Z"
}
```

### 422 — Già archiviato

```json
{ "error": "Passport already archived" }
```

### 404 — Non trovato

```json
{ "error": "Passport not found" }
```

## Related

- [Sospendere un passaporto (reversibile)](https://www.tracepass.eu/it/docs/suspend-passport.md)
- [Leggere un passaporto](https://www.tracepass.eu/it/docs/get-passport.md)
