Durch die Kombination der brandbox REST-Schnittstelle und der w2p-Editoren ist es möglich einen w2p-Editor aus einem Fremdsystem (bspw. einem eigenen Shop) zu öffnen, dem Anwender alle Möglichkeiten eines unterstützten Editors zu bieten und diesen nach Abschluss seiner Gestaltung wieder in das Fremdsystem zurückzubringen.
Aufbau des Plugins
Die Erweiterung ist mit den Editoren Strict
, Nested
, Mail
, XLSX
, Upload
, H5E
und StrictH5E
kompatibel. Wird einer dieser Editoren für ein Fremdsystem geöffnet, wird dem Anwender nach der Gestaltung nur die Möglichkeit geboten den gestalteten Artikel in den Warenkorb zu legen. Die Aktion den gestalteten Artikel in den Warenkorb aufzunehmen wird hierbei durch eine Rückleitung des Anwenders in das Fremdsystem ersetzt. Andere, normalerweise verfügbare Aktionen (bspw. den gestalten Artikel in eine Merkliste aufzunehmen) entfallen hierbei.
Ein über diesen Weg gestalteter Artikel unterliegt ggf. der sog. Garbage Collection und kann daher nach einer definierten Zeit eventuell nicht mehr vorhanden sein.
Konfiguration
Die Verwendung dieser Schnittstelle setzt einsatzbereite REST- und oAuth2-Server voraus.
Damit ein Fremdsystem eine w2p-Editoren URL anfordern kann muss das Feature base/editor.get/editor/url für den REST-Service (Server) freigegeben werden.
Artikel
Es können nur w2p-Editoren-URLs für Artikel angefragt werden, welche über eine SKU verfügen.
Es wird bei Anforderung einer URL für einen Editor immer die erste Artikelvorlage des entsprechenden Artikels genutzt.
Account für Schnittstellen-Authentifizierung
Ein Fremdsystem kann nur dann eine Editoren-URL für einen Artikel anfordern, wenn dieses bei brandbox authentifiziert ist. Hierzu wird ein Anwender benötigt welcher über entsprechende Zugriffsrechte für shop und join verfügt.
Verwendung
Schritt 1: Authentifizierung des Fremdsystems bei brandbox
Weitere Informationen in entsprechender Dokumentation.
Schritt 2: Anfordern einer Editoren-URL für einen Artikel
Die Kommunikation mit brandbox findet bei dieser Anfrage über ein POST-HTTP-Request statt.
URL | https://[brandbox System-URL]/rest/v3/request/editor/base/get_editor_url/ | |
---|---|---|
Method | POST | |
Header | content-type | form-data , x-www-form-urlencoded , etc. |
authorization | Durch Authentifizierung bereitgestellter Access-Token | |
Body | sku | Eindeutige SKU des gewünschten Artikels |
returnUrl | Vollständige URL an die nach Abschluss der Gestaltung im Editor zurückgekehrt werden soll | |
sessionArticleID | Dieser Parameter ist optional und darf nur mit einer gültigen Session-Artikel-ID genutzt werden. Die eindeutige Session-Artikel-ID welche bereits in einem Editor benutzt wurde. Somit kann eine bereits vorgenomme Gestaltung erneut aufgerufen werden. |
Als Antwort sendet brandbox entweder eine entsprechende Fehlermeldung im Fehlerfall oder die Editoren-URL für den geforderten Artikel. Gibt es keinen Fehler kann die Editoren-URL aus der body
-Eigenschaft der JSON-Antwort gelesen werden.
Eine Antwort über die REST-Schnittstelle von brandbox wird in einem entsprechende Antwortformat als JSON geliefert.
Schritt 3: Anwender zu brandbox Editor führen
Die in Schritt 2 gelieferte URL muss genutzt werden um den Anwender in brandbox zu führen. brandbox erzeugt nun selbständig eine entsprechende Gastsession für den Anwender und stellt den angeforderten Editor für die jeweiligen Artikel bereit.
Die gelieferte URL darf nicht verändert und/oder erweitert werden. Über die returnUrl
können zusätzliche Informationen für das Fremdsystem hinterlegt werden.
Schritt 4: Zurückkehrenden Anwender empfangen
Hat der Anwender seine Gestaltung und Datenpflege im Editor abgeschlossen und möchte den Artikel in seinen Warenkorb aufnehmen, wird dieser an die im returnUrl
-Parameter bereitgestellt URL weitergeleitet.
brandbox startet einen POST-HTTP-Request durch den Anwender an die in returnUrl
definierte URL und sendet den POST-Parameter sessionArticleID
mit der eindeutigen ID der Gestaltung des Anwenders mit. Die gelieferte ID muss im Fremdsystem entsprechend für den Anwender gespeichert werden.
Beispiel
Mithilfe des kostenlosen Tools Postman (https://www.screencast.com/t/sOLSb6HfW19) kann dieses Szenario durchgespielt werden.
Das hier genutzte Beispiel ist eine Kombination aus zwei Szenarien für die REST-Schnittstelle. Zum einen wird ein Editor über die Schnittstelle angefragt und zum anderen eine Bestellung daraus erzeugt.