WS-REST-OrderManagement (DE)
Allgemeines
Im Folgenden wird eine REST-basierte Schnittstelle beschrieben, mit deren Hilfe ein WEBSALE Shop kundenspezifische Bestellungen von einem ERP-System in Echtzeit übermittelt bekommt und diese dem Kunden/Besteller im Shop anzeigt. Insbesondere dient diese Schnittstelle dazu, dem Kunden alle Bestellungen anzuzeigen, also auch die Bestellungen, die nicht im Shop getätigt wurden, sondern z. B. per Callcenter, Brief oder Fax aufgegeben wurden. Des Weiteren können dem ERP-System Stornos und Retouren übermittelt werden.
Falls das ERP-System nicht direkt über das Internet erreichbar ist, dann kann die WEBSALE AG einen VPN-Tunnel zur Verfügung stellen. Über diesen VPN-Tunnel kann das ERP-System eine sichere TCP/IP-Verbindung ins Internet herstellen.
REST-Funktionen
Alle hier aufgelistete Funktionen werden mittels POST aufgerufen. Bei Erfolg liefert das ERP-System den Http-Code 200 zurück.
Übertragung einer Liste von Bestellungen (Kopf- und optionale Positionsdaten)
Der Shop fordert eine Liste von Bestellungen vom ERP-System an.
Das ERP-System liefert eine Liste von Bestellungen zurück.
In der Liste wird nur ein Teil der Bestelldaten übermittelt. In der Regel sind dies die Kopfdaten.
Übertragung einer einzelnen Bestellung (Kopf- und Positionsdaten)
Der Shop fordert eine einzelne Bestellung vom ERP-System an.
Das ERP-System liefert die Kopf- und alle Positionsdaten der Bestellung zurück.
Übertragung einer PDF-Datei
Der Shop fordert die PDF-Datei vom ERP-System an.
Das ERP-System liefert die PDF-Datei zurück.
Der Shop bietet die PDF-Datei dem Kunden als Download an.
Storno/Retoure von einer oder mehreren Positionen
Der Besteller storniert/retourniert eine oder mehrere Positionen.
Der Shop sendet die Stornierung/Retoure an das ERP-System.
Das ERP-System bestätigt die Stornierung/Retoure oder lehnt diese ab.
Übertragung der letzten Shop-Bestellnummer
Der Shop fordert die letzte Shop-Bestellnummer vom ERP-System an.
Das ERP-System liefert die letzte Shop-Bestellnummer zurück.
Übertragung des Lagerbestands/Filialbestandes eines einzelnen Produkts
Der Shop fordert den Lagerbestand zu einem einzelnen Produkt an.
Das ERP-System liefert den Lagerbestand des Produktes zurück.
Übertragung von allgemeinen Kundendaten
Der Shop fordert allgemeine Kundendaten vom ERP-System an.
Das ERP-System liefert die allgemeinen Kundendaten zurück.
Ausschließlich verschlüsselter Abruf
Der Webservice wird ausschließlich über SSL aufgerufen. Unverschlüsselte Verbindungen müssen auf beiden Seiten (Shop/ERP-System) abgelehnt werden.
UTF-8-Codierung
Alle Daten werden im UTF-8 Format übergeben.
Fehler
Das ERP-System antwortet mit einem Http-Code ungleich 200, wenn es keine Daten liefern kann. Dies ist z. B. in den folgenden Fällen gegeben:
falsches REST-Passwort
unbekannte Kundennummer
unbekannte ShopID/SubshopID
unbekannter Typ
interner Fehler
etc.
Der Shop erwartet einen Fehler-Code, der vom ERP-System vorgegeben wird, und eine optionale Fehlermeldung. Aufgrund des Fehler-Codes kann der Designer dem Besteller sprachabhängige Erläuterungen/Hinweismeldungen anzeigen. Die optionale Fehlermeldung dient nicht dazu, diese dem Besteller anzuzeigen, sondern wird zur Protokollierung in der Log-Datei verwendet. Sie kann daher rein technisch sein.
Der Fehlercode muss eindeutig und in jeder Antwort einheitlich sein. Beispiel:
0001: falsches REST-Passwort
0002: unbekannte Kundennummer
0003: unbekannte ShopID
0004: unbekannte SubshopID
0005: unbekannter Typ
1000: interner Fehler X
1001: interner Fehler Y
1002: interner Fehler Z
etc.
Liefert das ERP-System z. B. den Fehlercode „0002“, so könnte dem Besteller folgende Meldung angezeigt werden:
„Sehr geehrter Herr Müller,
leider liegen uns derzeit keine Informationen über Ihre Kundennummer vor. Bitte kontaktieren Sie uns unter der Telefonnummer XYZ oder benutzen Sie unser Kontaktformular (→ Link zum Kontaktformular)“
Außerdem können entsprechende (codeabhängige) Grafiken eingeblendet werden.
Response:
Http-Code = 400
{
"ErrCode": 2,
"ErrMsg": "Unbekannte Kundennummer"
}
Übertragung einer Liste von Bestellungen /GetOrderList
Bei der Übertragung liefert das ERP-System dem Shop
fest vorgegebene Daten
beliebige Daten
zurück.
Anfrage vom Shop für eine Liste von Bestellungen
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID, in der die Daten angezeigt werden. |
CustomerSubshopIDs | 128 je ID | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
Type |
| ja | Integer | Ein Typ, der die angeforderten Daten spezifiziert. Bei „0“ liefert das ERP-System alle Typen, die im ERP-System vorhanden sind zurück. Die einzelnen Typen sind im Shop frei konfigurierbar und werden vom ERP-System vorgegeben. 1: Rechnung Bitte beachten: Die Typen 1000 bis 1100 sind für interne Zwecke reserviert. |
MaxEntries |
| nein | Integer | Die max. Anzahl der Listeneinträge, die gesendet werden sollen. Fehlt der Parameter oder ist er „0“, dann benutzt das ERP-System einen eigenen Standardwert für die maximalen Listeneinträge. |
DateFrom | 10 | nein | String
Format: JJJJ-MM-TT | Ein optionales Anfangsdatum, ab dem die Listeneinträge gesendet werden. |
DateUntil | 10 | nein | String
Format: JJJJ-MM-TT | Ein optionales Enddatum, bis zu dem die Listeneinträge gesendet werden. |
SearchFilters |
| nein | Filter-Array | Optionale freie Suchfilter. Maximal 10 Einträge. |
Vom ERP-System vorgegebene freie Suchfilter
Optional können dem ERP-System bis zu 10 freie Suchfilter übergeben werden. Die möglichen Filter und die dazugehörigen Codes werden vom ERP-System vorgegeben.
{
"SearchFilters" : [
{
"Code": 1,
"Value": "FilterText"
},
{
"Code": 2,
"Value": "FilterText"
}
],
...
}
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
Code | 16 | ja | String | Der Code des Suchfilters. Das ERP-System gibt vor, welche Codes es unterstützt. Ein Code darf nur die Zeichen a-z, A-Z und 0-9 beinhalten. |
Value | 128 | ja | String | Der Wert, nach dem gefiltert wird. Die maximale eingebbare Länge kann vom Designer eingestellt/verringert werden. |
Anfrage /GetOrderList
{
"ShopID": "myshop",
"Password": "1234567890",
"SubshopID": "Deutsch",
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
],
"MaxEntries": 10,
"SearchFilters": [
{
"Code": "code01",
"Value": "1"
}
],
"Type": 1,
"DateFrom": "2020-03-02",
"DateUntil": "2020-03-08",
}
Antwort vom ERP-System
Das ERP-System liefert dem Shop fest vorgegebene und im Shop frei konfigurierbare Daten zurück.
Fest vorgegebene Kopfdaten
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ID | 128 | ja | String | Eindeutige ID der Bestellung, z. B. die Bestellnummer |
Type |
| ja | Integer | Ein Typ, der die gesendeten Daten spezifiziert. Der Typ wird vom ERP-System vergeben/verwaltet und ist im Shop frei konfigurierbar. Beispiel: 1: Rechnung |
FileAvailable |
| ja | Boolean | Dieser Parameter gibt an, ob zur Bestellung eine PDF-Datei (z. B. die Rechnung/Stornierung etc.) zur Verfügung steht. „true“ oder „false“ |
ReturnsFileAvailable |
| nein | Boolean | Nur, wenn Retoure angemeldet wird. Dieser Parameter gibt an, ob bei einer angemeldeten Retoure eine PDF-Datei (z. B. Retourenaufkleber etc.) zur Verfügung steht. „true“ oder „false“ |
CancellationFileAvailable |
| nein | Boolean | Nur, wenn ein Storno durchgeführt wird. Dieser Parameter gibt an, ob bei einem durchgeführten Storno eine PDF-Datei zur Verfügung steht. „true“ oder „false“ |
BankTransferRefund |
| nein | Boolean | Nur bei einer möglichen Retoure/Storno. Dieser Parameter gibt an, ob bei einer möglichen Retoure/Storno die Erstattung per Banküberweisung erfolgt und die Bankverbindung vom Besteller abgefragt werden soll. „true“ oder „false“ Bei true kann das ERP-System dem Shop die hinterlegten Bankdaten des Kunden zusenden. Dann werden die Bank-Felder mit diesen Daten vorbelegt. |
RefundBankName | 128 | nein | String | Name des Kreditinstitutes für die Erstattung |
RefundBankOwner | 128 | nein | String | Kontoinhaber für die Erstattung |
RefundBankIBAN | 128 | nein | String | IBAN für die Erstattung |
RefundBankBIC | 128 | nein | String | BIC für die Erstattung |
Im Shop frei konfigurierbare Kopfdaten
Im Shop werden maximal 1000 verschiedene Kopfdaten H1...H1000 unterstützt.
Die maximale Länge eines einzelnen Datensatzes beträgt 4096 Zeichen.
Die Kopfdaten sind im Shop (optional je Typ) frei konfigurierbar.
Beispiel einer Konfigurationsdatei im Shop unabhängig des Daten-Typs:
<HeadData>
H1 = Kundennummer
H2 = Auftragsdatum
H3 = Auftragsnummer
H4 = Rechnungsnummer
...
</HeadData>
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
Name | 5 | ja | String | Der Name des Kopfdatenfeldes H1...H1000 |
Value | 4096 je Value | ja | String | Ein oder mehrere Werte die dem Kopfdatenfeld zugeordnet sind. Bitte beachten: Dieser Parameter darf maximal 10-mal auftreten! |
Fest vorgegebene Positionsdaten
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
PositionID | 128 | Ja | String | Eindeutige ID der Position, z. B. die Artikelnummer oder laufende Positionsnummer |
OrderQuantity |
| Ja | Integer | Bestellmenge |
MaxReturns |
| Ja | Integer | Maximale Stückzahl der möglichen Retouren. 0 = Keine Retoure möglich |
PartReturns |
| Ja | Boolean | true=Teil-Retouren möglich false= keine Teil-Retouren möglich nur „MaxReturns“ möglich Beispiel: Beispiel: |
MaxCancellations |
| Ja | Integer | Maximale Stückzahl der möglichen Stornos. 0 = Kein Storno möglich |
PartCancellations |
| Ja | Boolean | true=Teil-Stornos möglich false= keine Teil-Stornos möglich nur „MaxCancellations“ möglich. Beispiel: Beispiel: |
Im Shop frei konfigurierbare Positionsdaten
Im Shop werden maximal 1000 verschiedene Positionsdaten P1...P1000 unterstützt.
Die maximale Länge eines einzelnen Datensatzes beträgt 4096 Zeichen.
Die Positionsdaten sind im Shop (optional je Typ) frei konfigurierbar.
Beispiel einer Konfigurationsdatei im Shop unabhängig des Daten-Typs:
<PositionData>
P1 = Artikelnummer
P2 = Bezeichnung
P3 = Farbe
P4 = Gewicht
P5 = Stückpreis
...
</PositionData>
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
Name | 5 | ja | String | Der Name des Positionsdatenfeldes P1...P1000 |
Value | 4096 je Value | ja | String | Ein oder mehrere Werte die dem Positionsdatenfeld zugeordnet sind. Bitte beachten: |
Antwort /GetOrderList:
[
{
"FileAvailable": true,
"HeadData": [
{
"Name": "H1",
"Value": "015552222"
},
{
"Name": "H2",
"Value": "10,99"
},
{
"Name": "H3",
"Value": "19,99"
},
...
],
"ID": "90909009909009",
"Type": 1
},
...
]
Übertragung einer einzelnen Bestellung /GetOrder
Anfrage vom Shop für eine einzelne Bestellung
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID, in der die Bestellungen angezeigt werden. |
CustomerSubshopIDs | 128 je ID | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
Type |
| ja | Integer | Dieser Wert wurde vom ERP-System in der Liste geliefert und wird hier zurückgegeben. |
ID | 128 | ja | String | Dieser Wert wurde vom ERP-System in der Liste geliefert und wird hier zurückgegeben. |
Anfrage /GetOrder:
{
"ShopID": "myshop",
"Password": "1234567890",
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
],
"ID": "90909009909009",
"SubshopID": "Deutsch",
"Type": 1
}
Antwort vom ERP-System /GetOrder:
(Siehe auch Kopfdaten und Positionsdaten)
{
"Type": 0,
"ID": "90909009909009",
"FileAvailable": true,
"ReturnFileAvailable": false,
"CancellationFileAvailable": false,
"BankTransferRefund": true,
"HeadData": [
{
"Name": H1,
"Value": Kundennummer
},
{
"Name": H2,
"Value": Auftragsdatum
},
...
],
"Positions": [
{
"MaxCancellations": 0,
"MaxReturns": 1,
"OrderQuantity": 1,
"PartCancellations": true,
"PartReturns": false,
"PositionData": [
{
"Name": "P1",
"Value": "Artikelnummer"
},
{
"Name": "P2",
"Value": "Bezeichnung"
},
...
],
"PositionID": "p0"
},
{
"MaxCancellations": 1,
"MaxReturns": 2,
"OrderQuantity": 2,
"PartCancellations": true,
"PartReturns": false,
"PositionData": [
{
"Name": "P1",
"Value": "Artikelnummer"
}
],
"PositionID": "p1"
},
...
]
}
Übertragung der möglichen Begründungen bei Storno/Retoure
Optional kann das ERP-System in den Kopfdaten des Auftrags die möglichen Begründungen mitliefern, die der Kunde im Shop bei einem Storno oder einer Retoure auswählen kann.
Dies überschreibt alle in der Konfiguration des Shops hinterlegten Begründungen.
Zum Überschreiben der Storno-Begründungen muss das CancellationReasons-Array übertragen werden.
Zum Überschreiben der Retoure-Begründungen muss das ReturnReasons-Array übertragen werden.
{
"Type": 0,
"ID": "90909009909009",
"FileAvailable": true,
"ReturnFileAvailable": false,
"CancellationFileAvailable": false,
"BankTransferRefund": true,
"CancellationReasons": [
{
"Code": 0,
"Text": "Ohne Begründung"
},
{
"Code": 1,
"Text": "Falsch bestellt"
},
...
],
"ReturnReasons": [
{
"Code": 0,
"Text": "Ohne Begründung"
},
{
"Code": 1,
"Text": "Falsch bestellt"
},
...
],
...
}
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
Code |
| ja | Integer | Der Code der Begründung |
Text | 1024 | ja | String | Der lesbare Text der Begründung, der im Shop zur Auswahl steht. |
Übertragung einer PDF-Datei
Wird z. B. eine Rechnung per PDF angefordert, so liefert das ERP-System alle Daten einer Bestellung:
komplette Rechnungsadresse
komplette Lieferadresse
alle Artikel der Bestellung
Gesamtsumme
Zahlungsart
Versandart/Zusteller
usw.
Der Shop übergibt dem ERP-System die eindeutige ID der Bestellung und den Typ, den das ERP-System in der Bestellung gesendet hat.
Retouren
Wird eine Retoure angemeldet, dann kann das ERP-System dem Shop eine PDF-Datei (Retourenaufkleber etc.) zur Verfügung stellen und gibt dies dem Shop in den Kopfdaten bekannt.
{
"Type": 0,
"ID": "90909009909009",
"FileAvailable": true,
"ReturnFileAvailable": true,
"CancellationFileAvailable": false,
"BankTransferRefund": false,
...
}
Die PDF-Datei einer Retoure wird mit dem Typ „1001“ angefordert.
Stornos
Wird ein Storno durchgeführt, dann kann das ERP-System dem Shop eine PDF-Datei (Stornobestätigung etc.) zur Verfügung stellen und gibt dies dem Shop in den Kopfdaten bekannt.
{
"Type": 0,
"ID": "90909009909009",
"FileAvailable": true,
"ReturnFileAvailable": false,
"CancellationFileAvailable": true,
"BankTransferRefund": false,
...
}
Die PDF-Datei eines Stornos wird mit dem Typ „1002“ angefordert.
Anfrage vom Shop für eine einzelne Bestellung als PDF-Datei /GetFile
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID, in der die Bestellungen angezeigt werden. |
CustomerSubshopIDs | 128 je ID | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
Type |
| ja | Integer | Dieser Wert wurde vom ERP-System in der Liste geliefert und wird hier zurückgegeben.
Bitte beachten Sie: Liegt ein Retouren-PDF vor und meldet der Kunde eine Retoure an, dann sendet der Shop den Typ „1001“ und fordert damit das Retouren-Dokument an. Analog wird bei einem durchgeführten Storno der Typ „1002“ übergeben. |
ID | 128 | ja | String | Dieser Wert wurde vom ERP-System geliefert und wird hier zurückgegeben. |
Anfrage /GetFile:
{
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
],
"ID": "90909009909009",
"Password": "1234567890",
"ShopID": "myshop",
"SubshopID": "Deutsch",
"Type": 1
}
Antwort vom ERP-System als PDF-Datei /GetFile
Das ERP-System liefert folgende Daten zurück:
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
FileName | 128 | ja | String | Name der PDF-Datei, z. B. 12345.pdf |
FileData | 2 MByte | ja | String | Base64-kodierte PDF-Daten |
Antwort vom ERP-System /GetFile:
{
"FileName": "1234567890.pdf",
"FileData": "Base64-kodierte PDF-Daten"
}
Der Dateiname sollte vom ERP-System möglichst eindeutig generiert werden, z. B. aus der Rechnungsnummer und der Endung „pdf“. Er sollte keine Sonderzeichen oder Leerzeichen beinhalten.
Das Dateiformat muss nicht notwendigerweise PDF sein. Prinzipiell kann jedes Format gesendet werden, welches eine möglichst hohe Verbreitung unter den Internet-Usern hat. Derzeit ist PDF die beste Wahl.
Storno/Retoure von Positionen einer Bestellung
Wie oben beschrieben gibt das ERP-System je Position bekannt, ob und wie viele Stücke storniert/retourniert werden können.
{
...
"Positions": [
{
"MaxCancellations": 0,
"MaxReturns": 2,
"OrderQuantity": 2,
"PartCancellations": false,
"PartReturns": true,
"PositionData": [
{
"Name": "P3",
"Value": "asdf0000"
}
],
"PositionID": "1"
},
...
Somit könnte ein Besteller z. B. die erste Position stornieren und die 2. Position retournieren, falls die 2. Position bei einer Teillieferung bereits ausgeliefert wurde.
Eine Position kann entweder storniert oder retourniert werden. Beides gleichzeitig ist nicht möglich.
Storno je Position
Übergibt das ERP-System den Wert „0“, dann wird kein Storno angeboten. Ansonsten wird eine
Storno-Checkbox
Mengeneingabefeld, falls MaxCancellations > 1
DropDown-Liste für eine Begründung
angeboten.
Retoure je Position
Übergibt das ERP-System den Wert „0“, dann wird keine Retoure angeboten. Ansonsten wird eine
Retouren-Checkbox
Mengeneingabefeld, falls MaxReturns > 1
DropDown-Liste für eine Begründung
angeboten.
Der Shop bietet optional zu jeder Position eine frei konfigurierbare DropDown-Liste an, mittels derer der Kunde eine Begründung angeben kann. Dem ERP-System wird hierzu ein Code übermittelt.
Beispiel für Retouren:
0=keine Begründung angegeben
1=Qualität gefällt nicht
2=Falscher Artikel geliefert
3=zu spät geliefert
etc.
Der Code und die Texte werden vom ERP-System vorgegeben und im Shop hinterlegt.
Abfragen der Bankverbindung
Meldet das ERP-System dem Shop, dass die Bankverbindung für die Erstattung abgefragt werden soll (BankTransferRefund=true), so werden 4 weitere Eingabefelder als Pflichtfelder
Name der Bank
Kontoinhaber
IBAN
BIC
angezeigt.
Senden einer Retoure oder eines Stornos an das ERP-System /CancelOrder
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID, in der die Bestellungen angezeigt werden. |
CustomerSubshopIDs | 128 je ID | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
ID | 128 | ja | String | Dieser Wert wurde vom ERP-System für die Bestellung übergeben und wird hier zurückgegeben. |
PositionID | 128 | ja | String | Dieser Wert wurde vom ERP-System für die Position übergeben und wird hier zurückgegeben. |
CancelType |
| ja | Integer | 1=Storno 2=Retoure |
Quantity |
| Ja | Integer | Menge/Stückzahl pro Position, die retourniert/storniert werden soll. |
ReasonCode |
| Nein | Integer | Code der Begründung. |
RefundBankName | 128 | nein | String | Name des Kreditinstitutes, falls die Erstattung per Banküberweisung erfolgt |
RefundBankOwner | 128 | nein | String | Kontoinhaber, falls die Erstattung per Banküberweisung erfolgt |
RefundBankIBAN | 128 | nein | String | IBAN, falls die Erstattung per Banküberweisung erfolgt |
RefundBankBIC | 128 | nein | String | BIC, falls die Erstattung per Banküberweisung erfolgt |
Anfrage /CancelOrder:
{
"ShopID": "myshop",
"Password": "1234567890",
"SubshopID": "Deutsch",
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
],
"ID": "90909009909009",
"RefundBankBIC": "BIC",
"RefundBankIBAN": "IBAN",
"RefundBankName": "Bankname",
"RefundBankOwner": "Kontoinhaber",
"Positions": [
{
"PositionID": "1",
"CancelType": 1,
"ReasonCode": 0,
"Quantity": 1
},
...
]
}
Bitte beachten Sie:
Es werden nur die Positionen an das ERP-System gesendet, die storniert/retourniert werden sollen.
Antwort vom ERP-System /CancelOrder
Das ERP-System liefert alle Daten (Kopf- und alle Positionsdaten) der Bestellung zurück.
Zusätzliche Kopfdaten
In den Kopfdaten kann das ERP-System jetzt und in späteren Anfragen zu dieser Bestellung mitteilen, dass eine Retouren-PDF-Datei, bzw. Storno-PDF-Datei abgeholt werden kann.
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ReturnsFileAvailable |
| nein | Boolean | Nur, wenn Retoure angemeldet wurde. Dieser Parameter gibt an, ob bei einer angemeldeten Retoure eine PDF-Datei (z. B. Retourenaufkleber etc.) zur Verfügung steht. „true“ oder „false“ |
CancellationFileAvailable |
| nein | Boolean | Nur, wenn ein Storno durchgeführt wurde. Dieser Parameter gibt an, ob bei einem durchgeführten Storno eine PDF-Datei zur Verfügung steht. „true“ oder „false“ |
Zusätzliche Positionsdaten
Das ERP-System meldet für jede Position, welche Aktion durchgeführt wurde und ob die Aktion erfolgreich bzw. nicht erfolgreich war. Diese Werte sollten nur einmal gesendet werden. Bei späteren Anfragen sollten diese dann entfallen.
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
CancelType |
| nein | Integer | 1=Storno |
CancelErrCode |
| nein | Integer | Ein Fehlercode >0: Fehler (wird vom ERP-System verwaltet) |
CancelErrMsg | 1024 | nein | String | Eine optionale Fehlermeldung vom ERP-System |
Bitte beachten Sie:
Wurde eine Position erfolgreich retourniert, so muss das ERP-System die Werte für
"MaxReturns": 0,
"PartReturns": false,
in dieser Antwort (und allen späteren Antworten) entsprechend anpassen, damit der Besteller nicht erneut retournieren kann. Das gleiche gilt für eine erfolgreiche Stornierung.
Außerdem sollte das ERP-System ab diesem Zeitpunkt das Datum und die Uhrzeit der Stornierung/Retoure übergeben, damit diese Informationen dem Besteller bei späteren Abfragen angezeigt werden können.
Antwort /CancelOrder (Beispiel: Besteller hat 2. Position storniert und 3. Position retourniert):
{
"Type": 0,
"BankTransferRefund": true,
"FileAvailable": true,
"ID": "90909009909009",
"HeadData": [
{
"Name": "H1",
"Value": "Kundennummer"
},
...
],
"Positions": [
{
"MaxCancellations": 2,
"MaxReturns": 0,
"OrderQuantity": 2,
"PartCancellations": true,
"PartReturns": false,
"PositionData": [
{
"Name": "P1",
"Value": "Artikelnummer”
},
...
],
"PositionID": "1"
},
{
"MaxCancellations": 0,
"MaxReturns": 0,
"OrderQuantity": 1,
"PartCancellations": false,
"PartReturns": false,
"CancelType": 1,
"CancelErrCode": 0,
"CancelErrMsg": "Position erfolgreich storniert",
"PositionData": [
{
"Name": "P1",
"Value": "Artikelnummer"
},
...
],
"PositionID": "2” },
{
"MaxCancellations": 0,
"MaxReturns": 0,
"OrderQuantity": 2,
"PartCancellations": false,
"PartReturns": false,
"CancelType": 2,
"CancelErrCode": 0,
"CancelErrMsg": "Retoure erfolgreich angemeldet",
"PositionData": [
{
"Name": "P3",
"Value": "asdf0003"
}
],
"PositionID": "3"
},
...
]
}
Übertragung der letzten Shop-Bestellnummer /GetLastOrderNumber
Damit der Shop die Bestellungen anzeigen kann, die noch nicht in das ERP-System importiert wurden, ist es erforderlich, dass das ERP-System dem Shop die letzte Shop-Bestellnummer mitteilt, welches das ERP-System importiert hat bzw. dem ERP-System bekannt ist.
Die Anfrage des Shops enthält folgende Parameter:
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID, in der die Bestellungen angezeigt werden. |
CustomerSubshopIDs | 128 | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
Anfrage vom Shop /GetLastOrderNumber:
{
"ShopID": "myshop",
"Password": "1234567890",
"SubshopID": "Deutsch",
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
]
}
Antwort vom ERP-System für die letzte Shop-Bestellnummer /GetLastOrderNumber
Das ERP-System liefert folgende Daten zurück:
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
LastOrderNumber | 64 | ja | String | Shop-Bestellnummer |
Antwort vom ERP-System /GetLastOrderNumber:
{
"LastOrderNumber": "1234567890"
}
Abfrage eines einzelnen Lagerbestandes (einer Filiale) /GetStockAmount
Diese Funktion eignet sich für die Abfrage in Echtzeit, ob ein Produkt in einer ausgewählten Filiale verfügbar ist.
Die Anfrage des Shops enthält folgende Parameter:
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID |
ProductNumber | 64 | ja | String | Artikelnummer |
BranchID | 64 | nein | String | Optionale Filial-ID |
Die Filial-ID ist optional. Wird keine Filial-ID übergeben, dann liefert das ERP-System den Lagerbestand des Artikels bzgl. des Subshops. Wird eine Filial-ID übergeben, dann liefert das ERP-System den Lagerbestand bzgl. der Filiale.
Anfrage vom Shop /GetStockAmount:
{
"ShopID": "myshop",
"Password": "1234567890",
"SubshopID": "Deutsch",
"ProductNumber": "1234567",
"BranchID": "123"
}
Antwort vom ERP-System für den einzelnen Lagerbestand /GetStockAmount
Das ERP-System liefert folgende Daten zurück:
Parameter | Max. Länge | Erforderlich | Datentyp | Bemerkung |
---|---|---|---|---|
StockAmount |
| ja | Integer | Lagerbestand |
Antwort vom ERP-System /GetStockAmount:
{
"StockAmount": 100
}
Übertragung von allgemeinen, zusätzlichen Kundendaten /GetCommonData
Bei diesen Informationen geht es nicht um Bestelldaten, sondern um zusätzliche, frei konfigurierbare Kundendaten, wie z. B. die angesammelten Bonuspunkte oder die Rabatte eines Kunden bei einem Kauf.
Die Anfrage des Shops enthält folgende Parameter:
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
ShopID | 128 | ja | String | Eine eindeutige Shop-ID. Die Shop-ID wird von der WEBSALE AG vergeben. |
Password | 128 | ja | String | Das REST-Passwort. Wird von der WEBSALE AG vergeben und muss vom ERP-System geprüft werden. Das ERP-System muss die Anfrage bei einem falschen Passwort ablehnen. |
SubshopID | 128 | ja | String | Eine eindeutige Subshop-ID |
CustomerSubshopIDs | 128 je ID | ja | String-Array | Liste der gültigen Subshops des Kunden |
CustomerID | 64 | ja | String | Eine eindeutige Kundennummer |
Type |
| nein | Integer | Die möglichen Werte legt das ERP-System fest. Ist der Typ 0, dann liefert das ERP-System alle allgemeinen Daten zurück. Bitte beachten: |
BillCountry | 3 | nein | String | Rechnungsland ISO 3166 (z. B. DEU) des Bestellers, falls im Shop bekannt. |
Anfrage vom Shop /GetCommonData:
{
"ShopID": "myshop",
"Password": "1234567890",
"SubshopID": "Deutsch",
"BillCountry": "DEU",
"CustomerID": "1001",
"CustomerSubshopIDs": [
"Deutsch"
],
"Type": 1
}
Antwort vom ERP-System für allgemeine Daten /GetCommonData
Das ERP-System liefert im Shop frei konfigurierbare Daten zurück.
Im Shop frei konfigurierbare Daten:
Im Shop werden maximal 1000 verschiedene Commondaten C1...C1000 unterstützt.
Die maximale Länge eines einzelnen Datensatzes beträgt 4096 Zeichen.
Commondaten sind im Shop (optional je Typ) frei konfigurierbar.
Beispiel einer Konfigurationsdatei im Shop unabhängig des Daten-Typs:
<CommonData>
C1 = Bonuspunkte
C2 = Kundenspezifische Rabatte nach Kalenderjahr
...
</CommonData>
Parameter | Max. Länge | Erfor-derlich | Datentyp | Bemerkung |
---|---|---|---|---|
Name | 5 | ja | String | Der Name des Commondatenfeldes C1...C1000 |
Value | 4096 | ja | String | Ein oder mehrere Werte, die dem Commondatenfeld zugeordnet sind. Bitte beachten: |
Antwort vom ERP-System /GetCommonData:
[
{
"Name": "C1",
"Value": "100"
},
{
"Name": "C2",
"Value": [
"umsatzabhängiger Kundenrabatt 2010: 5%",
"umsatzabhängiger Kundenrabatt 2011: 12%",
"umsatzabhängiger Kundenrabatt 2012: 5%",
"umsatzabhängiger Kundenrabatt 2013: 12%"
]
},
...
]