OpenXE/www/api/docs.raml

6901 lines
220 KiB
Plaintext
Raw Permalink Normal View History

2021-05-21 08:49:41 +02:00
#%RAML 1.0
title: Xentral-API
description: Die API befindet sich in ihrer Xentral-Installation im Unterordner `/www/api/`.
version: v1, v2
baseUri: http://www.example.com/api/{version}/
mediaType: application/json
securedBy: [ Digest ]
securitySchemes:
Digest:
type: Digest Authentication
displayName: Digest Authentifizierung
description: |
Die API unterstützt nur die Digest Authentifizierung.
Grundsätzlich empfehlen wir aber die zusätzliche Absicherung mit HTTPS-Verschlüsselung.
describedBy:
responses:
401:
description: |
Fehler bei der Authentifizierung werden immer mit dem HTTP-Status `401 Unauthorized` ausgeliefert.
**Beispiel-Response beim Zugriff ohne Authentifizierung:**
```
{
"error": {
"code": 7411,
"http_code": 401,
"message": "Unauthorized. You need to login.",
"href": "http://www.example.com/api/docs.html#error-7411"
}
}
```
documentation:
- title: Authentifizierung
content: |
Die REST-API unterstützt momentan nur die Digest Authentifizierung, da nur diese Authentifizierungsmethode auch
ohne HTTPS ausreichend Sicherheit bietet. Wir empfehlen grundsätzlich aber die zusätzliche Absicherung mit
HTTPS-Verschlüsselung.
## API-Account anlegen
In Xentral unter *Administration > Einstellungen > API-Account*. Dort auf *Neu* klicken.
Wichtig sind folgende Felder:
* *Aktiv*: Hacken muss gesetzt sein, damit API-Account genutzt werden kann.
* *App Name / Benutzername* und *Initkey / Passwort*: Benutzername und Kennwort für Digest-Authentifizierung.
- title: Authorisierung
content: |
Der Zugriff eines API-Accounts kann über Berechtigungen granular eingeschränkt werden.
## Berechtigungen bearbeiten
In Xentral unter *Administration > Einstellungen > API-Account* muss der gewünschte API-Account mit einem Klick
auf den Stift bearbeitet werden. Dort ist eine Liste der vorhandenen Berechtigungen.
### Alte API-Accounts
Alle API-Accounts, die vor der Einführung der Berechtigungen existierten, haben automatisch alle
Berechtigungen erhalten.
- title: Requests
content: |
## Ressourcen
Grundsätzlich können alle API-Ressourcen nach folgendem Schema angesprochen werden.
**Beispiel mit der `Addressen` Ressource:**
| Method | Endpoint | Aktion |
| --------- | ------------------ | ------------------------------ |
| `GET` | `/v1/adressen` | Alle Adressen auflisten |
| `GET` | `/v1/adressen/10` | Einzelne Adresse abrufen |
| `PUT` | `/v1/adressen/10` | Vorhandene Adresse bearbeiten |
| `POST` | `/v1/adressen` | Neue Adresse anlegen |
| `DELETE` | `/v1/adressen/10` | Vorhandene Adresse löschen |
Bei vereinzelten Ressourcen kann es Abweichungen von diesem Schema geben.
## Content-Types
Die API erwartet Anfragen mit dem Content-Type `application/json` oder `application/xml`.
## Zeichensatz
Alle Anfragen mit Nutzdaten müssen mit `UTF-8` kodiert sein.
## Nutzdaten
Nutzdaten müssen im Request-Body mitgeschickt werden. Nutzdaten sind nur bei POST- und PUT-Request zulässig;
also nur Anfragen bei denen Ressourcen (z.B. Adressen) angelegt oder bearbeitet werden.
**Beispiel HTTP-Request:**
```
PUT /v1/adressen/7 HTTP/1.1
Host: api.example.com
Accept: application/json
Content-Type: application/json; charset=utf-8
Authorization: Digest XXXXXXXXXXX
{
"name": "Schrauben Meier",
"telefon": "0987654321"
}
```
### Aufbau Nutzdaten
#### JSON
JSON-Nutzdaten werden ohne einheitliches Root-Element erwartet. Die zu ändernden Feldnamen werden in der ersten
Ebene erwartet.
**Beispiel JSON:**
```json
{
"name": "Schrauben Meier GmbH",
"strasse": "Dorfstrasse 123",
"ort": "Musterdorf",
"plz": "12345",
"telefon": "0987654321",
}
```
#### XML
XML-Nutzdaten müssen von einem Root-Element umschlossen sein. Der Name des Root-Elements kann beliebig lauten.
Die zu ändernden Feldnamen werden in der zweiten Ebene erwartet.
**Beispiel XML:**
```xml
<data>
<name>Schrauben Meier GmbH</name>
<strasse>Dorfstrasse 123</strasse>
<ort>Musterdorf</ort>
<plz>12345</plz>
<telefon>0987654321</telefon>
</data>
```
- title: Responses
content: |
Die API liefert Antworten im `JSON`- oder `XML`-Format aus; abhängig vom `Accept`-Header der Anfrage.
Es wird die `JSON`-Ausgabe bevorzugt, wenn der `Accept`-Header fehlt oder ein nicht unterstütztes Format aufweist.
## Content-Types
Antworten werden mit dem Content-Type `application/json` oder `application/xml` ausgeliefert; abhängig
vom gesendeten Format.
## Zeichensatz
Alle Antworten sind `UTF-8` kodiert.
## Response-Body
### Erfolgreiche Anfrage
Der Response-Body einer erfolgreichen Anfrage beinhaltet immer ein `data`-Property als Root-Element.
#### Einzelne Ressource
**Beispiel mit einzelnem Ergebnis:**
```
{
"data": {
"id": 1,
"title": "Bernhardt Bieber"
}
}
```
#### Mehrere Ressourcen
Anworten mit mehreren Ressourcen beinhalten zusätzlich ein `pagination` Root-Element.
**Beispiel mit mehreren Ergebnissen:**
```
{
"data": [
{
"id": 1,
"title": "Phillipp Pabst"
},
{
"id": 2,
"name": "Peter Pfaff"
}
],
"pagination": {
"items_total": 50,
"items_current": 20,
"items_per_page": 20,
"page_current": 1,
"page_last": 3
}
}
```
Die Paginierung lässt sich über die GET-Parameter `page` und `items` steuern.
### Fehler
Auch Fehler besitzen ein einheitliches Schema mit `error`-Property als Root-Element:
```
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
```
Fehler-Responses beinhalten in der Regel ein `code` Property. Jeder Code steht für einen spezifischen Fehler.
Im Helpdesk (oder dieser Dokumentation) ist zu jedem Code eine genaue Beschreibung und idealerweise
Lösungsvorschläge zu finden.
- title: Filter/Sortierung/Paginierung
content: |
Suchfilter, Sortierung und Paginierung stehen bei allen Endpunkten zur Verfügung die eine Liste zurückliefern.
## Filter
### Einfache Filter
Beispiel: `/resource?ausverkauft=1&typ=produkt`
Welche Filter-Parameter zur Verfügung stehen erfahren Sie in der jeweiligen Endpunkt-Beschreibung.
### Komplexe Filter
Komplexe Filter sind grundsätzlich bei allen Endpunkt verfügbar die eine Liste zurückliefern; unabhängig
von den einfachen Filtern.
Beispiele:
- `/resource?filter[0][property]=mwst_satz&filter[0][expression]=gte&filter[0][value]=10`
- `/resource?filter[0][property]=beschreibung&filter[0][value]=%Schraube%`
- `/resource?filter[0][property]=land&filter[0][value]=DE&filter[0][operation]=OR&filter[1][property]=land&filter[1][value]=AT`
Parameter:
- `property`\
Feld in dem gesucht werden soll (Pflichtangabe).
- `value`\
Wert nach dem gesucht werden soll (Pflichtangabe).
- `expression`\
Vergleichsoperator\
Mögliche Werte:
- `eq` entspricht **=**
- `not` entspricht **!=**
- `gt` entspricht **>**
- `gte` entspricht **>=**
- `lt` entspricht **<**
- `lte` entspricht **<=**
- `like` entspricht **LIKE**
- `not_like` entspricht **NOT LIKE**
Default-Wert: `like`
- `operation`\
Verknüpfungsart bei der Anwendung mehrerer Filter.\
Mögliche Werte: `and`, `or`.\
Default-Wert: `and`
## Sortierung
Welche Felder für die Sortierung zur Verfügung stehen, erfahren Sie in der jeweiligen Endpunkt-Beschreibung.
Ein Minuszeichen vor dem Feldnamen kehrt die Sortierung um.
Beispiel: `/resource?sort=titel,-projekt`
## Paginierung
| Parameter | Beschreibung | Default | Wertebereich |
| ---------- | -------------------------------- | -------- | -------------- |
| `page` | Auswahl der Seite | `1` | `1` bis `1000` |
| `items` | Anzahl der Ergebnisse pro Seite | `20` | `1` bis `1000` |
Beispiel: `/resource?page=2&items=5`
- title: Fehler-Codes
content: |
TODO: Erklärungen hinzufügen
## Auth-Fehler
### <a name="error-7411"></a> #7411 - Unauthorized
Zugriff ohne Authentifizierung. Authorization-Header fehlt komplett.
### <a name="error-7412"></a> #7412 - Digest header incomplete
Digest-Header unvollständig; benötigte Teile fehlen.
### <a name="error-7413"></a> #7413 - Api account missing
Es ist kein API-Account angelegt oder aktiv.
### <a name="error-7414"></a> #7414 - Api account invalid
Der verwendete API-Account ist nicht gültig. Eventuell wurde der Account auf inaktiv gestellt.
### <a name="error-7415"></a> #7415 - Digest validation failed
Die Prüfung der Digest-Authentifizierung ist fehlgeschlagen.
### <a name="error-7416"></a> #7416 - Digest nonce invalid
Server-Nonce ist auf Server nicht vorhanden. Mögliche Ursachen:
- Der Client hat einen beliebigen Nonce-Key mitgeschickt der dem Server nicht bekannt ist.
- Der Nonce-Key ist schon länger abgelaufen und wurde gelöscht. Abgelaufene Nonce-Keys werden nach einigen Tagen
gelöscht.
### <a name="error-7417"></a> #7417 - Digest nonce expired
Server-Nonce ist abgelaufen. Nonce-Keys sind maximal 24 Stunden gültig und danach muss die Authentifizierung neu
initialisiert werden. Beim erneuten Zugriff (auch schon beim Ausliefern des Fehlers) wird automatisch ein neuer
Nonce-Key erzeugt und dem Client mitgeteilt (im www-authenticate Header). Der Client muss bei den weiteren
Zugriffen den neuen Nonce-Key verwenden.
### <a name="error-7418"></a> #7418 - Auth username empty
Der Benutzername darf nicht leer sein.
### <a name="error-7419"></a> #7419 - Authorization type not allowed
Authorization-Header war vorhanden, aber die Authentifizierung-Methode ist nicht erlaubt. Vermutlich Zugriff mit
Basic-Auth.
### <a name="error-7420"></a> #7420 - Digest nonce count not matching
Fehler nicht möglich: Der Nonce-Count wird momentan nicht geprüft.
### <a name="error-7421"></a> #7421 - Missing Permission
API-Account hat nicht die benötigten Berechtigungen
## Routing-Fehler
### <a name="error-7431"></a> #7431 - Route not found
### <a name="error-7432"></a> #7432 - Method not allowed
### <a name="error-7433"></a> #7433 - API-Method not found
## Endpoint-Fehler
### <a name="error-7451"></a> #7451 - Bad Request
### <a name="error-7452"></a> #7452 - Resource not found
Mögliche Ursachen:
- Das Ergebnis wurde über Filter zu stark begrenzt.
- Beim Abrufen einer einzelnen Resource wurde eine nicht existierende ID angegeben.
- Über die Paginierung wurde eine zu hohe Seite eingestellt. Siehe `pagination`-Property; der Wert von
`page_current` darf nicht über dem von `page_last` liegen.
- Die entsprechende Datenbanktabelle hat keine Inhalte.
### <a name="error-7453"></a> #7453 - Validation error
Dieser Fehler kann nur beim Ändern oder Anlegen von Resourcen auftreten. Bei der Validierung der Eingabedaten
ist ein Fehler aufgetreten.
In diesem Fall beinhaltet der Error-Response das Property `details`, das Aufschluss über die fehlerhaften Felder
gibt.
### <a name="error-7454"></a> #7454 - Invalid argument
Es wurde ein unzulässiger Request-Parameter (GET-Parameter) verwendet z.B. ein Filter-Parameter der nicht
zulässig ist.
### <a name="error-7455"></a> #7455 - Malformed request body
Das JSON- oder XML-Dokument im Request-Body konnte nicht dekodiert werden. Ungültige Zeichen oder eine
fehlerhafte Struktur können die Ursache sein. Überprüfen Sie die Daten ggf. mit Online-Validatoren.
### <a name="error-7456"></a> #7456 - Content type not supported
Der Request-Body konnte nicht dekodiert werden, weil kein gültiger Content-Type übergeben wurde.
## Webserver-Konfiguration fehlerhaft
### <a name="error-7481"></a> #7481 - Webserver-Konfiguration fehlerhaft (nicht genauer beschrieben)
### <a name="error-7482"></a> #7482 - PATH_INFO ist nicht gesetzt oder leer
Die PHP-Variable `$_SERVER['PATH_INFO']` ist nicht gesetzt oder leer, obwohl die aufgerufene URL darauf
schließen lässt dass die Variable gefüllt sein müsste. Der Fehler deutet darauf hin dass die
Webserver-Konfiguration fehlerhaft ist. Sie können sich mit der <a href="#failsafe">Failsafe-Variante</a>
behelfen. Damit kann die API auch ohne eine spezielle Webserver-Konfiguration verwendet werden, z.B. auf einem
Webspace bei dem die Änderung der Webserver-Konfiguration eingeschränkt ist.
Zur Fehlerbehebung siehe Abschnitt <a href="#nginx">Nginx-Konfiguration</a> oder
<a href="#apache">Apache-Konfiguration</a>
- title: Debug-Modus
content: |
Im Auslieferungszustand gibt die REST-API bei Fehlern nur ausgewählte Fehlertypen zurück (siehe
<a href="#fehler_codes">Fehler-Codes</a>).
### Beispiel Fehler-Response; Debug-Modus inaktiv
```json
{
"error": {
"code": 7482,
"http_code": 500,
"message": "Webserver configuration incorrect. Pathinfo is invalid.",
"href": "http://www.example.com/api/docs.html#error-7482"
}
}
```
Zur Fehleranalyse kann der Debug-Modus aktiviert werden um zusätzliche Informationen über Request- und
Konfigurationsvariablen zu erhalten. Debug-Informationen werden nur beim Auftreten eines Fehlers angehangen.
### Beispiel Fehler-Response mit aktivierten Debug-Modus
```json
{
"error": {
"code": 7482,
"http_code": 500,
"message": "Webserver configuration incorrect. Pathinfo is invalid.",
"href": "http://www.example.com/api/docs.html#error-7482"
},
"debug": {
"router": {
"controllerClass": "Xentral\\Modules\\Api\\Controller\\Version1\\StartController",
"controllerAction": "indexAction",
"resourceClass": "Xentral\\Modules\\Api\\Resource\\Resource",
"routerParams": []
},
"request": {
"isFailsafe": false,
"pathInfo": {
"actual": "",
"expected": "/v1/adressen/123"
},
"info": {
"method": "PUT",
"requestUri": "/api/v1/adressen/123",
"fullUri": "http://www.example.com/api/v1/adressen/123"
},
"serverParams": {
// Ausgabe entfernt; wie PHP-Variable `$_SERVER`
},
"header": {
"Content-Type": "application/json",
"Authorization": "Digest .........",
"Host": "www.example.com",
"Accept": "application/json"
},
"getParams": [],
"postParams": [],
"additionalParams": []
}
}
}
```
## Debug-Modus aktivieren
**Der Debug-Modus ist nicht für Produktiv-Systeme geeignet und sollte nur zur Fehlersuche aktiviert werden.**
### Debug-Modus global aktivieren
In der Datei `/www/api/index.php` die Konstante `DEBUG_MODE` auf `true` stellen.
```php
define('DEBUG_MODE', true);
```
Der Debug-Modus ist dann global für alle API-Accounts aktiviert. Debug-Informationen werden aber nur beim
Auftreten eines Fehlers erzeugt.
- title: PHP Beispiel-Clients
content: |
## cURL
```php
if (!function_exists('curl_version')) {
throw new Exception('curl-Extension fehlt');
}
$api = array(
'url' => 'http://www.example.com/api/',
'resource' => 'v1/adressen?page=1&items=5',
'username' => 'Your-Username',
'password' => 'Your-Passwort',
);
$options = array(
CURLOPT_URL => $api['url'] . $api['resource'],
CURLOPT_HEADER => false,
CURLOPT_HTTPHEADER => array('Accept: application/json'), // oder 'application/xml'
CURLOPT_RETURNTRANSFER => true,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_HTTPAUTH => CURLAUTH_DIGEST, // Digest Authentifizierung
CURLOPT_USERPWD => $api['username'] . ':' . $api['password'],
);
$ch = curl_init();
curl_setopt_array($ch, $options);
$response = curl_exec($ch);
if (curl_errno($ch)) {
throw new Exception(curl_error($ch));
}
$contentType = curl_getinfo($ch, CURLINFO_CONTENT_TYPE);
$statusCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
$result = json_decode($response, true);
echo "<pre>";
echo "<h1>HTTP-Status: {$statusCode}</h1>";
echo "<h2>Content-Type: {$contentType}</h2>";
var_dump($result);
echo "</pre>";
if ($ch != null) {
curl_close($ch);
}
```
## Guzzle
```php
if (!class_exists('GuzzleHttp\Client')) {
throw new Exception('Guzzle konnte nicht gefunden werden');
}
$api = array(
'url' => 'http://www.example.com/api/',
'resource' => 'v1/adressen?page=1&items=5',
'username' => 'Your-Username',
'password' => 'Your-Passwort',
);
$client = new GuzzleHttp\Client(array(
'base_url' => $api['url'],
));
$options = array(
'headers' => array('Accept' => 'application/json'), // oder 'application/xml'
'auth' => array($api['username'], $api['password'], 'digest'), // Digest Authentifizierung
);
$request = $client->createRequest('GET', $api['resource'], $options);
$response = $client->send($request);
$contentType = $response->getHeader('Content-Type');
$statusCode = $response->getStatusCode();
$statusMsg = $response->getReasonPhrase();
$result = json_decode($response->getBody()->getContents(), true);
echo "<pre>";
echo "<h1>HTTP-Status: {$statusCode} {$statusMsg}</h1>";
echo "<h2>Content-Type: {$contentType}</h2>";
var_dump($result);
echo "</pre>";
```
- title: Webserver-Konfiguration
content: |
## <a name="apache"></a> Apache
Damit die API richtig funktioniert sollte `mod_rewrite` aktiviert sein.
Der Aufruf ohne `mod_rewrite` ist ebenfalls möglich, dann muss allerdings die index.php in der URL vorkommen:
z.B.: `/www/api/index.php/v1/adressen`
### mod_rewrite aktivieren
```
$ sudo a2enmod rewrite
Enabling module rewrite.
To activate the new configuration, you need to run:
systemctl restart apache2
$ sudo systemctl restart apache2
```
### .htaccess Einbindung erlauben
Bei Ubuntu- und Debian-basierten Betriebssystemen geschieht das für den gesamten Webserver in der Datei
`/etc/apache2/apache2.conf`. Dort nach folgendem Eintrag suchen:
```
<Directory /var/www/>
Options Indexes FollowSymLinks
AllowOverride None
Require all granted
</Directory>
```
Hier muss das `AllowOverride None` zu `AllowOverride All` geändert werden. Anschließend die Apache2-Konfiguration
neu einlesen mit: `sudo service apache2 reload`.
Wichtig: Diese Anpassung ist nur exemplarisch. Aus Sicherheitsgründen sollten Sie die Einstellung nicht für
den gesamten Webserver erlauben. Um die Einstellung für einzelne Webseites vorzunehmen, sollten sie die
entsprechende VHost-Konfiguration anpassen.
### Beispiel VHost-Konfiguration für Apache 2.4
```
<VirtualHost *:80>
# ServerName auskommentieren falls Sie per IP zugreifen
ServerName xentral.example.com
ServerAdmin webmaster@example.com
# Pfad zum www-Verzeichnis ihrer Xentral-Installation
DocumentRoot /var/www/xentral/www
<Directory /var/www/xentral/www/>
AllowOverride All
Require all granted
</Directory>
ErrorLog ${APACHE_LOG_DIR}/xentral-error.log
CustomLog ${APACHE_LOG_DIR}/xentral-access.log combined
</VirtualHost>
```
## <a name="nginx"></a> Nginx
### Beispiel-Konfiguration
```
server {
listen 80 default_server;
listen [::]:80 default_server;
root /var/www/xentral/www;
index index.php index.html index.htm;
server_name www.example.com;
location / {
# First attempt to serve request as file, then
# as directory, then fall back to displaying a 404.
try_files $uri $uri/ =404;
}
location /api/ {
# '/api/' befindet sich relativ zum Document-Root und muss ggf. angepasst werden.
try_files $uri $uri/ @xentral_api;
}
location @xentral_api {
# '/api/' befindet sich relativ zum Document-Root und muss ggf. angepasst werden.
rewrite ^/api/(.*)$ /api/index.php/$1 last;
}
location ~ [^/]\.php(/|$) {
# Path Info korrekt an PHP-Skript weitergeben
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
if (!-f $document_root$fastcgi_script_name) {
return 404;
}
# Mitigate https://httpoxy.org/ vulnerabilities
fastcgi_param HTTP_PROXY "";
# With php-fpm (or other unix sockets):
fastcgi_pass unix:/var/run/php/php-fpm.sock;
# With php-cgi (or other tcp sockets):
#fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
# deny access to .htaccess files, if Apache's document root concurs with nginx's one
location ~ /\.ht {
deny all;
}
}
```
Außerdem muss `cgi.fix_pathinfo` in der php.ini auf `1` gestellt sein (Default).
Quelle: <https://www.nginx.com/resources/wiki/start/topics/examples/phpfcgi/>
## <a name="failsafe"></a> Failsafe-Alternative
Sollte die Konfiguration des Webservers Probleme bereiten, oder aus anderen Gründen nicht möglich sein, so gibt
es die Möglichkeit die API ohne Anpassung der Webserver-Konfiguration zu nutzen.
Der Endpunkt wird dann nicht als Teil der Pfades übergeben, sondern als Query-Parameter `path`.
Beispiel: `/api/index.php?path=/v1/artikelkategorien&sort=bezeichnung`
- title: Standard API-Aufrufe
content: |
Es gibt auch die Möglichkeit die standard API über die neue URL abzurufen.
Struktur: `http://www.example.com/api/{Action}`
Beispiel: `http://www.example.com/api/ArtikelGet`
Eine Übersicht der möglichen Requests/Actions mit Beispielen:
<https://xentral.biz/helpdesk/api>
**In diesem Fall erwartet die API immer einen POST-Request und die Nutzdaten müssen im Request-Body
mitgeschickt werden.**
- title: Test-System
content: |
Um auf die API eines <a href="https://xentral.com/helpdesk/testsystem" target="_blank">Test-Systems</a>
zugreifen zu können, kann im HTTP-Header `MultiDb` der Datenbankname des Test-Systems angegeben werden.
Der Header muss bei jedem Request mitgeschickt werden.
### Beispiel HTTP-Request
```http
GET /api/v1/adressen HTTP/1.1
Host: www.example.com
Accept: application/json
MultiDb: xentral_test
```
/v1/aboartikel:
get:
displayName: Abo-Artikel abrufen
description: |
Endpunkt zum Abrufen von Abo-Artikeln.
Permission: `list_subscriptions`
queryParameters:
bezeichnung:
description: Suche nach Abo-Artikel-Bezeichnung (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_equals:
description: Suche nach Abo-Artikel-Bezeichnung (genaue Übereinstimmung)
type: string
required: false
bezeichnung_startswith:
description: Suche nach Abo-Artikel-Bezeichnung (Übereinstimmung am Anfang)
type: string
required: false
bezeichnung_endswith:
description: Suche nach Abo-Artikel-Bezeichnung (Übereinstimmung am Ende)
type: string
required: false
rabatt:
description: Suche nach Rabatt in Prozent (genaue Übereinstimmung)
type: number
multipleOf: 0.01
required: false
rabatt_gt:
description: Suche nach Rabatt in Prozent (Rabatt größer Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_gte:
description: Suche nach Rabatt in Prozent (Rabatt größer gleich Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_lt:
description: Suche nach Rabatt in Prozent (Rabatt kleiner Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_lte:
description: Suche nach Rabatt in Prozent (Rabatt kleiner gleich Suchwert)
type: number
multipleOf: 0.01
required: false
preis:
description: Suche nach Preis (genaue Übereinstimmung)
type: number
multipleOf: 0.0001
required: false
preis_gt:
description: Suche nach Preis (Preis größer Suchwert)
type: number
multipleOf: 0.0001
required: false
preis_gte:
description: Suche nach Preis (Preis größer gleich Suchwert)
type: number
multipleOf: 0.0001
required: false
preis_lt:
description: Suche nach Preis (Preis kleiner Suchwert)
type: number
multipleOf: 0.0001
required: false
preis_lte:
description: Suche nach Preis (Preis kleiner gleich Suchwert)
type: number
multipleOf: 0.0001
required: false
menge:
description: Suche nach Menge (Menge Übereinstimmung)
type: integer
required: false
menge_gt:
description: Suche nach Menge (Menge größer Suchwert)
type: integer
required: false
menge_gte:
description: Suche nach Menge (Menge größer gleich Suchwert)
type: integer
required: false
menge_lt:
description: Suche nach Menge (Menge kleiner Suchwert)
type: integer
required: false
menge_lte:
description: Suche nach Menge (Menge kleiner gleich Suchwert)
type: integer
required: false
startdatum:
description: Suche nach Startdatum (Startdatum Übereinstimmung)
type: string
required: false
startdatum_gt:
description: Suche nach Startdatum (Startdatum größer Suchwert)
type: string
required: false
startdatum_gte:
description: Suche nach Startdatum (Startdatum größer gleich Suchwert)
type: string
required: false
startdatum_lt:
description: Suche nach Startdatum (Startdatum kleiner Suchwert)
type: string
required: false
startdatum_lte:
description: Suche nach Startdatum (Startdatum kleiner gleich Suchwert)
type: string
required: false
enddatum:
description: Suche nach Enddatum (Enddatum Übereinstimmung)
type: string
required: false
enddatum_gt:
description: Suche nach Enddatum (Enddatum größer Suchwert)
type: string
required: false
enddatum_gte:
description: Suche nach Enddatum (Enddatum größer gleich Suchwert)
type: string
required: false
enddatum_lt:
description: Suche nach Enddatum (Enddatum kleiner Suchwert)
type: string
required: false
enddatum_lte:
description: Suche nach Enddatum (Enddatum kleiner gleich Suchwert)
type: string
required: false
waehrung:
description: Suche nach Waehrungscode (ISO3; genaue Übereinstimmung)
type: string
required: false
preisart:
description: |
Suche nach Preisart
(Gültige Werte `monat`, `monatx`, `jahr`, `wochen`, `30tage`, `360tage` oder `einmalig`)
type: string
required: false
dokumenttyp:
description: Suche nach Dokument-Typ (Gültige Werte `rechnung` oder `auftrag`)
type: string
required: false
artikel:
description: Suche nach Artikel-ID (genaue Übereinstimmung)
type: integer
required: false
adresse:
description: Suche nach Adressen-ID (genaue Übereinstimmung)
type: integer
required: false
kundennummer:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
gruppe:
description: Suche nach Abogruppen-ID (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Suche nach Projekt-ID (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=-bezeichnung,rabatt`)
Verfügbare Felder: `bezeichnung`, `rabatt`, `preis`, `menge`, `startdatum`, `enddatum`,
`abgerechnet_bis`, `reihenfolge`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=artikel`)
Verfügbare Includes: `gruppe`, `artikel`, `adresse`, `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Abo-Artikel anlegen
description: |
Abo-Artikel anlegen
Permission: `create_subscription`
body:
application/json:
properties:
artikelnummer:
description: Artikelnummer (Pflichfeld)
required: true
type: string
bezeichnung:
description: Name des Abo-Artikels (Pflichtfeld)
required: true
type: string
beschreibung:
description: Abo-Artikel-Beschreibung
required: false
type: string
beschreibung_ersetzen:
description: |
Wenn `1`, wird nur die Beschreibung von hier ohne Artikelbeschreibung aus den Stammdaten
angezeigt. (Default `0`)
required: false
type: integer
startdatum:
description: Erstes Startdatum (Format `YYYY-MM-DD`) (Default = Aktuelles Datum)
required: false
type: date-only
enddatum:
description: Enddatum (Format `YYYY-MM-DD`) (Default `0000-00-00`)
required: false
type: date-only
preisart:
description: |
Zulässige Werte `monat`, `monatx`, `jahr`, `wochen`, `einmalig`, `30tage`, `360tage`
(Default `monat`)
required: false
type: string
zahlzyklus:
description: abhängig von `preisart` (Default `1`)
required: false
type: integer
dokumenttyp:
description: Automatisch anlegen als Auftrag oder Rechnung.
Zulässige Werte `rechnung`, `auftrag` (Default `rechnung`)
required: false
type: string
preis:
description: Netto Artikelpreis (Default `0.00`)
required: false
type: number
multipleOf: 0.0001
menge:
description: Artikelmenge (Default `0`)
required: false
type: number
multipleOf: 0.01
rabatt:
description: Rabatt in Prozent (Default `0.00`)
required: false
type: number
multipleOf: 0.01
waehrung:
description: Währung; dreistelliger ISO-Code (Default `EUR`)
required: false
type: string
gruppe:
description: Abo-Gruppen-ID (Default `0`)
required: false
type: integer
adresse:
description: |
Adressen-ID (Default `0`)
Wird überschrieben wenn Feld `kundennummer` gefüllt ist.
required: false
type: integer
kundennummer:
description: |
Kundennummer (kein Default)
Wenn gefüllt, wird Adress-ID ermittelt und in Feld `adresse` geschrieben.
required: false
type: string
projekt:
description: |
Projekt-ID (Default `0`)
Die erstellte Rechnung läuft auf dieses Projekt
required: false
type: integer
reihenfolge:
description: |
Wenn mehrere Artikel in einer Rechnung vorkommen, kann die Reihenfolge der Artikel damit
angepasst werden (Default `1`)
required: false
type: integer
example: |
{
"bezeichnung": "Abo-Artikel 001",
"artikelnummer": "700006",
"preis": 9.52,
"zahlzyklus": 2,
"preisart": "wochen",
"kundennummer": "10001"
}
responses:
201:
description: Request erfolgreich; Angelegter Abo-Artikel wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 21,
"bezeichnung": "Abo-Artikel 001",
"beschreibung": "",
"beschreibung_ersetzen": 0,
"startdatum": "2019-05-27",
"enddatum": "0000-00-00",
"abgerechnet_bis": "0000-00-00",
"zahlzyklus": 2,
"preis": "9.5200",
"rabatt": "0.00",
"waehrung": "EUR",
"menge": 0,
"preisart": "wochen",
"dokumenttyp": "rechnung",
"artikel": 6,
"gruppe": 0,
"adresse": 3,
"kundennummer": "10000",
"reihenfolge": 1,
"projekt": 0
}
}
/{id}:
description: Einzelnen Abo-Artikel abrufen oder bearbeiten.
uriParameters:
id:
type: integer
description: Abo-Artikel-ID
get:
displayName: Einzelnen Abo-Artikel abrufen
description: |
Einzelnen Abo-Artikel abrufen
Permission: `edit_subscription`
put:
displayName: Abo-Artikel bearbeiten
description: |
Abo-Artikel bearbeiten (Felder siehe "Abo-Artikel anlegen")
Permission: `view_subscription`
body:
application/json:
example: |
{
"bezeichnung": "Abo-Artikel 001",
"beschreibung_ersetzen": 0,
"startdatum": "2019-01-01",
"enddatum": "2019-12-31",
"rabatt": "3.00",
"zahlzyklus": 1,
"waehrung": "EUR",
"preisart": "wochen",
"dokumenttyp": "rechnung",
"kundennummer": "10000"
}
responses:
200:
description: Request erfolgreich; Aktualisierter Abo-Artikel wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 1,
"bezeichnung": "Abo-Artikel 001",
"beschreibung": "",
"beschreibung_ersetzen": 0,
"startdatum": "2019-01-01",
"enddatum": "2019-12-31",
"abgerechnet_bis": "2019-07-31",
"zahlzyklus": 1,
"preis": "0.17",
"rabatt": "3.00",
"waehrung": "EUR",
"menge": 100,
"preisart": "wochen",
"dokumenttyp": "rechnung",
"artikel": 2,
"gruppe": 1,
"adresse": 3,
"kundennummer": "10000",
"reihenfolge": 1,
"projekt": 0
}
}
delete:
displayName: Abo-Artikel löschen
description: |
Endpunkt zum Löschen von Abo-Artikeln
Permission: `delete_subscription`
responses:
200:
description: Request erfolgreich; id des gelöschten Aboartikels wird zurückgegeben
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 1
}
}
404:
description: id wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7452"
}
}
/v1/abogruppen:
get:
displayName: Abo-Gruppen abrufen
description: |
Endpunkt zum Abrufen von Abo-Gruppen
Permission: `list_subscription_groups`
queryParameters:
bezeichnung:
description: Suche nach bestimmter Abo-Gruppen-Bezeichnung (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_equals:
description: Suche nach bestimmter Abo-Gruppen-Bezeichnung (genaue Übereinstimmung)
type: string
required: false
bezeichnung_startswith:
description: Suche nach bestimmter Abo-Gruppen-Bezeichnung (Übereinstimmung am Anfang)
type: string
required: false
bezeichnung_endswith:
description: Suche nach bestimmter Abo-Gruppen-Bezeichnung (Übereinstimmung am Ende)
type: string
required: false
gruppensumme:
description: Suche nach Gruppensumme-Kennzeichen (1 = aktiv / 0 = inaktiv)
type: integer
required: false
rabatt:
description: Suche nach Rabatt in Prozent (genaue Übereinstimmung)
type: number
multipleOf: 0.01
required: false
rabatt_gt:
description: Suche nach Rabatt in Prozent (Rabatt größer Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_gte:
description: Suche nach Rabatt in Prozent (Rabatt größer gleich Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_lt:
description: Suche nach Rabatt in Prozent (Rabatt kleiner Suchwert)
type: number
multipleOf: 0.01
required: false
rabatt_lte:
description: Suche nach Rabatt in Prozent (Rabatt kleiner gleich Suchwert)
type: number
multipleOf: 0.01
required: false
projekt:
description: Suche nach bestimmter Projekt-ID (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=-bezeichnung,rabatt`)
Verfügbare Felder: `bezeichnung`, `rabatt`, `reihenfolge`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Abo-Gruppe anlegen
description: |
Abo-Gruppe anlegen
Permission: `create_subscription_group`
body:
application/json:
properties:
bezeichnung:
description: Name der Gruppe; erscheint auf der Rechnung (Pflichtfeld)
required: true
type: string
beschreibung:
description: Beschreibung der Gruppe; erscheint auf der Rechnung (optional)
required: false
type: string
rabatt:
description: Rabatt in Prozent (Default = 0.00)
required: false
type: number
multipleOf: 0.01
gruppensumme:
description: Nach jeder Auflistung der Artikel einer Gruppe, wird eine Gruppensumme auf dem Beleg
ausgegeben (1 = aktiv / 0 = inaktiv) (Default = 0)
required: false
type: integer
projekt:
description: |
Projekt-ID (Default = 0)
Die erstellte Rechnung läuft auf dieses Projekt
required: false
type: integer
reihenfolge:
description: Wenn mehrere Gruppen in einer Rechnung vorkommen, kann die Reihenfolge der Gruppen damit
angepasst werden (ab Version 18.3) (Default = 0)
required: false
type: integer
example: |
{
"bezeichnung": "Abo-Gruppe Verbrauchsmaterial",
"rabatt": 2.50,
"gruppensumme": 1,
"projekt": 1,
"reihenfolge": 123
}
responses:
201:
description: Request erfolgreich; Angelegte Abo-Gruppe wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 14,
"bezeichnung": "Abo-Gruppe Verbrauchsmaterial",
"beschreibung": "",
"rabatt": "2.50",
"gruppensumme": 1,
"projekt": 1,
"reihenfolge": 123
}
}
/{id}:
description: Einzelne Abo-Gruppe abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Abo-Gruppen-ID
get:
displayName: Einzelne Abo-Gruppe abrufen
description: |
Einzelne Abo-Gruppe abrufen
Permission: `view_subscription_group`
put:
displayName: Abo-Gruppe bearbeiten
description: |
Abo-Gruppe bearbeiten (Felder siehe "Abo-Gruppe anlegen")
Permission: `edit_subscription_group`
body:
application/json:
example: |
{
"bezeichnung": "Abo-Gruppe Verbrauchsmaterial",
"rabatt": 3.00
}
responses:
200:
description: Request erfolgreich; Aktualisierte Abo-Gruppe wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 14,
"bezeichnung": "Abo-Gruppe Verbrauschsmaterial",
"beschreibung": "",
"rabatt": "3.00",
"gruppensumme": 1,
"projekt": 1,
"reihenfolge": 123
}
}
/v1/adressen:
description: Adressen anlegen, bearbeiten und abrufen
get:
displayName: Adressliste abrufen
description: |
Adressenliste abrufen
Permission: `list_addresses`
queryParameters:
kundennummer:
description: Suche nach bestimmter Adresse mit Kundennummer
type: string
required: false
default: ""
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
responses:
200:
body:
application/json:
example: |
{
"data": [
{
"id": 7,
"typ": "firma",
"sprache": "deutsch",
"name": "Schrauben Meier",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "13245",
"telefon": "12345678",
"telefax": "",
"mobile": "",
"email": "schrauben@meiermusterdorf.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
},
{
"id": 8,
"...": "Ausgabe gekürzt"
}
],
"pagination": {
"items_total": 50,
"items_current": 20,
"items_per_page": 20,
"page_current": 1,
"page_last": 3
}
}
post:
displayName: Adressen anlegen
description: |
Neue Adresse anlegen
Permission: `create_address`
body:
application/json:
example: |
{
"typ": "firma",
"sprache": "deutsch",
"name": "Max Muster",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "12345",
"telefon": "0821123456789",
"telefax": "0821123456790",
"email": "info@maxmuellermuster.de",
"projekt": 1
}
responses:
200:
description: Request erfolgreich; Angelegte Adresse wird zurückgeliefert
body:
application/json:
example: |
{
"data": {
"id": 33,
"typ": "firma",
"sprache": "deutsch",
"name": "Max Muster",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "12345",
"telefon": "0821123456789",
"telefax": "0821123456790",
"mobile": "",
"email": "info@maxmuellermuster.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
}
}
/{id}:
description: Einzelne Adresse per ID abrufen
uriParameters:
id:
type: integer
description: Adressen-ID
get:
displayName: Einzelne Adresse abrufen
description: |
Einzelne Adresse abrufen
Permission: `view_address`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 7,
"typ": "firma",
"sprache": "deutsch",
"name": "Schrauben Meier GmbH",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "13245",
"telefon": "12345678",
"telefax": "",
"mobile": "",
"email": "schrauben@meiermusterdorf.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
}
}
404:
description: Adresse wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Adresse bearbeiten
description: |
Adresse bearbeiten
Permission: `edit_address`
body:
application/json:
example: |
{
"name": "Schrauben Meier GmbH",
"strasse": "Dorfstrasse 123",
"ort": "Musterdorf",
"plz": "12345",
"telefon": "0987654321"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Adresse wird zurückgeliefert
body:
application/json:
example: |
{
"data": {
"id": 7,
"typ": "firma",
"sprache": "deutsch",
"name": "Schrauben Meier GmbH",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Dorfstrasse 123",
"ort": "Musterdorf",
"plz": "12345",
"telefon": "0987654321",
"telefax": "",
"mobile": "",
"email": "schrauben@meiermusterdorf.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
}
}
/v2/adressen:
description: Adressen abrufen
get:
displayName: Adressenliste abrufen
description: |
Adressenliste abrufen
Permission: `list_addresses`
queryParameters:
projekt:
description: Suche nach bestimmter Projekt-ID (genaue Übereinstimmung)
type: integer
required: false
firma:
description: Suche nach bestimmter Firmen-ID (genaue Übereinstimmung)
type: integer
required: false
rolle:
description: Suche nach bestimmter Rolle (Wert `kunde` oder `lieferant`)
type: string
required: false
typ:
description: Suche nach bestimmtem Adresstyp (genaue Übereinstimmung)
type: string
required: false
sprache:
description: Suche nach bestimmter Sprache (genaue Übereinstimmung)
type: string
required: false
waehrung:
description: Suche nach bestimmtem Währungscode (genaue Übereinstimmung)
type: string
required: false
land:
description: Suche nach bestimmtem Ländercode (genaue Übereinstimmung)
type: string
required: false
kundennummer:
description: Suche nach bestimmter Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach bestimmter Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach bestimmter Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach bestimmter Kundennummer (Übereinstimmung am Ende)
type: string
required: false
lieferantennummer:
description: Suche nach bestimmter Lieferantennummer (ungefähre Übereinstimmung)
type: string
required: false
lieferantennummer_equals:
description: Suche nach bestimmter Lieferantennummer (genaue Übereinstimmung)
type: string
required: false
lieferantennummer_startswith:
description: Suche nach bestimmter Lieferantennummer (Übereinstimmung am Anfang)
type: string
required: false
lieferantennummer_endswith:
description: Suche nach bestimmter Lieferantennummer (Übereinstimmung am Ende)
type: string
required: false
mitarbeiternummer:
description: Suche nach bestimmter Mitarbeiternummer (ungefähre Übereinstimmung)
type: string
required: false
mitarbeiternummer_equals:
description: Suche nach bestimmter Mitarbeiternummer (genaue Übereinstimmung)
type: string
required: false
mitarbeiternummer_startswith:
description: Suche nach bestimmter Mitarbeiternummer (Übereinstimmung am Anfang)
type: string
required: false
mitarbeiternummer_endswith:
description: Suche nach bestimmter Mitarbeiternummer (Übereinstimmung am Ende)
type: string
required: false
email:
description: Suche nach bestimmter E-Mail-Adresse (ungefähre Übereinstimmung)
type: string
required: false
email_equals:
description: Suche nach bestimmter E-Mail-Adresse (genaue Übereinstimmung)
type: string
required: false
email_startswith:
description: Suche nach bestimmter E-Mail-Adresse (Übereinstimmung am Anfang)
type: string
required: false
email_endswith:
description: Suche nach bestimmter E-Mail-Adresse (Übereinstimmung am Ende)
type: string
required: false
freifeld[1-10]:
description: |
Suche nach bestimmtem Wert im Freifeld1 bis Freifeld10 (ungefähre Übereinstimmung)
(Beispiel: `freifeld3=42`)
type: string
required: false
freifeld[1-10]_equals:
description: |
Suche nach bestimmtem Wert im Freifeld1 bis Freifeld10 (genaue Übereinstimmung)
(Beispiel: `freifeld3_equals=42`)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=name,-kundennummer`)
Verfügbare Felder: `name`, `kundennummer`, `lieferantennummer`, `mitarbeiternummer`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
responses:
200:
body:
application/json:
example: |
{
"data": [
{
"id": 7,
"rolle": "lieferant",
"typ": "firma",
"sprache": "deutsch",
"name": "Schrauben Meier",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "13245",
"telefon": "12345678",
"telefax": "",
"mobile": "",
"email": "schrauben@meiermusterdorf.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
},
{
"id": 8,
"...": "Ausgabe gekürzt"
}
],
"pagination": {
"items_total": 50,
"items_current": 20,
"items_per_page": 20,
"page_current": 1,
"page_last": 3
}
}
/{id}:
description: Einzelne Adresse per ID abrufen
uriParameters:
id:
type: integer
description: Adressen-ID
get:
displayName: Einzelne Adresse abrufen
description: |
Einzelne Adresse abrufen
Permission: `view_address`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 7,
"rolle": "lieferant",
"typ": "firma",
"sprache": "deutsch",
"name": "Schrauben Meier GmbH",
"abteilung": "",
"unterabteilung": "",
"land": "DE",
"strasse": "Musterstrasse 6",
"ort": "Musterdorf",
"plz": "13245",
"telefon": "12345678",
"telefax": "",
"mobile": "",
"email": "schrauben@meiermusterdorf.de",
"projekt": 1,
"...": "Ausgabe gekürzt"
}
}
404:
description: Adresse wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/adresstyp:
description: Adresstyp anlegen, bearbeiten und abrufen
get:
displayName: Adresstypen abrufen
description: |
Adresstypen abrufen
Permission: `list_address_types`
queryParameters:
bezeichnung:
description: Adresstyp mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_exakt:
description: Adresstyp mit bestimmter Bezeichnung suchen (genaue Übereinstimmung)
type: string
required: false
type:
description: |
Nach bestimmten Typ filtern (genaue Übereinstimmung)
Mögliche Werte: `herr`, `frau`, `firma`
type: string
required: false
projekt:
description: Adresstyp eines Projekts filtern (genaue Übereinstimmung)
type: integer
required: false
netto:
description: Netto-Adresstypen filtern (1 = netto / 0 = brutto)
type: boolean
required: false
aktiv:
description: Aktive/Inaktive Adresstypen filtern (1 = aktiv / 0 = inaktiv)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=type,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `type`, `projekt`, `modul`, `aktiv`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Adresstyp anlegen
description: |
Adresstyp anlegen
Permission: `create_address_type`
body:
application/json:
properties:
bezeichnung:
description: Bezeichnung des Adresstyps
required: true
type: string
type:
description: Adresstyp; Mögliche Werte `herr`, `frau`, `firma`
required: true
type: string
projekt:
description: Projekt
required: false
type: integer
netto:
description: Anzeige Belege in Netto (`1` = netto / `0` = brutto)
required: false
type: integer
aktiv:
description: Aktiv (`1` = aktiv / `0` = inaktiv)
required: false
type: integer
example: |
{
"type": "herr",
"bezeichnung": "Gentleman",
"aktiv": 1,
"projekt": 1
}
responses:
201:
description: Request erfolgreich; Angelegter Adresstyp wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "5",
"type": "herr",
"bezeichnung": "Gentleman",
"projekt": "1",
"netto": "0",
"aktiv": "1"
}
}
/{id}:
description: Einzelner Adresstyp abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Adresstyp-ID
get:
displayName: Einzelnen Adresstyp abrufen
description: |
Einzelnen Adresstyp abrufen
Permission: `view_address_type`
queryParameters:
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "1",
"type": "firma",
"bezeichnung": "Firma",
"projekt": "0",
"netto": "1",
"aktiv": "1"
}
}
404:
description: Adresstyp wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Adresstyp bearbeiten
description: |
Adresstyp bearbeiten
Permission: `edit_address_type`
body:
application/json:
example: |
{
"type": "herr",
"bezeichnung": "Mr",
"aktiv": "1",
"projekt": "1"
}
responses:
200:
description: Request erfolgreich; Aktualisierter Adresstyp wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "5",
"type": "herr",
"bezeichnung": "Mr",
"projekt": "1",
"netto": "0",
"aktiv": "1"
}
}
/v1/artikel:
description: Artikel abrufen
get:
displayName: Artikelliste abrufen
description: |
Artikelliste abrufen
Permission: `list_articles`
queryParameters:
typ:
description: |
Artikel eines bestimmten Typs suchen (genaue Übereinstimmung)
Mögliche Werte: `produkt`, `gebuehr`
type: string
required: false
nummer:
description: Suche nach Artikeln mit bestimmter Artikelnummer (ungefähre Übereinstimmung)
type: string
required: false
nummer_equals:
description: Suche nach Artikeln mit bestimmter Artikelnummer (genaue Übereinstimmung)
type: string
required: false
nummer_startswith:
description: Suche nach Artikeln mit bestimmter Artikelnummer (Übereinstimmung am Anfang)
type: string
required: false
nummer_endswith:
description: Suche nach Artikeln mit bestimmter Artikelnummer (Übereinstimmung am Ende)
type: string
required: false
name_de:
description: Suche nach Artikeln mit bestimmtem deutschem Namen (ungefähre Übereinstimmung)
type: string
required: false
name_de_equals:
description: Suche nach Artikeln mit bestimmtem deutschem Namen (genaue Übereinstimmung)
type: string
required: false
name_de_startswith:
description: Suche nach Artikeln mit bestimmtem deutschem Namen (Übereinstimmung am Anfang)
type: string
required: false
name_de_endswith:
description: Suche nach Artikeln mit bestimmtem deutschem Namen (Übereinstimmung am Ende)
type: string
required: false
name_en:
description: Suche nach Artikeln mit bestimmtem englischem Namen (ungefähre Übereinstimmung)
type: string
required: false
name_en_equals:
description: Suche nach Artikeln mit bestimmtem englischem Namen (genaue Übereinstimmung)
type: string
required: false
name_en_startswith:
description: Suche nach Artikeln mit bestimmtem englischem Namen (Übereinstimmung am Anfang)
type: string
required: false
name_en_endswith:
description: Suche nach Artikeln mit bestimmtem englischem Namen (Übereinstimmung am Ende)
type: string
required: false
projekt:
description: Artikel nach Projekt filtern
type: integer
required: false
adresse:
description: Artikel nach Adresse filtern
type: integer
required: false
firma:
description: Artikel nach Firma filtern
type: integer
required: false
katalog:
description: Artikel nach Katalog filtern
type: integer
required: false
ausverkauft:
description: Suche nach ausverkauften Artikeln (1 = ausverkauft / 0 = nicht ausverkauft)
type: integer
required: false
startseite:
description: Suche nach Artikeln auf Startseite (1 = Startseite / 0 = nicht Startseite)
type: integer
required: false
topseller:
description: Suche nach Topseller-Artikeln (1 = Topseller / 0 = kein Topseller)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=typ,-nummer`)
Verfügbare Felder: `name_de`, `name_en`, `nummer`, `typ`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt,verkaufpreise`)
Verfügbare Includes: `projekt`, `verkaufspreise`, `dateien`, `lagerbestand`
###### Lagerbestand
**Beispiel Lagerartikel**
```json
"lagerbestand": {
"lagernd": 12,
"reserviert": 0,
"offene_auftraege": 33,
"offene_bestellungen": 1,
"berechneter_bestand": -21,
"verkaufbar": 0
}
```
**Beispiel Kein Lagerartikel**
```json
"lagerbestand": []
```
**Erklärung**
* **Lagernd**: Lagernde Menge über alle Lager, außer Sperrlager;
* **Reserviert**: Reservierte Menge
* **Offene Aufträge**: Menge aus offenen Aufträgen;
Es werden nur Aufträge mit dem Status FREIGEGEBEN berücksichtigt;
Aufträge mit Status ANGELEGT werden nicht berücksichtigt;
* **Offene Bestellungen**:
Es werden nur Bestellungen mit dem Status FREIGEGEBEN berücksichtigt;
Bestellungen mit Status ANGELEGT werden nicht berücksichtigt;
* **Berechneter Bestand**: *Lagernder Bestand* minus *Offene Aufträge*
* **Verkaufbar**: Wie *Berechneter Bestand*; wird nur nicht kleiner als `0`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
responses:
200:
body:
application/json:
example: |
{
"data": [
{
"id": 1,
"typ": "produkt",
"nummer": "700001",
"checksum": "",
"projekt": 1,
"inaktiv": "",
"ausverkauft": 0,
"warengruppe": "",
"name_de": "Schraube M10x20",
"name_en": "",
"kurztext_de": "",
"kurztext_en": "",
"beschreibung_de": "",
"beschreibung_en": "",
"uebersicht_de": "",
"uebersicht_en": "",
"links_de": "",
"links_en": "",
"startseite_de": "",
"startseite_en": "",
"standardbild": "",
"herstellerlink": "",
"hersteller": "",
"teilbar": "",
"...": "Ausgabe gekürzt"
},
{
"id": 2,
"...": "Ausgabe gekürzt"
}
]
}
# post:
# displayName: Artikel anlegen
# description: Neuen Artikel anlegen
# body:
# application/json:
# example: |
# {
# "name_de": "Name vom Artikel",
# "aktiv": "1",
# "hersteller": "Herstellername",
# "herstellernummer": "123",
# "ean": "234",
# "zolltarifnummer": "345",
# "mindestlager": "10",
# "mindestbestellung": "5",
# "gewicht": "1.5",
# "lagerartikel": "1",
# "einkaufspreise": {
# "staffelpreis": {
# "lieferantennummer": "70000",
# "ab_menge": "1",
# "bestellnummer": "123456789",
# "bezeichnunglieferant": "Artikel 123456789",
# "preis": "1.20",
# "waehrung": "EUR"
# }
# },
# "verkaufspreise": {
# "staffelpreis": {
# "ab_menge": "1",
# "preis": "2.20",
# "waehrung": "EUR"
# }
# }
# }
# responses:
# 200:
# description: Request erfolgreich; Angelegte Adresse wird zurückgeliefert
# body:
# application/json:
# example: |
# {
# "data": {
# "id": 20,
# "typ": "",
# "nummer": "1000005",
# "projekt": 0,
# "inaktiv": "0",
# "ausverkauft": "0",
# "name_de": "Name vom Artikel",
# "name_en": "",
# "kurztext_de": "",
# "kurztext_en": "",
# "beschreibung_de": "",
# "beschreibung_en": "",
# "hersteller": "Herstellername",
# "gewicht": "1.5",
# "lagerartikel": "1",
# "mindestlager": "10",
# "mindestbestellung": "5",
# "herstellernummer": "123",
# "ean": "234",
# "...": "Ausgabe gekürzt",
# "einkaufspreise": {
# "staffelpreis": {
# "ab_menge": "1.0000",
# "preis": "1.20000000",
# "waehrung": "EUR",
# "lieferantennummer": "70000",
# "projekt": "STANDARD",
# "bestellnummer": "123456789",
# "bezeichnunglieferant": "Artikel 123456789"
# }
# },
# "verkaufspreise": {
# "staffelpreis": {
# "ab_menge": "1.0000",
# "preis": "2.20000000",
# "vpe": "1",
# "waehrung": "EUR"
# }
# }
# }
# }
/{id}:
description: Einzelnen Artikel per ID abrufen
uriParameters:
id:
type: integer
description: Artikel-ID
get:
displayName: Einzelnen Artikel abrufen
description: |
Einzelnen Artikel abrufen
Permission: `view_article`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 1,
"typ": "produkt",
"nummer": "700001",
"checksum": "",
"projekt": 1,
"inaktiv": "",
"ausverkauft": 0,
"warengruppe": "",
"name_de": "Schraube M10x20",
"name_en": "",
"kurztext_de": "",
"kurztext_en": "",
"beschreibung_de": "",
"beschreibung_en": "",
"uebersicht_de": "",
"uebersicht_en": "",
"links_de": "",
"links_en": "",
"startseite_de": "",
"startseite_en": "",
"standardbild": "",
"herstellerlink": "",
"hersteller": "",
"teilbar": "",
"nteile": "",
"...": "Ausgabe gekürzt"
}
}
404:
description: Artikel wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
# put:
# displayName: Artikel bearbeiten
# description: Artikel bearbeiten
# body:
# application/json:
# example: |
# {
# "nummer": "100001",
# "name_de": "Name neu von Artikel",
# "aktiv": "1",
# "anabregs_text": "Text für Angebot, Auftrag, Rechnung usw.",
# "hersteller": "Herstellername",
# "herstellernummer": "123",
# "ean": "234",
# "zolltarifnummer": "345",
# "mindestlager": "10",
# "mindestbestellung": "5",
# "gewicht": "1.5",
# "lagerartikel": "1"
# }
# responses:
# 200:
# description: Request erfolgreich; Aktualisierter Artikel wird zurückgeliefert
# body:
# application/json:
# example: |
# {
# "data": {
# "id": 1,
# "typ": "produkt",
# "nummer": "700001",
# "checksum": "",
# "projekt": 1,
# "inaktiv": "",
# "ausverkauft": 0,
# "warengruppe": "",
# "name_de": "Schraube M10x20",
# "name_en": "",
# "kurztext_de": "",
# "kurztext_en": "",
# "beschreibung_de": "",
# "beschreibung_en": "",
# "uebersicht_de": "",
# "uebersicht_en": "",
# "links_de": "",
# "links_en": "",
# "startseite_de": "",
# "startseite_en": "",
# "standardbild": "",
# "herstellerlink": "",
# "hersteller": "",
# "teilbar": "",
# "nteile": "",
# "...": "Ausgabe gekürzt"
# }
# }
/v1/artikelkategorien:
description: Artikelkategorien anlegen, bearbeiten und abrufen
get:
displayName: Artikelkategorien abrufen
description: |
Artikelkategorien abrufen
Permission: `list_article_categories`
queryParameters:
parent:
description: Artikelkategorien mit Parent-ID filtern (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Artikelkategorien mit Projekt filtern (genaue Übereinstimmung)
type: integer
required: false
bezeichnung:
description: Artikelkategorie mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_exakt:
description: Artikelkategorie mit bestimmter Bezeichnung suchen (genaue Übereinstimmung)
type: string
required: false
id_ext:
description: Artikelkategorie mit externer ID filtern (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=parent,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `parent`, `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Artikelkategorie anlegen
description: |
Artikelkategorie anlegen
Permission: `create_article_category`
body:
application/json:
properties:
bezeichnung:
description: Name der Artikelkategorie
required: true
type: string
projekt:
description: Projekt-ID
required: false
type: integer
parent:
description: ID der Elternkategorie
required: false
type: integer
example: |
{
"bezeichnung": "Schaufelradbagger",
"projekt": 1,
"parent": 10
}
responses:
201:
description: Request erfolgreich; Angelegte Artikelkategorie wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 19,
"bezeichnung": "Schaufelradbagger",
"next_nummer": "",
"projekt": 1,
"geloescht": "0",
"externenummer": "0",
"parent": 10,
"steuer_erloese_inland_normal": "",
"steuer_aufwendung_inland_normal": "",
"steuer_erloese_inland_ermaessigt": "",
"steuer_aufwendung_inland_ermaessigt": "",
"steuer_erloese_inland_steuerfrei": "",
"steuer_aufwendung_inland_steuerfrei": "",
"steuer_erloese_inland_innergemeinschaftlich": "",
"steuer_aufwendung_inland_innergemeinschaftlich": "",
"steuer_erloese_inland_eunormal": "",
"steuer_erloese_inland_nichtsteuerbar": "",
"steuer_erloese_inland_euermaessigt": "",
"steuer_aufwendung_inland_nichtsteuerbar": "",
"steuer_aufwendung_inland_eunormal": "",
"steuer_aufwendung_inland_euermaessigt": "",
"steuer_erloese_inland_export": "",
"steuer_aufwendung_inland_import": "",
"steuertext_innergemeinschaftlich": null,
"steuertext_export": null,
"id_ext": 0
}
}
/{id}:
description: Einzelne Artikelkategorie abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Artikelkategorie-ID
get:
displayName: Einzelne Artikelkategorie abrufen
description: |
Einzelne Artikelkategorie abrufen
Permission: `view_article_category`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 1,
"bezeichnung": "1000000 Sonstiges",
"next_nummer": "1000000",
"projekt": 0,
"geloescht": "0",
"externenummer": "0",
"parent": 0,
"...": "Ausgabe gekürzt",
"id_ext": 0
}
}
404:
description: Artikelkategorie wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Artikelkategorie bearbeiten
description: |
Artikelkategorie bearbeiten
Permission: `edit_article_category`
body:
application/json:
example: |
{
"bezeichnung": "Schwimmbagger"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Artikelkategorie wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 19,
"bezeichnung": "Schwimmbagger",
"next_nummer": "",
"projekt": 1,
"geloescht": "0",
"externenummer": "0",
"parent": 0,
"...": "Ausgabe gekürzt",
"id_ext": 0
}
}
/v1/eigenschaften:
description: Eigenschaften für Artikel abrufen, erstellen, bearbeiten und löschen
get:
displayName: Eigenschaften abrufen
description: |
Eigenschaften abrufen
Permission: `list_property`
queryParameters:
artikel:
description: Artikel Id der die Eigenschaft zugewiesen ist (genaue Übereinstimmung) - Standardmäßig 0, da die Zuordnung zum Artikel über den Wert realisiert wird
type: integer
required: false
name:
description: Name der Eigenschaft (genaue Übereinstimmung)
type: string
required: false
typ:
description: Typ der Eigenschaft (genaue Übereinstimmung)
type: string
required: false
projekt:
description: Projekt dem die Eigenschaft zugewiesen ist (genaue Übereinstimmung)
type: integer
required: false
geloescht:
description: Markiert die Eigenschaft als gelöscht (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=artikel,-name`)
Verfügbare Felder: `artikel`, `name`, `typ`, `projekt`, `geloescht`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Eigenschaft anlegen
description: |
Eigenschaft anlegen
Permission: `create_property`
body:
application/json:
properties:
artikel:
description: Artikel Id der die Eigenschaft zugewiesen werden soll
type: integer
required: false
name:
description: Name der Eigenschaft (muss eindeutig sein)
type: string
required: true
typ:
description: Typ der Eigenschaft
type: string
required: false
projekt:
description: Projekt dem die Eigenschaft zugewiesen ist
type: integer
required: false
geloescht:
description: Markiert die Eigenschaft als gelöscht
type: integer
required: false
example: |
{
"name": "Farbe",
"typ": "einzeilig"
}
responses:
201:
description: Request erfolgreich; Angelegte Eigenschaft wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 19,
"artikel": 0,
"name": "Farbe",
"typ": "einzeilig",
"projekt": 0,
"geloescht": "0"
}
}
/{id}:
description: Einzelne Eigenschaft abrufen, bearbeiten, oder löschen
uriParameters:
id:
type: integer
description: Eigenschaft-ID
get:
displayName: Einzelne Eigenschaft abrufen
description: |
Einzelne Eigenschaft abrufen
Permission: `view_property`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 19,
"artikel": 0,
"name": "Farbe",
"typ": "einzeilig",
"projekt": 0,
"geloescht": "0"
}
}
404:
description: Eigenschaft wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Eigenschaft bearbeiten
description: |
Eigenschaft bearbeiten
Permission: `edit_property`
body:
application/json:
example: |
{
"name": "Material"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Eigenschaft wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 19,
"artikel": 0,
"name": "Material",
"typ": "einzeilig",
"projekt": 0,
"geloescht": "0"
}
}
delete:
displayName: Einzelne Eigenschaft löschen
description: |
Einzelne Eigenschaft löschen - Eigenschaften sollten nur dann gelöscht werden wenn auch keine Werte mehr für sie vorliegen
Permission: `delete_property`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 19
}
}
404:
description: Eigenschaft wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7452"
}
}
/v1/eigenschaftenwerte:
description: Eigenschaftenwerte für Artikel abrufen, erstellen, bearbeiten und löschen
get:
displayName: Eigenschaftenwerte abrufen
description: |
Eigenschaften abrufen
Permission: `list_property_value`
queryParameters:
artikel:
description: Artikel Id der die Eigenschaft zugewiesen ist (genaue Übereinstimmung)
type: integer
required: false
artikeleigenschaften:
description: Id der Eigenschaft (genaue Übereinstimmung)
type: string
required: false
wert:
description: Wert der Eigenschaft (genaue Übereinstimmung)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=artikel,-wert`)
Verfügbare Felder: `artikel`, `wert`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Eigenschaftwert anlegen
description: |
Eigenschaftenwert anlegen
Permission: `create_property_value`
body:
application/json:
properties:
artikel:
description: Artikel Id der der Eigenschaftenwert zugewiesen werden soll
type: integer
required: true
artikeleigenschaften:
description: Id der Eigenschaft
type: integer
required: true
wert:
description: Wert der Eigenschaft
type: string
required: false
example: |
{
"artikel": 1,
"artikeleigenschaften": 19,
"wert": "Gelb"
}
responses:
201:
description: Request erfolgreich; Angelegter Eigenschaftenwert wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 203,
"artikel": 1,
"artikeleigenschaften": 19,
"wert": "Gelb"
}
}
/{id}:
description: Einzelnen Eigenschaftenwert abrufen, bearbeiten, oder löschen
uriParameters:
id:
type: integer
description: Eigenschaftenwert-ID
get:
displayName: Einzelnen Eigenschaftenwert abrufen
description: |
Einzelnen Eigenschaftenwert abrufen
Permission: `view_property_value`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 203,
"artikel": 1,
"artikeleigenschaften": 19,
"wert": "Gelb"
}
}
404:
description: Eigenschaftenwert wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Eigenschaftenwert bearbeiten
description: |
Eigenschaftenwert bearbeiten
Permission: `edit_property_value`
body:
application/json:
example: |
{
"wert": "Holz"
}
responses:
200:
description: Request erfolgreich; Aktualisierter Eigenschaftenwert wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 203,
"artikel": 1,
"artikeleigenschaften": 19,
"wert": "Holz"
}
}
delete:
displayName: Einzelnen Eigenschaftenwert löschen
description: |
Einzelnen Eigenschaftenwert löschen
Permission: `delete_property_value`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 203
}
}
404:
description: Eigenschaftenwert wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7452"
}
}
/v1/belege/angebote:
description: Angebote abrufen
get:
displayName: Angebotsliste abrufen
description: |
Angebotsliste abrufen und Angebote suchen
Permission: `list_quotes`
queryParameters:
status:
description: |
Suche nach Angebotsstatus (genaue Übereinstimmung)
Mögliche Werte: `angelegt`, `abgelehnt`, `beauftragt`, `bestellt`, `freigegeben`, `versendet`, `storniert`
type: string
required: false
belegnr:
description: Suche nach Belegnummer (ungefähre Übereinstimmung)
type: string
required: false
belegnr_equals:
description: Suche nach Belegnummer (genaue Übereinstimmung)
type: string
required: false
belegnr_startswith:
description: Suche nach Belegnummer (Übereinstimmung am Anfang)
type: string
required: false
belegnr_endswith:
description: Suche nach Belegnummer (Übereinstimmung am Ende)
type: string
required: false
kundennummer:
description: Suche nach Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach Kundennummer (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Belegdatum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Belegdatum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Belegdatum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Belegdatum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Belegdatum (Datum kleiner gleich Suchwert)
type: string
required: false
projekt:
description: Angebote eines bestimmten Projekt filtern
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=belegnr`)
Verfügbare Felder: `belegnr`, `datum`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=positionen`)
Verfügbare Includes: `positionen`, `protokoll`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
/{id}:
description: Einzelnes Angebot abrufen
uriParameters:
id:
type: integer
description: Angebots-ID
get:
displayName: Einzelnes Angebot abrufen
description: |
Einzelnes Angebot abrufen
Permission: `list_quotes`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 4,
"firma": 1,
"projekt": "1",
"status": "versendet",
"belegnr": "100003",
"kundennummer": "10000",
"datum": "2019-06-28",
"gueltigbis": "2019-04-10",
"adresse": 3,
"typ": "firma",
"name": "Max Muster",
"titel": "",
"strasse": "Musterstrasse 6",
"plz": "12345",
"ort": "Musterdorf",
"land": "DE",
"...": "Ausgabe gekürzt"
}
}
404:
description: Angebot wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/belege/auftraege:
description: Aufträge abrufen
get:
displayName: Auftragsliste abrufen
description: |
Auftragsliste abrufen und Aufträge suchen
Permission: `list_orders`
queryParameters:
status:
description: |
Suche nach Auftragssstatus (genaue Übereinstimmung)
Mögliche Werte: `angelegt`, `bestellt`, `freigegeben`, `versendet`, `abgeschlossen`, `storniert`,
type: string
required: false
belegnr:
description: Suche nach Belegnummer (ungefähre Übereinstimmung)
type: string
required: false
belegnr_equals:
description: Suche nach Belegnummer (genaue Übereinstimmung)
type: string
required: false
belegnr_startswith:
description: Suche nach Belegnummer (Übereinstimmung am Anfang)
type: string
required: false
belegnr_endswith:
description: Suche nach Belegnummer (Übereinstimmung am Ende)
type: string
required: false
kundennummer:
description: Suche nach Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach Kundennummer (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Belegdatum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Belegdatum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Belegdatum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Belegdatum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Belegdatum (Datum kleiner gleich Suchwert)
type: string
required: false
angebot:
description: Aufträge nach Angebotsnummer filtern (genaue Übereinstimmung)
type: string
required: false
angebotid:
description: Aufträge nach Angebots-ID filtern (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Aufträge eines bestimmten Projekt filtern
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=belegnr`)
Verfügbare Felder: `belegnr`, `datum`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=positionen`)
Verfügbare Includes: `positionen`, `protokoll`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
/{id}:
description: Einzelnen Auftrag abrufen
uriParameters:
id:
type: integer
description: Auftrag-ID
get:
displayName: Einzelnen Auftrag abrufen
description: |
Einzelnen Auftrag abrufen
Permission: `list_orders`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 4,
"firma": 1,
"projekt": "1",
"status": "freigegeben",
"belegnr": "200003",
"kundennummer": "10002",
"ihrebestellnummer": null,
"datum": "2019-02-26",
"adresse": 5,
"typ": "firma",
"name": "Hans Huber",
"titel": "",
"strasse": "Musterstrasse 6",
"plz": "12345",
"ort": "Musterstadt",
"land": "DE",
"...": "Ausgabe gekürzt"
}
}
404:
description: Auftrag wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/belege/lieferscheine:
description: Lieferscheine abrufen
get:
displayName: Lieferscheinliste abrufen
description: |
Lieferscheinliste abrufen und Lieferscheine suchen
Permission: `list_delivery_notes`
queryParameters:
status:
description: |
Suche nach Lieferschein-Status (genaue Übereinstimmung)
Mögliche Werte: `angelegt`, `freigegeben`, `abgeschlossen`, `versendet`, `storniert`
type: string
required: false
belegnr:
description: Suche nach Belegnummer (ungefähre Übereinstimmung)
type: string
required: false
belegnr_equals:
description: Suche nach Belegnummer (genaue Übereinstimmung)
type: string
required: false
belegnr_startswith:
description: Suche nach Belegnummer (Übereinstimmung am Anfang)
type: string
required: false
belegnr_endswith:
description: Suche nach Belegnummer (Übereinstimmung am Ende)
type: string
required: false
internet:
description: Suche nach Internetnummer (ungefähre Übereinstimmung)
type: string
required: false
internet_equals:
description: Suche nach Internetnummer (genaue Übereinstimmung)
type: string
required: false
internet_startswith:
description: Suche nach Internetnummer (Übereinstimmung am Anfang)
type: string
required: false
internet_endswith:
description: Suche nach Internetnummer (Übereinstimmung am Ende)
type: string
required: false
kundennummer:
description: Suche nach Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach Kundennummer (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Belegdatum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Belegdatum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Belegdatum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Belegdatum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Belegdatum (Datum kleiner gleich Suchwert)
type: string
required: false
auftrag:
description: Lieferscheine nach Auftragsnummer filtern (genaue Übereinstimmung)
type: string
required: false
auftragid:
description: Lieferscheine nach Auftrags-ID filtern (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Lieferscheine eines bestimmten Projekt filtern
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=belegnr`)
Verfügbare Felder: `belegnr`, `datum`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=positionen`)
Verfügbare Includes: `positionen`, `protokoll`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
/{id}:
description: Einzelnen Lieferschein abrufen
uriParameters:
id:
type: integer
description: Lieferschein-ID
get:
displayName: Einzelnen Lieferschein abrufen
description: |
Einzelnen Lieferschein abrufen
Permission: `list_delivery_notes`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 4,
"firma": 1,
"projekt": "1",
"status": "freigegeben",
"lieferscheinart": "",
"belegnr": "300003",
"kundennummer": "10001",
"ihrebestellnummer": "",
"datum": "2019-06-12",
"adresse": 4,
"typ": "frau",
"name": "Eva Müller",
"strasse": "Musterweg 12a",
"plz": "12345",
"ort": "Musterdorf",
"land": "DE",
"...": "Ausgabe gekürzt"
}
}
404:
description: Lieferschein wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/belege/rechnungen:
description: Rechnungen abrufen
get:
displayName: Rechnungsliste abrufen
description: |
Rechnungsliste abrufen und Rechnungen suchen
Permission: `list_invoices`
queryParameters:
status:
description: |
Suche nach Rechnungs-Status (genaue Übereinstimmung)
Mögliche Werte: `angelegt`, `freigegeben`, `versendet`, `storniert`
type: string
required: false
belegnr:
description: Suche nach Belegnummer (ungefähre Übereinstimmung)
type: string
required: false
belegnr_equals:
description: Suche nach Belegnummer (genaue Übereinstimmung)
type: string
required: false
belegnr_startswith:
description: Suche nach Belegnummer (Übereinstimmung am Anfang)
type: string
required: false
belegnr_endswith:
description: Suche nach Belegnummer (Übereinstimmung am Ende)
type: string
required: false
kundennummer:
description: Suche nach Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach Kundennummer (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Belegdatum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Belegdatum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Belegdatum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Belegdatum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Belegdatum (Datum kleiner gleich Suchwert)
type: string
required: false
auftrag:
description: Rechnungen nach Auftragsnummer filtern (genaue Übereinstimmung)
type: string
required: false
auftragid:
description: Rechnungen nach Auftrags-ID filtern (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Rechnungen eines bestimmten Projekt filtern
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=belegnr`)
Verfügbare Felder: `belegnr`, `datum`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=positionen`)
Verfügbare Includes: `positionen`, `protokoll`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
/{id}:
description: Einzelne Rechnung abrufen oder löschen
uriParameters:
id:
type: integer
description: Rechnungs-ID
get:
displayName: Einzelne Rechnung abrufen
description: |
Einzelne Rechnung abrufen
Permission: `view_invoice`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 4,
"firma": 1,
"projekt": "1",
"status": "versendet",
"belegnr": "400002",
"datum": "2019-05-21",
"kundennummer": "10000",
"adresse": 3,
"typ": "firma",
"name": "Max Muster",
"strasse": "Musterstrasse 6",
"plz": "12345",
"ort": "Musterdorf",
"land": "DE",
"...": "Ausgabe gekürzt"
}
}
404:
description: Rechnung wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
delete:
displayName: Einzelne Rechnung löschen
description: |
Einzelne Rechnung löschen
Permission: `delete_invoice`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 18
}
}
404:
description: Rechnung wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7452"
}
}
/v1/belege/gutschriften:
description: Gutschriften/Stornorechnungen abrufen
get:
displayName: Gutschriftenliste abrufen
description: |
Gutschriftenliste abrufen und Gutschriften suchen
Permission: `list_credit_memos`
queryParameters:
status:
description: |
Suche nach Gutschriften-Status (genaue Übereinstimmung)
Mögliche Werte: `angelegt`, `freigegeben`, `versendet`, `storniert`
type: string
required: false
belegnr:
description: Suche nach Belegnummer (ungefähre Übereinstimmung)
type: string
required: false
belegnr_equals:
description: Suche nach Belegnummer (genaue Übereinstimmung)
type: string
required: false
belegnr_startswith:
description: Suche nach Belegnummer (Übereinstimmung am Anfang)
type: string
required: false
belegnr_endswith:
description: Suche nach Belegnummer (Übereinstimmung am Ende)
type: string
required: false
kundennummer:
description: Suche nach Kundennummer (ungefähre Übereinstimmung)
type: string
required: false
kundennummer_equals:
description: Suche nach Kundennummer (genaue Übereinstimmung)
type: string
required: false
kundennummer_startswith:
description: Suche nach Kundennummer (Übereinstimmung am Anfang)
type: string
required: false
kundennummer_endswith:
description: Suche nach Kundennummer (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Belegdatum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Belegdatum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Belegdatum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Belegdatum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Belegdatum (Datum kleiner gleich Suchwert)
type: string
required: false
rechnung:
description: Gutschriften nach Rechnungsnummer filtern (genaue Übereinstimmung)
type: string
required: false
rechnungid:
description: Gutschriften nach Rechnungs-ID filtern (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Gutschriften eines bestimmten Projekt filtern
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=belegnr`)
Verfügbare Felder: `belegnr`, `datum`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=positionen`)
Verfügbare Includes: `positionen`, `protokoll`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
/{id}:
description: Einzelne Gutschrift abrufen
uriParameters:
id:
type: integer
description: Gutschriften-ID
get:
displayName: Einzelne Gutschrift abrufen
description: |
Einzelne Gutschrift abrufen
Permission: `view_credit_memo`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 1,
"firma": 1,
"projekt": "1",
"status": "versendet",
"belegnr": "900000",
"datum": "2019-08-07",
"stornorechnung": 0,
"kundennummer": "10001",
"adresse": 4,
"typ": "frau",
"name": "Eva Müller",
"strasse": "Musterweg 12a",
"plz": "12345",
"ort": "Musterdorf",
"land": "DE",
"...": "Ausgabe gekürzt"
}
}
404:
description: Gutschrift wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/crmdokumente:
description: CRM-Dokumente abrufen, anlegen und bearbeiten
get:
displayName: CRM-Dokumente abrufen
description: |
CRM-Dokumente abrufen und suchen
Permission: `list_crm_documents`
queryParameters:
typ:
description: Suche nach CRM-Dokumenten eines Typs (ungefähre Übereinstimmung)
type: string
required: false
typ_equals:
description: |
Suche nach CRM-Dokumenten eines Typs (genaue Übereinstimmung)
Verfügbare Typen: `brief`, `email`, `telefon`, `notiz`
type: string
required: false
typ_exact:
description: (deprecated) gleich wie typ_equals
type: string
required: false
betreff:
description: Suche nach Betreff (ungefähre Übereinstimmung)
type: string
required: false
betreff_equals:
description: Suche nach Betreff (genaue Übereinstimmung)
type: string
required: false
betreff_exakt:
description: (deprecated) gleich wie betreff_equals
type: string
required: false
projekt:
description: Filtere nach Projekt (Projekt-ID)
type: integer
required: false
adresse_from:
description: Filtere nach Absender (Adresse-ID)
type: integer
required: false
adresse_to:
description: Filtere nach Empfänger (Adresse-ID)
type: integer
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`, `adresse_to`, `adresse_from`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: CRM-Dokument anlegen
description: |
CRM-Dokument anlegen
Permission: `create_crm_document`
body:
application/json:
properties:
typ:
description: Mögliche Werte sind `email`, `brief`, `telefon`, `notiz`
required: true
type: string
betreff:
description: Betreff des CRM-Dokuments
required: true
type: string
content:
description: Inhalt des CRM-Dokuments
required: false
type: string
adresse_from:
description: Absender/Mitarbeiter (Adresse-ID)
required: false
type: integer
adresse_to:
description: Empfänger/Kunde (Adresse-ID)
required: false
type: integer
von:
description: Anzeigename Absender
required: false
type: string
an:
description: Anzeigename Empfänger
required: false
type: string
email_an:
description: E-Mail Adresse Empfänger
required: false
type: string
email_cc:
description: E-Mail Adresse CC
required: false
type: string
email_bcc:
description: E-Mail Adresse BCC
required: false
type: string
adresse:
description: Anschrift 1. Adresszeile
required: false
type: string
plz:
description: Anschrift Postleitzahl
required: false
type: string
ort:
description: Anschrift Ort
required: false
type: string
land:
description: Anschrift Land
required: false
type: string
datum:
description: Datum des Dokuments
required: false
type: date-only
uhrzeit:
description: Uhrzeit des Dokuments
required: false
type: time-only
projekt:
description: Projekt-ID
required: false
type: integer
signatur:
description: Signatur verwendet (1=ja, 0=nein)
required: false
type: integer
printer:
description: Nachricht wurde gedruckt (1=ja, 0=nein)
required: false
type: integer
fax:
description: Fax wurde versendet (1=ja, 0=nein)
required: false
type: integer
sent:
description: Nachricht wurde versendet (1=ja, 0=nein)
required: false
type: integer
deleted:
description: Nachricht wurde gelöscht (1=ja, 0=nein)
required: false
type: integer
example: |
{
"typ": "email",
"betreff": "AW: Antwort auf eine Frage",
"adresse_from": 1,
"adresse_to": 7,
"projekt": 1
}
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 14,
"adresse_from": 1,
"adresse_to": 7,
"typ": "email",
"von": "",
"an": "",
"email_an": "",
"send_as": "",
"email": "",
"email_cc": null,
"email_bcc": null,
"bearbeiter": null,
"firma_an": "",
"adresse": "",
"ansprechpartner": null,
"plz": "",
"ort": "",
"land": "",
"datum": "0000-00-00",
"uhrzeit": null,
"betreff": "AW: Antwort auf eine Frage",
"content": "",
"projekt": 1,
"internebezeichnung": "",
"signatur": 0,
"fax": 0,
"sent": 0,
"printer": 0,
"deleted": 0
}
}
400:
description: Request Body Fehlerhaft
body:
application/json:
example: |
{
"error": {
"code": 7453,
"http_code": 400,
"message": "Validation error",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7453",
"details": [
"The attribute 'betreff' is required."
]
}
}
/{id}:
description: Einzelne CRM-Dokumente abrufen
uriParameters:
id:
type: integer
description: CRM-Dokumenten-ID
get:
displayName: Einzelnes CRM-Dokument abrufen
description: |
Einzelnes CRM-Dokument abrufen.
Permission: `view_crm_document`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 4,
"adresse_from": 1,
"adresse_to": 7,
"typ": "telefon",
"von": "",
"an": "",
"email_an": "",
"send_as": "",
"email": "",
"email_cc": "",
"email_bcc": "",
"bearbeiter": "Mitarbeiter XY",
"firma_an": "",
"adresse": "",
"ansprechpartner": "",
"plz": "",
"ort": "",
"land": "",
"datum": "2019-11-05",
"uhrzeit": "12:04:00",
"betreff": "Fragen zur Bedienung",
"content": "- Keine Fragen, alles klar",
"projekt": 1,
"internebezeichnung": "",
"signatur": 0,
"fax": 0,
"sent": 0,
"printer": 0,
"deleted": 0
}
}
404:
description: CRM-Dokument wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: CRM-Dokument bearbeiten
description: |
CRM-Dokument bearbeiten
Permission: `view_crm_document`
body:
application/json:
properties:
typ:
description: Mögliche Werte sind `email`, `brief`, `telefon`, `notiz`
required: true
type: string
betreff:
description: Betreff des CRM-Dokuments
required: true
type: string
content:
description: Inhalt des CRM-Dokuments
required: false
type: string
adresse_from:
description: Absender/Mitarbeiter (Adresse-ID)
required: false
type: integer
adresse_to:
description: Empfänger/Kunde (Adresse-ID)
required: false
type: integer
von:
description: Anzeigename Absender
required: false
type: string
an:
description: Anzeigename Empfänger
required: false
type: string
email_an:
description: E-Mail Adresse Empfänger
required: false
type: string
email_cc:
description: E-Mail Adresse CC
required: false
type: string
email_bcc:
description: E-Mail Adresse BCC
required: false
type: string
adresse:
description: Anschrift 1. Adresszeile
required: false
type: string
plz:
description: Anschrift Postleitzahl
required: false
type: string
ort:
description: Anschrift Ort
required: false
type: string
land:
description: Anschrift Land
required: false
type: string
datum:
description: Datum des Dokuments
required: false
type: date-only
uhrzeit:
description: Uhrzeit des Dokuments
required: false
type: time-only
projekt:
description: Projekt-ID
required: false
type: integer
signatur:
description: Signatur verwendet (1=ja, 0=nein)
required: false
type: integer
printer:
description: Nachricht wurde gedruckt (1=ja, 0=nein)
required: false
type: integer
fax:
description: Fax wurde versendet (1=ja, 0=nein)
required: false
type: integer
sent:
description: Nachricht wurde versendet (1=ja, 0=nein)
required: false
type: integer
deleted:
description: Nachricht wurde gelöscht (1=ja, 0=nein)
required: false
type: integer
example: |
{
"typ": "brief",
"betreff": "Test Brief 14"
}
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 14,
"adresse_from": 1,
"adresse_to": 7,
"typ": "brief",
"von": "",
"an": "",
"email_an": "",
"send_as": "",
"email": "",
"email_cc": null,
"email_bcc": null,
"bearbeiter": null,
"firma_an": "",
"adresse": "",
"ansprechpartner": null,
"plz": "",
"ort": "",
"land": "",
"datum": "0000-00-00",
"uhrzeit": null,
"betreff": "Test Brief 14",
"content": "",
"projekt": 1,
"internebezeichnung": "",
"signatur": 0,
"fax": 0,
"sent": 0,
"printer": 0,
"deleted": 0
}
}
400:
description: Request Body Fehlerhaft
body:
application/json:
example: |
{
"error": {
"code": 7453,
"http_code": 400,
"message": "Validation error",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7453",
"details": [
"The attribute 'betreff' is required."
]
}
}
404:
description: CRM-Dokument wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
delete:
displayName: CRM-Dokument löschen
description: |
CRM-Dokument löschen
Permission: `delete_crm_document`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 14
}
}
404:
description: CRM-Dokument wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/dateien:
description: Dateiliste abrufen und Dateien downloaden
get:
displayName: Dateiliste abrufen
description: |
Dateiliste abrufen.
Permission: `list_files`
queryParameters:
titel:
description: Suche nach Dateititel (ungefähre Übereinstimmung)
type: string
required: false
titel_equals:
description: Suche nach Dateititel (genaue Übereinstimmung)
type: string
required: false
titel_startswith:
description: Suche nach Dateititel (Übereinstimmung am Anfang)
type: string
required: false
titel_endswith:
description: Suche nach Dateititel (Übereinstimmung am Ende)
type: string
required: false
dateiname:
description: Suche nach Dateiname (ungefähre Übereinstimmung)
type: string
required: false
dateiname_equals:
description: Suche nach Dateiname (genaue Übereinstimmung)
type: string
required: false
dateiname_startswith:
description: Suche nach Dateiname (Übereinstimmung am Anfang)
type: string
required: false
dateiname_endswith:
description: Suche nach Dateiname (Übereinstimmung am Ende)
type: string
required: false
belegtyp:
description: Suche nach Zuweisungen zu Belegtyp (ungefähre Übereinstimmung)
type: string
required: false
stichwort:
description: Suche nach Stichwort (ungefähre Übereinstimmung)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=dateiname`)
Verfügbare Felder: `dateiname`, `datum`, `titel`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=stichwoerter`)
Verfügbare Includes: `stichwoerter`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Datei anlegen/hochladen
description: |
Datei anlegen/hochladen
Permission: `create_files`
body:
application/x-www-form-urlencoded:
properties:
file_content:
description: Datei-Inhalt (Raw-Daten)
required: true
type: file
titel:
description: Datei-Titel
required: true
type: string
dateiname:
description: Dateiname (ohne Verzeichnis; Beispiel `foo.jpg`)
required: true
type: string
beschreibung:
description: Beschreibungstext
required: false
type: string
responses:
201:
description: Request erfolgreich; Angelegte Datei wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 123,
"titel": "Rechnung 400027",
"beschreibung": "Rechnung 400027 von Kunde Max Mustermann",
"nummer": "",
"firma": 1,
"ersteller": "",
"datum": "2018-11-15",
"version": 1,
"dateiname": "RE400027.pdf",
"bemerkung": "Initiale Version",
"size": "8427",
"stichwoerter": null,
"belegtypen": null,
"mimetype": "application/pdf",
"links": {
"download": "http://www.example.com/api/v1/dateien/123/download",
"base64": "http://www.example.com/api/v1/dateien/123/base64"
}
}
}
/{id}:
description: Informationen zu einer Datei abrufen
uriParameters:
id:
type: integer
description: Datei-ID
get:
displayName: Informationen zu einer Datei abrufen
description: |
Informationen zu einer Datei abrufen
Permission: `view_file`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 115,
"titel": "Rechnung 400027",
"beschreibung": "",
"nummer": "",
"firma": 1,
"ersteller": "Max Mustermann",
"datum": "2018-11-15",
"version": 1,
"dateiname": "RE400027.pdf",
"bemerkung": "Initiale Version",
"size": "8427",
"stichwoerter": "Belege",
"belegtypen": "Verbindlichkeiten",
"mimetype": "application/pdf",
"links": {
"download": "http://www.example.com/api/v1/dateien/115/download",
"base64": "http://www.example.com/api/v1/dateien/115/base64"
}
}
}
404:
description: Datei wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/download:
description: Datei downloaden
get:
displayName: Datei downloaden
description: |
Datei downloaden
Permission: `handle_assets`
responses:
200:
description: |
Request erfolgreich
Der Content-Type ist abhängig vom Mime-Type der Datei die gesendet wird.
/base64:
description: Dateiinhalt base64-kodiert abrufen
get:
displayName: Dateiinhalt base64-kodiert abrufen
description: |
Dateiinhalt base64-kodiert abrufen
Permission: `handle_assets`
responses:
200:
description: Request erfolgreich
body:
text/plain:
example: 
/v1/docscan:
description: DocumentScanner-Dateiliste abrufen und Dateien downloaden
get:
displayName: DocumentScanner-Dateiliste abrufen
description: |
DocumentScanner-Dateiliste abrufen
Permission: `list_scanned_documents`
queryParameters:
titel:
description: Suche nach Dateititel (ungefähre Übereinstimmung)
type: string
required: false
titel_equals:
description: Suche nach Dateititel (genaue Übereinstimmung)
type: string
required: false
titel_startswith:
description: Suche nach Dateititel (Übereinstimmung am Anfang)
type: string
required: false
titel_endswith:
description: Suche nach Dateititel (Übereinstimmung am Ende)
type: string
required: false
dateiname:
description: Suche nach Dateiname (ungefähre Übereinstimmung)
type: string
required: false
dateiname_equals:
description: Suche nach Dateiname (genaue Übereinstimmung)
type: string
required: false
dateiname_startswith:
description: Suche nach Dateiname (Übereinstimmung am Anfang)
type: string
required: false
dateiname_endswith:
description: Suche nach Dateiname (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach Datum (genaue Übereinstimmung; Format `YYYY-MM-DD`)
type: string
required: false
datum_gt:
description: Suche nach Datum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach Datum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach Datum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach Datum (Datum kleiner gleich Suchwert)
type: string
required: false
belegtyp:
description: Suche nach Zuweisungen zu Belegtyp (ungefähre Übereinstimmung)
type: string
required: false
stichwort:
description: Suche nach Stichwort (ungefähre Übereinstimmung)
type: string
required: false
firma:
description: Suche nach Firmen-ID
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=dateiname`)
Verfügbare Felder: `dateiname`, `datum`, `titel`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=stichwoerter`)
Verfügbare Includes: `stichwoerter`, `metadata`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: DocumentScanner-Datei anlegen/hochladen
description: |
DocumentScanner-Datei anlegen/hochladen
Permission: `create_scanned_documents`
body:
multipart/form-data:
properties:
file_content:
description: Datei-Inhalt
required: true
type: file
titel:
description: Datei-Titel
required: true
type: string
dateiname:
description: Dateiname (ohne Verzeichnis; Beispiel `beleg.pdf`)
required: true
type: string
beschreibung:
description: Datei-Beschreibungstext
required: false
type: string
meta:
description: Meta-Daten
required: false
type: array
meta.invoice_number:
description: Rechnungsnummer
required: false
type: string
meta.invoice_date:
description: Rechnungsdatum (Format `YYYY-MM-DD`)
required: false
type: string
meta.invoice_amount:
description: Rechnungsbetrag brutto (Beispiel `12345.67`)
required: false
type: string
meta.invoice_tax:
description: Mehrwertsteuerbetrag der Rechnung (Beispiel `12345.67`)
required: false
type: string
meta.invoice_currency:
description: Währungscode der Rechnung (Beispiel `EUR`)
required: false
type: string
application/x-www-form-urlencoded:
properties:
file_content:
description: Datei-Inhalt (Raw-Daten)
required: true
type: string
titel:
description: Datei-Titel
required: true
type: string
dateiname:
description: Dateiname (ohne Verzeichnis; Beispiel `beleg.pdf`)
required: true
type: string
beschreibung:
description: Datei-Beschreibungstext
required: false
type: string
meta:
description: Meta-Daten
required: false
type: array
meta.invoice_number:
description: Rechnungsnummer
required: false
type: string
meta.invoice_date:
description: Rechnungsdatum (Format `YYYY-MM-DD`)
required: false
type: string
meta.invoice_amount:
description: Rechnungsbetrag brutto (Beispiel `12345.67`)
required: false
type: string
meta.invoice_tax:
description: Mehrwertsteuerbetrag der Rechnung (Beispiel `12345.67`)
required: false
type: string
meta.invoice_currency:
description: Währungscode der Rechnung (Beispiel `EUR`)
required: false
type: string
responses:
201:
description: Request erfolgreich; Angelegte Datei wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 123,
"titel": "Rechnung 400027",
"beschreibung": "Rechnung 400027 von Kunde Max Mustermann",
"nummer": "",
"firma": 1,
"ersteller": "",
"datum": "2018-11-15",
"version": 1,
"dateiname": "RE400027.pdf",
"bemerkung": "Initiale Version",
"size": "8427",
"mimetype": "application/pdf",
"links": {
"download": "http://www.example.com/api/v1/dateien/123/download",
"base64": "http://www.example.com/api/v1/dateien/123/base64"
}
}
}
/{id}:
description: Informationen zu einer DocumentScanner-Datei abrufen
uriParameters:
id:
type: integer
description: Datei-ID
get:
displayName: Informationen zu einer DocumentScanner-Datei abrufen
description: |
Informationen zu einer DocumentScanner-Datei abrufen
Permission: `view_scanned_documents`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 115,
"titel": "Rechnung 400027",
"beschreibung": "",
"nummer": "",
"firma": 1,
"ersteller": "Max Mustermann",
"datum": "2018-11-15",
"version": 1,
"dateiname": "RE400027.pdf",
"bemerkung": "Initiale Version",
"size": "8427",
"mimetype": "application/pdf",
"links": {
"download": "http://www.example.com/api/v1/dateien/115/download",
"base64": "http://www.example.com/api/v1/dateien/115/base64"
}
}
}
404:
description: Datei wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
/v1/gruppen:
description: Gruppen anlegen, bearbeiten und abrufen
get:
displayName: Gruppenliste abrufen
description: |
Gruppenliste abrufen
Permission: `list_groups`
queryParameters:
name:
description: Gruppe mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
name_exakt:
description: Gruppe mit bestimmter Bezeichnung suchen (genaue Übereinstimmung)
type: string
required: false
kennziffer:
description: Gruppen mit bestimmter Kennziffer suchen (ungefähre Übereinstimmung)
type: string
required: false
kennziffer_exakt:
description: Gruppen mit bestimmter Kennziffer suchen (genaue Übereinstimmung)
type: string
required: false
art:
description: |
Gruppen mit bestimmter Art suchen (genaue Übereinstimmung)
Mögliche Werte: `gruppe`, `preisgruppe`, `verband`, `regionalgruppe`, `kategorie`, `vertreter`
type: string
required: false
projekt:
description: Gruppen mit bestimmten Projekt filtern
type: integer
required: false
kategorie:
description: Gruppen mit bestimmter Kategorie filtern
type: integer
required: false
aktiv:
description: Aktive/Inaktive Gruppen filtern (1 = aktiv / 0 = inaktiv)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=projekt,-bezeichnung`)
Verfügbare Felder: `name`, `art`, `kennziffer`, `projekt`, `kategorie`, `aktiv`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Gruppe anlegen
description: |
Gruppe anlegen
Permission: `create_groups`
body:
application/json:
properties:
name:
description: Bezeichnung der Gruppe
required: true
type: string
art:
description: Mögliche Werte sind `gruppe`, `preisgruppe`, `verband`, `regionalgruppe`, `kategorie` , `vertreter`
required: true
type: string
kennziffer:
description: Einmalige Kennziffer
required: true
type: string
projekt:
description: Projekt-ID
required: false
type: integer
kategorie:
description: Projekt-ID
required: false
type: integer
aktiv:
description: Gruppe aktiv? (1 = Aktiv / 0 = Inaktiv)
required: false
type: integer
example: |
{
"name": "Support",
"art": "gruppe",
"kennziffer": "SUPPORT",
"projekt": 0,
"kategorie": 0,
"aktiv": 1
}
responses:
201:
description: Request erfolgreich; Angelegte Gruppe wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "11",
"name": "Support",
"art": "gruppe",
"kennziffer": "SUPPORT",
"internebemerkung": "",
"projekt": "0",
"kategorie": "0",
"aktiv": "1"
}
}
/{id}:
description: Einzelne Gruppe abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Gruppe-ID
get:
displayName: Einzelne Gruppe abrufen
description: |
Einzelne Gruppe abrufen
Permission: `view_group`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "1",
"name": "Vertriebsleiter",
"art": "vertreter",
"kennziffer": "VETRL",
"internebemerkung": "",
"projekt": "0",
"kategorie": "0",
"aktiv": "1"
}
}
404:
description: Gruppe wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Gruppe bearbeiten
description: |
Gruppe bearbeiten
Permission: `update_group`
body:
application/json:
example: |
{
"name": "Support (inaktiv)",
"art": "gruppe",
"kennziffer": "SUPPORT",
"aktiv": "0"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Gruppe wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "11",
"name": "Support (inaktiv)",
"art": "gruppe",
"kennziffer": "SUPPORT",
"internebemerkung": "",
"projekt": "0",
"kategorie": "0",
"aktiv": "0"
}
}
/v1/laender:
description: Länder anlegen, bearbeiten und abrufen
get:
displayName: Länderliste abrufen
description: |
Länderliste abrufen
Permission: `list_countries`
queryParameters:
eu:
description: Länder innerhalb/außerhalb EU filtern (1 = EU / 0 = Nicht EU)
type: integer
required: false
iso:
description: Länder mit ISO-Code filtern (genaue Übereinstimmung)
type: string
required: false
bezeichnung_de:
description: Länder mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_en:
description: Länder mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
id_ext:
description: Land mit externer ID filtern (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=iso,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `bezeichnung_de`, `bezeichnung_en`, `iso` , `eu`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Land anlegen
description: |
Land anlegen
Permission: `create_countries`
body:
application/json:
properties:
bezeichnung_de:
description: Deutsche Bezeichnung des Landes
required: true
type: string
bezeichnung_en:
description: Englische Bezeichnung des Landes
required: true
type: string
iso:
description: ISO-Code (ISO-3166 ALPHA 2)
required: true
type: string
eu:
description: EU (1 = EU / 0 = Nicht EU)
required: false
type: integer
example: |
{
"bezeichnung_de": "Republik Togo",
"bezeichnung_en": "République Togolaise",
"iso": "TG",
"eu": 0
}
responses:
201:
description: Request erfolgreich; Angelegtes Land wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "246",
"iso": "TG",
"bezeichnung_de": "Republik Togo",
"bezeichnung_en": "République Togolaise",
"eu": "0",
"id_ext": null
}
}
/{id}:
description: Einzelnes Land abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Land-ID
get:
displayName: Einzelnes Land abrufen
description: |
Einzelnes Land abrufen
Permission: `view_country`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "43",
"iso": "DE",
"bezeichnung_de": "Deutschland",
"bezeichnung_en": "Germany",
"eu": "1",
"id_ext": null
}
}
404:
description: Land wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Land bearbeiten
description: |
Land bearbeiten
Permission: `edit_country`
body:
application/json:
example: |
{
"bezeichnung_de": "Togo",
"bezeichnung_en": "Republique Togolaise",
"iso": "TX",
"eu": 0
}
responses:
200:
description: Request erfolgreich; Aktualisiertes Land wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "246",
"iso": "TX",
"bezeichnung_de": "Togo",
"bezeichnung_en": "Republique Togolaise",
"eu": "0",
"id_ext": null
}
}
/v1/lagercharge:
description: Lagercharge abrufen
get:
displayName: Lagercharge abrufen
description: |
Lagercharge abrufen
Permission: `view_storage_batch`
queryParameters:
artikelnummer:
description: Suche nach bestimmter Artikelnummer (ungefähre Übereinstimmung)
type: string
required: false
artikelnummer_equals:
description: Suche nach bestimmter Artikelnummer (genaue Übereinstimmung)
type: string
required: false
artikelnummer_startswith:
description: Suche nach bestimmter Artikelnummer (Übereinstimmung am Anfang)
type: string
required: false
artikelnummer_endswith:
description: Suche nach bestimmter Artikelnummer (Übereinstimmung am Ende)
type: string
required: false
artikel:
description: Suche nach bestimmter Artikel-ID (genaue Übereinstimmung)
type: integer
required: false
lagerplatzbezeichnung:
description: Suche nach bestimmter Lagerplatzbezeichnung (ungefähre Übereinstimmung)
type: string
required: false
lagerplatzbezeichnung_equals:
description: Suche nach bestimmter Lagerplatzbezeichnung (genaue Übereinstimmung)
type: string
required: false
lagerplatzbezeichnung_startswith:
description: Suche nach bestimmter Lagerplatzbezeichnung (Übereinstimmung am Anfang)
type: string
required: false
lagerplatzbezeichnung_endswith:
description: Suche nach bestimmter Lagerplatzbezeichnung (Übereinstimmung am Ende)
type: string
required: false
lagerplatz:
description: Suche nach bestimmter Lagerplatz-ID (genaue Übereinstimmung)
type: integer
required: false
charge:
description: Suche nach bestimmter Charge (ungefähre Übereinstimmung)
type: integer
required: false
charge_equals:
description: Suche nach bestimmter Charge (genaue Übereinstimmung)
type: string
required: false
charge_startswith:
description: Suche nach bestimmter Charge (Übereinstimmung am Anfang)
type: string
required: false
charge_endswith:
description: Suche nach bestimmter Charge (Übereinstimmung am Ende)
type: string
required: false
datum:
description: Suche nach bestimmtem Datum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Datum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Datum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Datum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Datum (Datum kleiner gleich Suchwert)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=artikelnummer,-menge`)
Verfügbare Felder: `lagerplatzbezeichnung`, `artikelnummer`, `charge`, `datum` , `menge`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=artikel`)
Verfügbare Includes: `artikel`, `lagerplatz`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
responses:
200:
description: |
Request erfolgreich
Die Menge wird gruppiert über drei Felder: `artikel`, `lagerplatz` und `charge`.
body:
application/json:
example: |
{
"data": [
{
"artikel": 1,
"artikelnummer": "700001",
"lagerplatz": 1,
"lagerplatzbezeichnung": "HL001A",
"charge": "111111",
"datum": "2018-12-21",
"menge": "200.0000",
"internebemerkung": ""
},
{
"artikel": 1,
"artikelnummer": "700001",
"lagerplatz": 2,
"lagerplatzbezeichnung": "HL001B",
"charge": "222222",
"datum": "2018-12-21",
"menge": "300.0000",
"internebemerkung": ""
}
],
"pagination": {
"items_per_page": 20,
"items_current": 2,
"items_total": 2,
"page_current": 1,
"page_last": 1
}
}
/v1/lagermhd:
description: Lager-Mindesthaltbarkeitdatum abrufen
get:
displayName: Lager-Mindesthaltbarkeitdatum abrufen
description: |
Lager-Mindesthaltbarkeitdatum abrufen
Permission: `view_storage_best_before`
queryParameters:
artikelnummer:
description: Suche nach bestimmter Artikelnummer (ungefähre Übereinstimmung)
type: string
required: false
artikelnummer_equals:
description: Suche nach bestimmter Artikelnummer (genaue Übereinstimmung)
type: string
required: false
artikelnummer_startswith:
description: Suche nach bestimmter Artikelnummer (Übereinstimmung am Anfang)
type: string
required: false
artikelnummer_endswith:
description: Suche nach bestimmter Artikelnummer (Übereinstimmung am Ende)
type: string
required: false
artikel:
description: Suche nach bestimmter Artikel-ID (genaue Übereinstimmung)
type: integer
required: false
lagerplatzbezeichnung:
description: Suche nach bestimmter Lagerplatzbezeichnung (ungefähre Übereinstimmung)
type: string
required: false
lagerplatzbezeichnung_equals:
description: Suche nach bestimmter Lagerplatzbezeichnung (genaue Übereinstimmung)
type: string
required: false
lagerplatzbezeichnung_startswith:
description: Suche nach bestimmter Lagerplatzbezeichnung (Übereinstimmung am Anfang)
type: string
required: false
lagerplatzbezeichnung_endswith:
description: Suche nach bestimmter Lagerplatzbezeichnung (Übereinstimmung am Ende)
type: string
required: false
lagerplatz:
description: Suche nach bestimmter Lagerplatz-ID (genaue Übereinstimmung)
type: integer
required: false
charge:
description: Suche nach bestimmter Charge (ungefähre Übereinstimmung)
type: integer
required: false
charge_equals:
description: Suche nach bestimmter Charge (genaue Übereinstimmung)
type: string
required: false
charge_startswith:
description: Suche nach bestimmter Charge (Übereinstimmung am Anfang)
type: string
required: false
charge_endswith:
description: Suche nach bestimmter Charge (Übereinstimmung am Ende)
type: string
required: false
mhddatum:
description: Suche nach bestimmtem MHD-Datum (genaue Übereinstimmung)
type: string
required: false
mhddatum_gt:
description: Suche nach bestimmtem MHD-Datum (MHD-Datum größer Suchwert)
type: string
required: false
mhddatum_gte:
description: Suche nach bestimmtem MHD-Datum (MHD-Datum größer gleich Suchwert)
type: string
required: false
mhddatum_lt:
description: Suche nach bestimmtem MHD-Datum (MHD-Datum kleiner Suchwert)
type: string
required: false
mhddatum_lte:
description: Suche nach bestimmtem MHD-Datum (MHD-Datum kleiner gleich Suchwert)
type: string
required: false
datum:
description: Suche nach bestimmtem Datum (genaue Übereinstimmung)
type: string
required: false
datum_gt:
description: Suche nach bestimmtem Datum (Datum größer Suchwert)
type: string
required: false
datum_gte:
description: Suche nach bestimmtem Datum (Datum größer gleich Suchwert)
type: string
required: false
datum_lt:
description: Suche nach bestimmtem Datum (Datum kleiner Suchwert)
type: string
required: false
datum_lte:
description: Suche nach bestimmtem Datum (Datum kleiner gleich Suchwert)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=artikelnummer,-menge`)
Verfügbare Felder: `lagerplatzbezeichnung`, `artikelnummer`, `charge`, `mhddatum`, `datum` , `menge`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=artikel`)
Verfügbare Includes: `artikel`, `lagerplatz`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
responses:
200:
description: |
Request erfolgreich
Die Menge wird gruppiert über vier Felder: `artikel`, `lagerplatz`, `charge` und `mhddatum`.
body:
application/json:
example: |
{
"data": [
{
"artikel": 1,
"artikelnummer": "700001",
"lagerplatz": 1,
"lagerplatzbezeichnung": "HL001A",
"charge": "444444",
"mhddatum": "2019-12-24",
"datum": "2018-12-21",
"menge": "300.0000",
"internebemerkung": "Charge und / oder MHD angelegt"
},
{
"artikel": 1,
"artikelnummer": "700001",
"lagerplatz": 4,
"lagerplatzbezeichnung": "HL002",
"charge": "555555",
"mhddatum": "2019-12-23",
"datum": "2018-12-21",
"menge": "289.0000",
"internebemerkung": "Produktion 400003 Einlagern"
}
],
"pagination": {
"items_per_page": 20,
"items_current": 2,
"items_total": 2,
"page_current": 1,
"page_last": 1
}
}
/v1/lieferadressen:
description: Lieferadressen anlegen, bearbeiten und abrufen
get:
displayName: Lieferadressen abrufen
description: |
Lieferadressen abrufen
Permission: `list_delivery_addresses`
queryParameters:
adresse:
description: Suche nach allen Lieferadressen einer bestimmten Hauptadresse
type: integer
required: false
standardlieferadresse:
description: Ist Standard-Lieferadresse? (0 = Keine Standard-Lieferadresse / 1 = Ist Standard-Lieferadresse)
type: integer
required: false
typ:
description: |
Nach bestimmten Adresstyp filtern (genaue Übereinstimmung)
Mögliche Werte: Siehe Adresstyp-Endpunkt: [GET /adresstyp](#adresstyp).
type: string
required: false
name:
description: Suche nach Name (ungefähre Übereinstimmung)
type: string
required: false
name_equals:
description: Suche nach Name (genaue Übereinstimmung)
type: string
required: false
name_startswith:
description: Suche nach Name (Übereinstimmung am Anfang)
type: string
required: false
name_endswith:
description: Suche nach Name (Übereinstimmung am Ende)
type: string
required: false
land:
description: Suche nach Lieferadressen aus einem bestimmten Land (zweistelliger ISO-Code)
type: string
required: false
id_ext:
description: Lieferadresse mit externer ID filtern (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=plz,-land`)
Verfügbare Felder: `typ`, `name`, `plz`, `land`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Lieferadresse anlegen
description: |
Lieferadresse anlegen
Permission: `create_delivery_address`
body:
application/json:
properties:
name:
description: Name der Firma bzw. Person
required: true
type: string
adresse:
description: ID der Hauptadresse; Die angelegte Lieferadresse wird dieser Hauptadresse zugeordnet.
required: false
type: integer
typ:
description: Adresstyp; Siehe [Adresstyp-Endpunkt](#adresstyp) Feld `type`.
required: false
type: string
abteilung:
required: false
type: string
strasse:
required: false
type: string
ort:
required: false
type: string
plz:
required: false
type: string
telefon:
required: false
type: string
telefax:
required: false
type: string
email:
required: false
type: string
land:
description: ISO-Code (ISO-3166 ALPHA 2)
required: false
type: string
standardlieferadresse:
description: |
Als Standard-Lieferadresse markieren?
(`0` = Keine Standard-Lieferadresse / `1` = Ist Standard-Lieferadresse)
required: false
type: integer
ust_befreit:
description: |
Besteuerung
(`0` = Inland / `1` = EU-Lieferung / `2` = Export / `3` = Steuerfrei Inland)
required: false
type: integer
example: |
{
"adresse": 5,
"typ": "herr",
"name": "Max Mustermann",
"abteilung": "Musterabteilung",
"strasse": "Musterweg",
"ort": "Musterort",
"plz": "12345",
"land": "DE",
"telefon": "0123-456789-9",
"telefax": "0123-456789-0",
"email": "max@mustermann.de",
"standardlieferadresse": 1,
"ust_befreit": 0
}
responses:
201:
description: Request erfolgreich; Angelegte Lieferadresse wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 23,
"typ": "herr",
"name": "Max Mustermann",
"abteilung": "Musterabteilung",
"...": "Ausgabe gekürzt",
"standardlieferadresse": 1,
"ust_befreit": 0,
"id_ext": null
}
}
/{id}:
description: Einzelne Lieferadresse abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Lieferadressen-ID
get:
displayName: Einzelne Lieferadresse abrufen
description: |
Einzelne Lieferadresse abrufen
Permission: `view_delivery_address`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 1,
"typ": "herr",
"name": "Max Mustermann",
"abteilung": "Musterabteilung",
"...": "Ausgabe gekürzt",
"standardlieferadresse": 1,
"ust_befreit": 0,
"id_ext": null
}
}
404:
description: Lieferadresse wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Lieferadresse bearbeiten
description: |
Lieferadresse bearbeiten
Permission: `edit_delivery_address`
body:
application/json:
example: |
{
"typ": "firma",
"name": "Mustermann Gmbh"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Lieferadresse wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 1,
"typ": "firma",
"name": "Mustermann Gmbh",
"abteilung": "Musterabteilung",
"...": "Ausgabe gekürzt",
"standardlieferadresse": 1,
"ust_befreit": 0,
"id_ext": null
}
}
delete:
displayName: Lieferadresse löschen
description: |
Lieferadresse löschen
Permission: `delete_delivery_address`
responses:
200:
description: Request erfolgreich; ID der gelöschten Lieferadresse wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 1
}
}
/v1/reports:
displayName: /v1/reports
description: Berichte (neues Modul) abrufen
/{id}/download:
description: |
Einzelnen Bericht per ID herunterladen
Permission: `view_report`
uriParameters:
id:
type: integer
description: Bericht-ID
get:
displayName: Einzelnen Bericht herunterladen
description: Einzelnen Bericht herunterladen
queryParameters:
parameter:
description: Jeder Parameter, der in der Abfrage des Berichts vorkommt.
type: any
required: false
responses:
200:
description: |
Request erfolgreich
Der Content-Type ist abhängig vom Mime-Type des Formats, das im Bericht hinterlegt ist.
403:
description: Der Bericht ist nicht für den Zugriff über diesen API Account freigegeben.
body:
application/json:
example: |
{
"error": {
"http_code": 403,
"message": "Access denied"
}
}
404:
description: Bericht wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
500:
description: Der Bericht konnte nicht erstellt werden. Der Bericht ist eventuell fehlerhaft.
body:
application/json:
example: |
{
"error": {
"code": 7499,
"http_code": 500,
"message": "Unknown server error",
"href": "http://localhost/xentral/20.1/www/api/docs.html#error-7499"
}
}
/v1/steuersaetze:
description: Steuersätze anlegen, bearbeiten und abrufen
get:
displayName: Steuersätze abrufen
description: |
Steuersätze abrufen
Permission: `list_tax_rates`
queryParameters:
bezeichnung:
description: Steuersatz mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
satz:
description: Nach Steuersatz filtern (genaue Übereinstimmung)
type: string
required: false
aktiv:
description: Aktive/Inaktive Steuersätze filtern (1 = aktiv / 0 = inaktiv)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=satz,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `satz`, `aktiv`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Steuersatz anlegen
description: |
Steuersatz anlegen
Permission: `create_tax_rate`
body:
application/json:
properties:
bezeichnung:
description: Bezeichnung des Steuersatzes
required: true
type: string
satz:
description: Steuersatz in Prozent (ohne Prozentzeichen; Dezimaltrenner = Punkt)
required: true
type: string
aktiv:
description: Aktiv (1 = aktiv / 0 = inaktiv)
required: false
type: integer
example: |
{
"bezeichnung": "Steuer DE ermäßigt",
"satz": "7.00",
"aktiv": 1
}
responses:
201:
description: Request erfolgreich; Angelegter Steuersatz wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "14",
"bezeichnung": "Steuer DE ermäßigt",
"satz": "7.00",
"aktiv": "1"
}
}
/{id}:
description: Einzelnen Steuersatz abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Steuersatz-ID
get:
displayName: Einzelnen Steuersatz abrufen
description: |
Einzelnen Steuersatz abrufen
Permission: `view_tax_rate`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "1",
"bezeichnung": "Steuersatz DE normal",
"country_code": "DE",
"satz": "19.00",
"aktiv": "1"
}
}
404:
description: Steuersatz wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Steuersatz bearbeiten
description: |
Steuersatz bearbeiten
Permission: `edit_tax_rates`
body:
application/json:
properties:
bezeichnung:
description: Bezeichnung des Steuersatzes
required: true
type: string
country_code:
description: Ländercode des Steuersatzes
required: false
type: string
satz:
description: Steuersatz in Prozent (ohne Prozentzeichen; Dezimaltrenner = Punkt)
required: true
type: string
aktiv:
description: Aktiv (1 = aktiv / 0 = inaktiv)
required: false
type: integer
example: |
{
"bezeichnung": "Steuer DE normal",
"satz": "19.00"
}
responses:
200:
description: Request erfolgreich; Aktualisierter Steuersatz wird zurückgeliefert
body:
application/json:
example: |
{
"data": {
"id": "1",
"bezeichnung": "Steuer DE normal",
"country_code": "DE",
"satz": "19.00",
"aktiv": "1"
}
}
/v1/trackingnummern:
get:
displayName: Trackingnummern abrufen
description: |
Endpunkt zum Abrufen von Trackingnummern
Permission: `list_tracking_numbers`
queryParameters:
tracking:
description: Suche nach bestimmter Trackingnummer (ungefähre Übereinstimmung)
type: string
required: false
tracking_equals:
description: Suche nach bestimmter Trackingnummer (genaue Übereinstimmung)
type: string
required: false
tracking_startswith:
description: Suche nach bestimmter Trackingnummer (Übereinstimmung am Anfang)
type: string
required: false
tracking_endswith:
description: Suche nach bestimmter Trackingnummer (Übereinstimmung am Ende)
type: string
required: false
lieferschein:
description: Suche nach bestimmter Lieferscheinnummer (ungefähre Übereinstimmung)
type: string
required: false
lieferschein_equals:
description: Suche nach bestimmter Lieferscheinnummer (genaue Übereinstimmung)
type: string
required: false
lieferschein_startswith:
description: Suche nach bestimmter Lieferscheinnummer (Übereinstimmung am Anfang)
type: string
required: false
lieferschein_endswith:
description: Suche nach bestimmter Lieferscheinnummer (Übereinstimmung am Ende)
type: string
required: false
auftrag:
description: Suche nach bestimmter Auftragsnummer (ungefähre Übereinstimmung)
type: string
required: false
auftrag_equals:
description: Suche nach bestimmter Auftragsnummer (genaue Übereinstimmung)
type: string
required: false
auftrag_startswith:
description: Suche nach bestimmter Auftragsnummer (Übereinstimmung am Anfang)
type: string
required: false
auftrag_endswith:
description: Suche nach bestimmter Auftragsnummer (Übereinstimmung am Ende)
type: string
required: false
internet:
description: Suche nach bestimmter Internetnummer (ungefähre Übereinstimmung)
type: string
required: false
internet_equals:
description: Suche nach bestimmter Internetnummer (genaue Übereinstimmung)
type: string
required: false
internet_startswith:
description: Suche nach bestimmter Internetnummer (Übereinstimmung am Anfang)
type: string
required: false
internet_endswith:
description: Suche nach bestimmter Internetnummer (Übereinstimmung am Ende)
type: string
required: false
versandart:
description: Suche nach bestimmter Versandart (genaue Übereinstimmung)
type: string
required: false
versendet_am:
description: Suche nach bestimmtem Versanddatum (genaue Übereinstimmung)
type: string
required: false
versendet_am_gt:
description: Suche nach bestimmtem Versanddatum (Datum größer Suchwert)
type: string
required: false
versendet_am_gte:
description: Suche nach bestimmtem Versanddatum (Datum größer gleich Suchwert)
type: string
required: false
versendet_am_lt:
description: Suche nach bestimmtem Versanddatum (Datum kleiner Suchwert)
type: string
required: false
versendet_am_lte:
description: Suche nach bestimmtem Versanddatum (Datum kleiner gleich Suchwert)
type: string
required: false
adresse:
description: Suche nach bestimmter Adress-ID (genaue Übereinstimmung)
type: integer
required: false
projekt:
description: Suche nach bestimmter Projekt-ID (genaue Übereinstimmung)
type: integer
required: false
land:
description: Suche nach bestimmtem Ländercode (genaue Übereinstimmung)
type: string
required: false
sort:
description: |
Sortierung (Beispiel: `sort=-versendet_am,lieferschein`)
Verfügbare Felder: `tracking`, `auftrag`, `lieferschein`, `versandart`, `versendet_am` , `abgeschlossen`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Trackingnummer anlegen
description: |
Trackingnummer anlegen
Eines der Felder `internet`, `auftrag` oder `lieferschein` muss mindestens gefüllt sein!
Permission: `create_tracking_number`
body:
application/json:
properties:
tracking:
description: Trackingnummer
required: true
type: string
internet:
description: Internetnummer aus Auftrag (Pflichtfeld, wenn Auftragsnummer und Lieferscheinnummer leer)
required: false
type: string
auftrag:
description: Auftragsnummer (Pflichtfeld, wenn Internetnummer und Lieferscheinnummer leer)
required: false
type: string
lieferschein:
description: Lieferscheinnummer (Pflichtfeld, wenn Auftragsnummer und Internetnummer leer)
required: false
type: string
anzahlpakete:
description: Anzahl Pakete
required: true
type: integer
gewicht:
description: Gewicht
required: true
type: string
versendet_am:
description: Versanddatum im Format `YYYY-MM-DD`
required: true
type: string
example: |
{
"tracking": "11223344556677889900",
"internet": "111001",
"auftrag": "200001",
"lieferschein": "300001",
"anzahlpakete": 1,
"gewicht": "2 kg",
"versendet_am": "2019-07-25"
}
responses:
201:
description: Request erfolgreich; Angelegte Trackingnummer wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 8,
"tracking": "11223344556677889900",
"adresse": 5,
"internet": "111001",
"auftrag": "200001",
"lieferschein": "300001",
"projekt": 1,
"versandart": "versandunternehmen",
"land": "DE",
"gewicht": "2 kg",
"abgeschlossen": 0,
"versendet_am": "2019-07-25",
"anzahlpakete": 1,
"retoure": 0,
"klaergrund": ""
}
}
/{id}:
description: Einzelne Trackingnummer abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Trackingnummer-ID
get:
displayName: Einzelne Trackingnummer abrufen
description: |
Einzelne Trackingnummer abrufen
Permission: `view_tracking_number`
put:
displayName: Trackingnummer bearbeiten
description: |
Trackingnummer bearbeiten (Felder siehe "Trackingnummer anlegen")
Permission: `edit_tracking_number`
body:
application/json:
example: |
{
"tracking": "11223344556677889900",
"versendet_am": "2019-06-22",
"anzahlpakete": 2
}
responses:
200:
description: Request erfolgreich; Aktualisierter Trackingnummern-Eintrag wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 8,
"tracking": "11223344556677889900",
"adresse": 5,
"internet": "111001",
"auftrag": "200001",
"lieferschein": "300001",
"projekt": 1,
"versandart": "versandunternehmen",
"land": "DE",
"gewicht": "2 kg",
"abgeschlossen": 0,
"versendet_am": "2019-06-22",
"anzahlpakete": 2,
"retoure": 0,
"klaergrund": ""
}
}
/v1/versandarten:
description: Versandarten anlegen, bearbeiten und abrufen
get:
displayName: Versandarten abrufen
description: |
Versandarten abrufen
Permission: `list_shipping_methods`
queryParameters:
bezeichnung:
description: Versandart mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_exakt:
description: Versandart mit bestimmter Bezeichnung suchen (genaue Übereinstimmung)
type: string
required: false
type:
description: Versandart eines bestimmten Typs suchen (ungefähre Übereinstimmung)
type: string
required: false
type_exakt:
description: Versandart eines bestimmten Typs suchen (genaue Übereinstimmung)
type: string
required: false
projekt:
description: Versandarten eines Projekts filtern (genaue Übereinstimmung)
type: integer
required: false
modul:
description: Versandarten mit bestimmtem Modul filtern (genaue Übereinstimmung)
type: integer
required: false
aktiv:
description: Aktive/Inaktive Versandarten filtern (1 = aktiv / 0 = inaktiv)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=type,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `type`, `projekt`, `modul`, `aktiv`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Versandart anlegen
description: |
Versandart anlegen
Permission: `create_shipping_method`
body:
application/json:
properties:
bezeichnung:
description: Bezeichnung der Versandart
required: true
type: string
type:
description: Versandart-Typ (einmaliger Wert)
required: true
type: string
projekt:
description: Projekt
required: false
type: integer
aktiv:
description: Aktiv (1 = aktiv / 0 = inaktiv)
required: false
type: integer
example: |
{
"type": "DHL",
"bezeichnung": "DHL",
"aktiv": 1,
"projekt": 1
}
responses:
201:
description: Request erfolgreich; Angelegte Versandart wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "15",
"type": "DHL",
"bezeichnung": "DHL",
"aktiv": "1",
"projekt": "1",
"modul": "",
"paketmarke_drucker": "0",
"export_drucker": "0",
"ausprojekt": "1",
"versandmail": "0",
"geschaeftsbrief_vorlage": "0"
}
}
/{id}:
description: Einzelne Versandart abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Versandarten-ID
get:
displayName: Einzelnen Versandart abrufen
description: |
Einzelnen Versandart abrufen
Permission: `view_shipping_method`
queryParameters:
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "15",
"type": "DHL",
"bezeichnung": "DHL",
"aktiv": "1",
"projekt": "1",
"modul": "",
"paketmarke_drucker": "0",
"export_drucker": "0",
"ausprojekt": "1",
"versandmail": "0",
"geschaeftsbrief_vorlage": "0"
}
}
404:
description: Versandart wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Versandart bearbeiten
description: |
Versandart bearbeiten
Permission: `edit_shipping_method`
body:
application/json:
example: |
{
"type": "DHL_Paket",
"bezeichnung": "DHL Paket",
"aktiv": "1",
"projekt": "1"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Versandart wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "15",
"type": "DHL_Paket",
"bezeichnung": "DHL Paket",
"aktiv": "1",
"projekt": "1",
"modul": "",
"paketmarke_drucker": "0",
"export_drucker": "0",
"ausprojekt": "1",
"versandmail": "0",
"geschaeftsbrief_vorlage": "0"
}
}
/v1/wiedervorlagen:
description: Wiedervorlagen anlegen, bearbeiten und abrufen
get:
displayName: Wiedervorlagen abrufen
description: |
Wiedervorlagen abrufen
Permission: `list_resubmissions`
queryParameters:
adresse:
description: Wiedervorlagen mit bestimmter Address-ID filtern (genaue Übereinstimmung)
type: integer
required: false
adresse_mitarbeiter:
description: Wiedervorlagen filtern die einem bestimmten Mitarbeiter (Address-ID) zugewiesen sind (genaue Übereinstimmung)
type: string
required: false
bearbeiter:
description: Wiedervorlagen filtern die einem bestimmten Bearbeiter (Address-ID) zugewiesen sind (genaue Übereinstimmung)
type: string
required: false
projekt:
description: Wiedervorlagen mit bestimmter Projekt-ID filtern (genaue Übereinstimmung)
type: string
required: false
stages:
description: Wiedervorlagen mit bestimmter Stage-ID filtern (genaue Übereinstimmung)
type: string
required: false
id_ext:
description: Wiedervorlage mit externer ID filtern (genaue Übereinstimmung)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=iso,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `datum_angelegt`, `zeit_angelegt`, `datum_erinnerung` , `zeit_erinnerung`,
`stages`, `prio`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Wiedervorlage anlegen
description: |
Wiedervorlage anlegen
Permission: `create_resubmission`
body:
application/json:
properties:
datum_erinnerung:
description: Fälligkeits-Datum der Wiedervorlage (Format `2019-12-31`)
required: true
type: date-only
zeit_erinnerung:
description: Fälligkeits-Uhrzeit der Wiedervorlage (Format `23:59:59`)
required: true
type: time-only
datum_angelegt:
description: Anlage-Datum der Wiedervorlage (Format `2019-12-31`)
required: false
type: date-only
zeit_angelegt:
description: Anlage-Uhrzeit der Wiedervorlage (Format `23:59:59`)
required: false
type: time-only
bezeichnung:
description: Kurzbeschreibung
required: true
type: string
beschreibung:
description: Langbeschreibung
required: false
type: string
bearbeiter:
description: Address-ID des Bearbeiters
required: false
type: integer
adresse_mitarbeiter:
description: Address-ID des zuständigen Mitarbeiters
required: false
type: integer
datum_abschluss:
description: Abschlussdatum der Wiedervorlage (Format `2019-12-31`)
required: false
type: date-only
example: |
{
"bearbeiter": 4,
"bezeichnung": "Blumengießen",
"beschreibung": "Alle Blumen im Büro gießen",
"datum_erinnerung": "2019-12-31",
"zeit_erinnerung": "23:59:59",
"datum_abschluss": "2020-01-06",
"adresse_mitarbeiter": 1
}
responses:
201:
description: Request erfolgreich; Angelegte Wiedervorlage wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": 49,
"adresse": 0,
"projekt": 0,
"bezeichnung": "Blumengießen",
"beschreibung": "Alle Blumen im Büro gießen",
"bearbeiter": 4,
"adresse_mitarbeiter": 1,
"datum_erinnerung": "2019-12-31",
"zeit_erinnerung": "23:59:59",
"datum_abschluss": "2020-01-06",
"oeffentlich": 0,
"abgeschlossen": 0,
"prio": 0,
"stages": 0,
"color": "",
"id_ext": null
}
}
/{id}:
description: Einzelne Wiedervorlage abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Wiedervorlage-ID
get:
displayName: Einzelne Wiedervorlage abrufen
description: |
Einzelne Wiedervorlage abrufen
Permission: `view_resubmission`
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": 49,
"adresse": 1,
"projekt": 1,
"bezeichnung": "Blumengießen",
"beschreibung": "Alle Blumen im Büro gießen",
"ergebnis": "",
"betrag": "5.00",
"erinnerung_per_mail": 0,
"bearbeiter": 4,
"adresse_mitarbeiter": 1,
"datum_angelegt": null,
"zeit_angelegt": null,
"datum_erinnerung": "2019-12-31",
"zeit_erinnerung": "23:59:00",
"datum_abschluss": "2020-01-06",
"oeffentlich": 0,
"abgeschlossen": 1,
"chance": 100,
"prio": 0,
"stages": 2,
"color": "",
"id_ext": null
}
}
404:
description: Wiedervorlage wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Wiedervorlage bearbeiten
description: |
Wiedervorlage bearbeiten
Permission: `edit_resubmission`
body:
application/json:
example: |
{
"bearbeiter": 1,
"bezeichnung": "Blumengießen",
"datum_erinnerung": "2019-12-31",
"zeit_erinnerung": "23:59:59"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Wiedervorlage wird zurückgeliefert
body:
application/json:
example: |
{
"data": {
"id": 49,
"adresse": 1,
"projekt": 1,
"bezeichnung": "Blumengießen",
"beschreibung": "Alle Blumen im Büro gießen",
"ergebnis": "",
"betrag": "5.00",
"erinnerung_per_mail": 0,
"bearbeiter": 1,
"adresse_mitarbeiter": 1,
"datum_angelegt": null,
"zeit_angelegt": null,
"datum_erinnerung": "2019-12-31",
"zeit_erinnerung": "23:59:00",
"datum_abschluss": "2020-01-06",
"oeffentlich": 0,
"abgeschlossen": 1,
"chance": 100,
"prio": 0,
"stages": 2,
"color": "",
"id_ext": null
}
}
/v1/zahlungsweisen:
description: Zahlungsweisen anlegen, bearbeiten und abrufen
get:
displayName: Zahlungsweisen abrufen
description: |
Zahlungsweisen abrufen
Permission: `list_payment_methods`
queryParameters:
bezeichnung:
description: Zahlungsweise mit bestimmter Bezeichnung suchen (ungefähre Übereinstimmung)
type: string
required: false
bezeichnung_exakt:
description: Zahlungsweise mit bestimmter Bezeichnung suchen (genaue Übereinstimmung)
type: string
required: false
type:
description: Nach bestimmten Typ filtern (ungefähre Übereinstimmung)
type: string
required: false
type_exakt:
description: Nach bestimmten Typ filtern (genaue Übereinstimmung)
type: string
required: false
projekt:
description: Zahlungsweise eines Projekts filtern (genaue Übereinstimmung)
type: integer
required: false
modul:
description: Nach bestimmtem Modul filtern (genaue Übereinstimmung)
type: integer
required: false
aktiv:
description: Aktive/Inaktive Zahlungsweise filtern (1 = aktiv / 0 = inaktiv)
type: integer
required: false
sort:
description: |
Sortierung (Beispiel: `sort=type,-bezeichnung`)
Verfügbare Felder: `bezeichnung`, `type`, `projekt`, `modul`, `aktiv`
type: string
required: false
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
page:
description: Seitenzahl
type: integer
required: false
default: 1
maximum: 1000
items:
description: Anzahl der Ergebnisse pro Seite
type: integer
required: false
default: 20
maximum: 1000
post:
displayName: Zahlungsweisen anlegen
description: |
Zahlungsweisen anlegen
Permission: `create_payment_method`
body:
application/json:
properties:
bezeichnung:
description: Bezeichnung der Zahlungsweise
required: true
type: string
type:
description: Zahlungsweise-Typ (einmaliger Wert)
required: true
type: string
verhalten:
description: Verhalten; Zulässige Werte sind `vorkasse`, `rechnung`, `lastschrift`
required: false
type: string
projekt:
description: Projekt
required: false
type: integer
aktiv:
description: Aktiv (`1` = aktiv / `0` = inaktiv)
required: false
type: integer
example: |
{
"type": "vorkasse",
"bezeichnung": "Vorkasse",
"verhalten": "vorkasse",
"aktiv": 1,
"projekt": 1
}
responses:
201:
description: Request erfolgreich; Angelegte Zahlungsweise wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "10",
"type": "vorkasse",
"bezeichnung": "Vorkasse",
"freitext": "",
"aktiv": "1",
"automatischbezahlt": "0",
"automatischbezahltverbindlichkeit": "0",
"projekt": "1",
"vorkasse": "0",
"verhalten": "vorkasse",
"modul": ""
}
}
/{id}:
description: Einzelne Zahlungsweise abrufen oder bearbeiten
uriParameters:
id:
type: integer
description: Zahlungsweisen-ID
get:
displayName: Einzelnen Zahlungsweise abrufen
description: |
Einzelnen Zahlungsweise abrufen
Permission: `view_payment_method`
queryParameters:
include:
description: |
Unter-Resourcen in Resource einbinden (Beispiel: `include=projekt`)
Verfügbare Includes: `projekt`
type: string
required: false
responses:
200:
description: Request erfolgreich
body:
application/json:
example: |
{
"data": {
"id": "1",
"type": "vorkasse",
"bezeichnung": "Vorkasse",
"freitext": "",
"aktiv": "1",
"automatischbezahlt": "0",
"automatischbezahltverbindlichkeit": "0",
"projekt": "0",
"vorkasse": "0",
"verhalten": "vorkasse",
"modul": ""
}
}
404:
description: Zahlungsweise wurde nicht gefunden
body:
application/json:
example: |
{
"error": {
"code": 7452,
"http_code": 404,
"message": "Resource not found",
"href": "http://www.example.com/api/docs.html#error-7452"
}
}
put:
displayName: Zahlungsweise bearbeiten
description: |
Zahlungsweise bearbeiten
Permission: `edit_payment_method`
body:
application/json:
example: |
{
"type": "lastschrift",
"bezeichnung": "Lastschrift",
"aktiv": "1",
"projekt": "1",
"verhalten": "lastschrift"
}
responses:
200:
description: Request erfolgreich; Aktualisierte Zahlungsweise wird zurückgeliefert
body:
application/json:
example: |
{
"success": true,
"data": {
"id": "10",
"type": "lastschrift",
"bezeichnung": "Lastschrift",
"freitext": "",
"aktiv": "1",
"automatischbezahlt": "0",
"automatischbezahltverbindlichkeit": "0",
"projekt": "1",
"vorkasse": "0",
"verhalten": "lastschrift",
"modul": ""
}
}
#types:
# ZeroValue:
# description: Zero-value numbers, accepting either 0 or 0.00
# type: number
# enum:
# - 0
# - 0.00
# HundredthsValue:
# description: Non-zero two-decimal place values (positive and negative)
# type: number
# multipleOf: 0.01
# decimal:
# description: this type describes any monetary value comprised between -9,999,999,999,999.99 and 9,999,999,999,999.99
# type: ZeroValue | HundredthsValue
# default: 0.00
# minimum: -9999999999999.99
# maximum: 9999999999999.99
# examples:
# zero: 0
# zerozero: 0.00
# tenten: 10.10
# negative: -0.10