Du hast eine regulatorische Frist — Batterien 2027, Textilien kurz danach — und eine Entscheidung: ein Digital-Product-Passport-System selbst bauen oder kaufen? Die meisten „Build vs Buy"-Artikel sind kaum getarnte Verkaufstexte. Dieser versucht, ehrlich zu sein — inklusive wann Selbstbauen wirklich richtig ist.
Was „selbst bauen" wirklich bedeutet
Ein DPP ist keine Datenbankzeile plus Webseite. Damit ein System konform und nützlich ist, muss es all das leisten:
- einen GS1-Digital-Link-Resolver mit Content-Negotiation (HTML für Menschen, JSON-LD für Maschinen, Linkset für Behörden);
- GTIN/Seriennummer-Verwaltung mit unveränderlichen Identifiern, damit gedruckte Etiketten nie brechen;
- unveränderliches, langlebiges Hosting der Passport-Daten (der Passport muss deine nächste CMS-Migration überleben);
- druckfertige QR-Generierung in Vektorformaten (SVG/EPS) für Etikettendrucker;
- kategoriespezifische EU-Validierung — die Batterie-Regeln (VO 2023/1542) und Textil-/ESPR-Regeln unterscheiden sich Feld für Feld;
- lokalisierte Verbraucherseiten in EU-Sprachen;
- EU-Register-Übermittlung, Scan-Analytics und einen Audit-Trail.
Eine realistische Schätzung dafür sind €100k–500k+ und 9–18 Monate — und nichts davon ist dein eigentliches Produkt.
Was Kaufen dir bringt
| Selbst bauen | Kaufen (z. B. qr3.app) | |
|---|---|---|
| Zeit bis zum ersten konformen DPP | 9–18 Monate | Minuten |
| Vorab-Kosten | €100k–500k+ | €0 (Free) |
| Laufend | dein Engineering-Team | ab €29/Mo |
| Compliance-Updates (ESPR Delegated Acts) | selbst verfolgen + umsetzen | inklusive |
| GS1-Resolver + Content-Negotiation | bauen + betreiben | inklusive |
| Lokalisierte Verbraucherseiten | bauen | inklusive |
| Wohin der Fokus deines Teams geht | Infrastruktur | dein Produkt |
Die dritte Option, die fast alle verschweigen: Infrastruktur kaufen, UX selbst bauen
Es ist kein Entweder-oder. Die teuren, undifferenzierten Teile — Resolver, unveränderliches Hosting, QR-Generierung, EU-Validierung — sind genau das, was du nicht bauen solltest. Was sich zu besitzen lohnt, ist deine gebrandete Experience und Integration. Also: Infrastruktur per API kaufen, deine UX obendrauf bauen.
import { QR3 } from "@qr3/sdk";
const client = new QR3({ apiKey: process.env.QR3_API_KEY! });
// Der harte, compliance-lastige Teil — ein Aufruf, direkt aus deinem ERP/PIM:
const passport = await client.dpp.create({
gtin: product.gtin,
serial: product.serial,
product_name: product.name,
manufacturer: "ExampleTech GmbH",
origin_country: "DE",
category: "battery",
battery_data: product.batteryData,
});
// Deine Experience obendrauf: dein Dashboard, dein Branding, deine
// Integrationen. Auf Scans in deinen Systemen via Webhooks reagieren:
// qr.scanned -> Analytics, Nachbestellung auslösen, Rückruf markieren.
Das ist die ehrliche Umdeutung des klassischen „Selbstbauen kostet ein Vermögen": Kauf den Teil, der schwer und für alle gleich ist; bau den Teil, der dir gehört.
Wann Selbstbauen wirklich sinnvoll ist
Fairerweise — manchmal ist es das:
- DPP ist dein Kernprodukt (du verkaufst selbst eine Compliance-Plattform);
- du hast Anforderungen, die kein Anbieter erfüllt (exotische Data-Residency, ein bespoke On-Prem-Stack);
- extreme Skalierung, bei der die Stückkosten jede SaaS schlagen.
Außerhalb dieser Fälle lenkt das Bauen der undifferenzierten Schwerstarbeit meist nur davon ab, dein eigentliches Produkt vor der Frist auszuliefern.
FAQ
Ist eine API nicht auch nur eine andere Form von Lock-in? Weniger als selbst zu bauen und im eigenen, ungepflegten Code festzustecken. GTIN/Seriennummer sind GS1-Standards; Passport-Daten sind als JSON-LD exportierbar. Die Standards sind per Design portabel.
Können wir erst kaufen und später selbst bauen? Ja — genau das ist der Hybrid-Pfad. Heute auf der API starten (Frist halten), später selektiv insourcen, wenn die Ökonomie es verlangt.
Und der Zeitdruck konkret? Bauen dauert 9–18 Monate; Batterie-DPPs sind 2027 fällig. Wer noch nicht baut, hält die Frist nur durch Kaufen.
Quellen
Kostenlos starten und heute einen konformen DPP ausliefern: app.qr3.app/sign-up