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