---
title: Pass archivieren (unumkehrbar)
description: Pass unumkehrbar archivieren. Viewer gibt 404, GS1 Digital Link löst nicht auf. passport.archived-Webhook. Nur für nie ausgelieferte Produkte.
canonical: "https://www.tracepass.eu/de/docs/archive-passport"
locale: de
source: "https://www.tracepass.eu/de/docs/archive-passport"
---

# Pass archivieren (unumkehrbar)

> Pass unumkehrbar archivieren. Viewer gibt 404, GS1 Digital Link löst nicht auf. passport.archived-Webhook. Nur für nie ausgelieferte Produkte.

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

**Unumkehrbar.** Der öffentliche Viewer gibt 404 zurück, die GS1-Digital-Link-URL löst nicht mehr auf, der QR-Code stirbt endgültig. Nur für Produkte verwenden, die nie ausgeliefert wurden — das Archivieren eines Passes für ein Produkt, das bereits bei Kunden ist, zerstört jeden QR-Scan, den sie je damit machen werden.

Es gibt absichtlich kein DELETE-Verb: zu leicht als destruktive Aktion per Curl-Typo oder fehlkonfiguriertem Client auszulösen. Die HTTP-Methode ist POST und der Pfad enthält das literale `archive`-Segment — beides bewusste Reibung. Zählt als ein v1-Schreibvorgang. Unterstützt Idempotency-Key. Sendet den `passport.archived`-Webhook.

## Parameters

| Name | In | Type | Required | Description |
| --- | --- | --- | --- | --- |
| `Authorization` | header | string | yes | `Bearer <token>` — entweder ein `tp_` API-Schlüssel (Developer → API Keys; am einfachsten, für Server-zu-Server) oder ein OAuth-2.0-Access-Token (Developer → OAuth Apps; für nutzerautorisierte Apps, scoped und widerrufbar). Die Authentication-Seite enthält den vollständigen OAuth-Flow und die Scope-Liste. |
| `Idempotency-Key` | header | string | no | UUID v4. |
| `id` | path | ObjectId | yes | Pass-ID. |

## 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 — Archiviert

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

### 422 — Bereits archiviert

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

### 404 — Nicht gefunden

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

## Related

- [Pass suspendieren (reversibel)](https://www.tracepass.eu/de/docs/suspend-passport.md)
- [Pass lesen](https://www.tracepass.eu/de/docs/get-passport.md)
