API Basics
Die REST API bietet Ihnen die Möglichkeit, automatisiert mit dem Shop-System zu interagieren – etwa um Produktdaten zu verwalten, Bestellungen auszulesen oder eigene Integrationen anzubinden. Dieses Dokument beschreibt die grundlegenden Voraussetzungen und technischen Konzepte, um mit der API arbeiten zu können.
Inhaltsverzeichnis
1. Basis-URL
Alle REST-API-Endpunkte sind unter folgendem Pfad erreichbar:
https://<ihr-shop>.de/admin/api/v1/Diese URL ist die Basis für sämtliche Anfragen, z.B.
GET https://<ihr-shop>.de/admin/api/v1/productsPOST https://<ihr-shop>.de/admin/api/v1/login
2. Zugang & Berechtigungen
Für den Zugriff auf die REST API ist ein Benutzerkonto erforderlich, das im Admin Interface Ihres Shops verwaltet wird.
Das Admin Interface ist in sogenannte Services unterteilt (z. B. Produkte, Kategorien, Sitemaps, SEO-URLs, Datenfeeds, Statistiken etc.). Für jeden Service können im Admin-Bereich Berechtigungen vergeben werden – z. B. Lesen, Bearbeiten, Erstellen, Löschen oder Publizieren.
Diese Rechte gelten auch für die REST API und bestimmen, auf welche Endpunkte Sie zugreifen und welche HTTP-Methoden (GET, POST, PUT, DELETE) Sie verwenden dürfen.
Ein Benutzer mit z. B. nur Leserechten im Service „Produkte“ kann Produkte per API nur abrufen (GET), aber nicht bearbeiten (PUT/POST/DELETE).
Ihre zugewiesenen Rechte können Sie im Admin Interface unter folgendem Pfad einsehen:
https://<ihr-shop>.de/admin/profileDie Vergabe von Rechten erfolgt über den Service „Benutzer“:
https://<ihr-shop>.de/admin/administration/usersEinige Endpunkte arbeiten mit subshopspezifischen Daten. In diesen Fällen muss der betreffende Subshop über den URL-Parameter subshopId explizit angegeben werden. Das betrifft unter anderem Methoden für Produkte, Kategorien, SEO-Daten und ähnliche kontextabhängige Inhalte.
https://<ihr-shop>.de/admin/api/v1/categories?subshopId=deutschWird der Parameter weggelassen, kann die Anfrage fehlschlagen oder unerwartete Ergebnisse liefern.
Falls Ihnen der Zugriff auf bestimmte REST-Endpunkte verweigert wird, fehlen Ihnen möglicherweise die erforderlichen Rechte. In diesem Fall wenden Sie sich an den zuständigen Shop-Administrator.
3. Authentifizierung
Für den Zugriff auf geschützte REST-API-Endpunkte ist eine Anmeldung erforderlich.
Die Authentifizierung erfolgt entweder über Benutzername/Passwort oder per API-Schlüssel. Erfolgreich authentifizierte Anfragen erhalten ein Access Token, mit dem weitere Endpunkte angesprochen werden können. Zusätzlich wird ein Refresh Token bereitgestellt.
Der Login erfolgt über folgenden Endpunkt:
POST https://<ihr-shop>.de/admin/api/v1/loginDas erhaltene Access Token muss bei allen folgenden API-Aufrufen im HTTP-Header mitgesendet werden. Der Header muss dazu das Feld X-Authorization enthalten. Der Wert besteht aus dem Wort Bearer, gefolgt vom Token:
"X-Authorization": "Bearer <Access-Token>"Details zur Authentifizierung (Request-Varianten, Token-Verwendung, Fehlercodes etc.) finden Sie in der separaten Dokumentation: API-Referenz Authentifizierung
4. Filter, Sortierung & Paginierung
Viele REST-Endpunkte liefern Listen von Daten – etwa Produkte, Bestellungen oder Kategorien. Um mit diesen Daten effizient zu arbeiten, stellt die API verschiedene Parameter zur Verfügung, mit denen sich die Ergebnisse eingrenzen, sortieren und seitenweise abrufen lassen. Diese Mechanismen sind besonders bei großen Datenmengen wichtig, um performante und gezielte Abfragen zu ermöglichen.
Ein API-Aufruf kann dabei verschiedene Parameter enthalten. Ein typischer GET-Request könnte wie folgt aussehen:
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?size=100&sort=field1:asc&filter_eq[field2]=value&pageToken=MTAwDie Antwort der API ist standardisiert aufgebaut und enthält neben den angeforderten Datensätzen weitere Meta-Informationen wie den nextPageToken, den Gesamtzähler (totalCount) sowie das Flag endReached, das angibt, ob weitere Seiten zur Verfügung stehen:
{
"endReached": true,
"items": [...],
"nextPageToken": "MTAx",
"totalCount": 123
}
4.1 Unterstützte Parameter
Die folgenden URL-Parameter werden zur Steuerung von Ergebnislisten unterstützt. Die Schreibweise ist case-sensitive.
Parameter | Beschreibung |
|---|---|
| Anzahl der zurückgegebenen Einträge pro Seite (1 bis maximal 300) |
| Optionaler Paginierungsmarker für den Abruf der nächsten Seite |
| Ergebnis-Sortierung nach einem oder mehreren Feldern |
| Filterbedingungen zur Einschränkung der Ergebnisse |
| Optionaler Parameter zur Einschränkung auf einen bestimmten Subshop. Bei einigen Endpunkten (z. B. Produkte, Kategorien, SEO) erforderlich. |
4.2 Anzahl & Paginierung
Die Anzahl der zurückgegebenen Datensätze pro API-Anfrage kann über den Parameter size gesteuert werden. Der Wert muss eine Ganzzahl zwischen 1 und 300 sein.
Wird kein size-Parameter übergeben, verwendet die API standardmäßig einen Wert von 100 Einträgen pro Seite.
Ist die angeforderte Datenmenge größer als der definierte size-Wert (bzw. größer als der Standardwert), liefert die API in der Antwort einen nextPageToken, mit dem weitere Seiten geladen werden können. Der Paginierungsmechanismus erlaubt es, große Datenmengen schrittweise abzurufen.
Beispiel
Beispiel für eine manuell gesetzte Seitengröße.
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?size=50Fehlercodes
Fehlercode | Typ | Beschreibung |
|---|---|---|
400 |
| Ungültige Zeichen im Parameterwert |
400 |
| Wert kleiner als 1 oder größer als 300 |
Der Parameter pageToken ermöglicht den Zugriff auf die Folgeseiten von Ergebnislisten. Der Wert wird von der API automatisch als nextPageToken zurückgegeben und muss base64-url-kodiert übergeben werden. Bei einer fehlerhaften oder ungültigen Codierung erfolgt eine Fehlermeldung.
Beispiel
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?size=100&pageToken=MTAwFehlercodes
Fehlercode | Typ | Beschreibung |
|---|---|---|
400 |
| Token nicht dekodierbar oder negativ bzw. ungültig |
Sonderfall: Produkte
Das Laden von Produkten mittels pageToken kann langsam sein, wenn mehr als 10.000 Produkte im Shop existieren. Neben dem pageToken wird bei Produkten auch ein searchAfterToken zurückgegeben.
Statt pageToken kann searchAfterToken in der URL angegeben werden, um auch bei vielen Ergebnissen die Produkte effizient laden zu können.
Beispiel
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?size=300&searchAfterToken=WzAuMCwiMTAwLTQxMjMyLTk3NDFfZGV1dHNjaF8zIl0
4.3 Sortierung
Die Sortierung von Ergebnissen erfolgt über den Parameter sort. Er erwartet als Wert einen Feldnamen und eine Sortierrichtung (asc für aufsteigend, desc für absteigend), getrennt durch einen Doppelpunkt.
Für die Kombination mehrerer Sortierkriterien ist es erforderlich, mehrere sort-Parameter zu übergeben. Jeder Parameter steht dabei für ein einzelnes Kriterium. Eine kommaseparierte Liste innerhalb eines Parameters wird nicht unterstützt.
Falls kein Sortierparameter angegeben ist, wird standardmäßig nach der internen ID sortiert.
Syntax
sort=<Feldname>:asc|descSortierung nach Preis aufsteigend
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?sort=price:ascEin weiteres Beispiel für eine Sortierung nach dem Namen (aufsteigend) und anschließend nach dem Preis (absteigend):
https://<ihr-shop>.de/admin/api/v1/<API-Referenz>?sort=name:asc&sort=price:descFehlercodes
Fehlercode | Typ | Beschreibung |
|---|---|---|
400 |
| Fehlender oder mehrfach vorhandener Doppelpunkt. |
400 |
| Ungültige Sortierrichtung (nicht |
400 |
| Das angegebene Sortierfeld ist unbekannt |
4.4 Filter
Filter ermöglichen eine gezielte Einschränkung von Ergebnislisten. Jeder Filter folgt dem Muster.
Syntax
filter_<Operation>[<Feldname>]=<Wert>Mehrere Filter für unterschiedliche Felder werden logisch mit UND verknüpft. Wenn mehrere Filter für dasselbe Feld angegeben werden, interpretiert die API diese als ODER-Verknüpfung.
?filter_eq[status]=open
&filter_gte[createdAt]=2024-12-01T00:00:00Z
&filter_lte[createdAt]=2025-01-05T23:59:59ZUnterstützte Filteroperationen:
Operation | Bedeutung |
|---|---|
| Gleichheit ( |
| Ungleichheit ( |
| Kleiner als ( |
| Kleiner oder gleich ( |
| Größer als ( |
| Größer oder gleich ( |
| Beginnt mit |
| Endet mit |
| Enthält |
| Enthält nicht |
| Gilt für benutzerdefinierte Felder vom Typ Liste |
| Gilt für benutzerdefinierte Felder vom Typ Liste |
Fehlercodes
Fehlercode | Typ | Beschreibung |
|---|---|---|
400 |
| Die Filteroperation ist nicht bekannt |
400 |
| Das angegebene Feld ist ungültig |
5. Support
Bei technischen Fragen und Hilfestellungen ist unser Support-Team für Sie erreichbar: Zum Kundenportal
Bitte senden Sie uns eine möglichst detaillierte Beschreibung sowie Screenshots, Requests/Antworten damit wir Ihre Anfrage zeitnah und zielführend beantworten können.
© 2025 WEBSALE AG | Impressum | Datenschutz