mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2024-11-15 04:27:14 +01:00
6901 lines
220 KiB
Plaintext
6901 lines
220 KiB
Plaintext
|
#%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: data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkYAAAAAYAAjCB0C8AAAAASUVORK5CYII=
|
|||
|
|
|||
|
/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
|