OpenXE/www/api/docs.raml
2021-05-21 08:49:41 +02:00

6901 lines
220 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#%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