---
title: Pass-Konformität prüfen
description: Dreistufiges Konformitätsurteil für einen Pass, mit regulierungsbezogenen Findings — prüfen, beheben, erneut prüfen (prüfen-beheben-verifizieren).
canonical: "https://www.tracepass.eu/de/docs/passport-compliance"
locale: de
source: "https://www.tracepass.eu/de/docs/passport-compliance"
---

# Pass-Konformität prüfen

> Dreistufiges Konformitätsurteil für einen Pass, mit regulierungsbezogenen Findings — prüfen, beheben, erneut prüfen (prüfen-beheben-verifizieren).

```http
GET /api/v1/passports/{id}/compliance
```

Liefert ein dreistufiges Konformitätsurteil für einen Pass — `compliant`, `compliant_with_warnings` oder `incomplete` — zusammen mit regulierungsbezogenen Findings, sodass eine Integration einen Pass prüfen, die genannten Lücken beheben und erneut aufrufen kann, um zu bestätigen. Diese Kette prüfen → beheben → verifizieren ist der Zweck: Die Antwort sagt dem KI-Agenten genau, was als Nächstes zu setzen ist.

Findings stammen aus drei Stufen. **Static**: erforderliche Template-Felder, die fehlen oder nicht freigegeben sind, und erforderliche Wirtschaftsakteure, die nicht gesetzt sind, sind `critical`; Feldwerte, die das Template-Format verletzen (Pattern / Enum / Grenzen), sind `warning`. **Conditional**: kategoriespezifische Regeln, die heute in Kraft sind — der Batteriepass-Geltungsbereich nach Verordnung (EU) 2023/1542 Art. 77, die SVHC-Offenlegung nach REACH Art. 33 / SCIP, die Leistungserklärung nach Verordnung (EU) 2024/3110 — plus die übergreifende Regel, dass ein von einem Nicht-EU-Hersteller auf dem EU-Markt bereitgestelltes Produkt einen in der EU niedergelassenen Akteur benötigt (Verordnung (EU) 2019/1020 Art. 4).

**Lesen Sie `conditionalCoverage`.** Es ist `evaluated`, wenn Conditional-Regeln für diese Kategorie liefen, oder `static-only`, wenn noch keine bindende Conditional-Regel in Kraft ist (heute 8 der 12 Kategorien). Bei `static-only` bedeutet das Fehlen von Conditional-Findings NICHT, dass die Kategorie keine künftigen Anforderungen hat — nur dass noch keine rechtsverbindlich sind. Ein mit `unverifiable_conditional` markiertes Finding bedeutet, dass eine Regel gilt, aber die zur Auswertung nötigen Daten (z. B. Batteriekategorie, SVHC-Gehalt) nicht im Pass stehen — prüfen Sie es manuell. Nur lesend; zählt als ein v1-Passlesezugriff gegen das Tageslimit.

## Parameters

| Name | In | Type | Required | Description |
| --- | --- | --- | --- | --- |
| `Authorization` | header | string | yes | `Bearer <api-key>`. |
| `id` | path | ObjectId | yes | Pass-ID. |

## Examples

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

```typescript
const res = await fetch(
  `https://app.tracepass.eu/api/v1/passports/${id}/compliance`,
  { headers: { Authorization: `Bearer ${process.env.TRACEPASS_API_KEY}` } },
);
const verdict = await res.json();

if (verdict.verdict === "incomplete") {
  // Each critical finding names the field/party to set and cites the regulation.
  for (const f of verdict.critical) {
    console.log(`${f.target}: ${f.why} (${f.regulation ?? ""} ${f.article ?? ""})`);
  }
}
```

```python
import os, requests
res = requests.get(
    f"https://app.tracepass.eu/api/v1/passports/{passport_id}/compliance",
    headers={"Authorization": f"Bearer {os.environ['TRACEPASS_API_KEY']}"},
)
res.raise_for_status()
verdict = res.json()
for f in verdict["critical"]:
    print(f["target"], "—", f["why"], f.get("regulation", ""), f.get("article", ""))
```

## Responses

### 200 — incomplete

```json
{
  "verdict": "incomplete",
  "category": "battery",
  "conditionalCoverage": "evaluated",
  "critical": [
    {
      "type": "conditional_missing",
      "severity": "critical",
      "target": "batteryUniqueIdentifier",
      "regulation": "(EU) 2023/1542",
      "article": "Art. 77",
      "ruleId": "BAT-1",
      "why": "This is an in-scope battery (EV); a battery passport with its unique identifier is mandatory.",
      "fix": "Provide batteryUniqueIdentifier — the battery passport's unique identifier (GS1 Digital Link)."
    }
  ],
  "warnings": [],
  "checkedRules": ["static:required-fields", "static:required-parties", "static:format", "BAT-1", "CC-1"],
  "completionPercentage": 72
}
```

### 200 — compliant

```json
{
  "verdict": "compliant",
  "category": "furniture",
  "conditionalCoverage": "static-only",
  "critical": [],
  "warnings": [],
  "checkedRules": ["static:required-fields", "static:required-parties", "static:format", "CC-1"],
  "completionPercentage": 100
}
```

### 404 — Nicht gefunden

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

## Related

- [Einzelnen Pass lesen](https://www.tracepass.eu/de/docs/get-passport.md)
- [Feld aktualisieren](https://www.tracepass.eu/de/docs/update-field.md)
- [Wirtschaftsakteur setzen](https://www.tracepass.eu/de/docs/upsert-party.md)
