Servermodus
Der Publisher bietet eine Schnittstelle an, mit der über HTTP Aufträge zur Dokumentenerzeugung übergeben werden können. Gestartet wird der Servermodus mit
sp server
auf der Kommandozeile. Der Servermodus bietet die Möglichkeit
- Daten zum Server zu übertragen und einen Lauf zu starten
- Status des Laufs zu ermitteln (läuft der Prozess noch?)
- fertige PDF-Dateien herunterzuladen
- Sonstige Statusdateien zu lesen
| Der Server-Modus ist für eine nicht-öffentliche Umgebung gedacht. Es gibt keine Authentifizierungsmethoden und keine Mechanismen, Dokumente zu schützen. |
Der Server baut die Verbindung auf der IP-Adresse 127.0.0.1 und dem Port 5266 auf.
Die Adresse kann mit den Parameter address und port in der Konfigurationsdatei bzw. auf der Kommandozeile geändert werden, siehe den Anhang über die Konfiguration.
Es folgt ein Überblick über alle API Methoden.
Die aktuelle Versionsnummer der API ist 0, also werden alle Methoden über https://127.0.0.1:5266/v0/.. angesprochen.
Falls es zukünftig inkompatible Änderungen gibt, sind diese in der Versionsnummer /v1/... erreichbar, die vorhandenen Methoden werden weiterhin über /v0 aufrufbar sein.
/available
Ohne Versionsnummer. Gibt den HTTP-Status 200 zurück.
/v0/publish
Wird die URL mit einem POST-Request aufgerufen, erwartet der speedata Publisher eine JSON-Datei im folgenden Format:
{<dateiname>:<base64 kodierter Inhalt>,
<dateiname>:<base64 kodierter Inhalt>,
...
}
also z. B.
{"layout.xml":"PD94bWwgdmVyc2lv....",
"data.xml":"PGRhdGE+CiAgICA8Y29udGVudHM+PCFbQ0RBVEFbPHV..." }
Diese Dateien werden auf dem Server in ein leeres Verzeichnis kopiert und dort wird sp aufgerufen.
Die Rückgabe ist in der Form
{"id":"752869708"}
mit einem HTTP-Statuscode 201 (Created).
Falls die JSON-Datei fehlerhaft ist, wird ein HTTP-Statuscode 400 (Bad Request) zurückgegeben, mit dem textuellen Inhalt der Fehlermeldung, z. B.:
illegal base64 data at input byte 0
Parameter
Folgende URL-Parameter können beim POST-Request angegeben werden:
jobnameSetzt den Namen der Ausgabe, der beim Herunterladen der PDF-Datei vorgegeben wird (HTTP-Header
Content-Disposition). Alternativ wird er aus der Dateipublisher.cfgbzw. der Voreinstellungpublishergenommen.varsSetzt Variablen für den Publisher-Lauf. Angabe in der Form
var1=wert1,var2=wert2,var3=wert3..., jedoch URL-kodiert.
/v0/publish/<id>
Ein GET-Request an diese URL mit einer id aus dem oben beschriebenen POST-Request liefert eine JSON-Datei, mit dem Inhalt:
{"status":"ok",
"path":"/pfad/zu/publisher.pdf",
"blob":"<base64 kodiertes PDF>",
"finished":"2015-03-03T13:12:55+01:00"}oder, im Fehlerfall, falls die id unbekannt ist:
{"status":"error","path":"","blob":"id unknown"}Falls die PDF-Datei noch nicht fertig geschrieben wurde:
{"status":"error","path":"","blob":"in progress"}Das Verzeichnis mit der PDF-Datei wird nach diesem Request gelöscht, es sei denn, die URL enthält den Parameter delete mit dem Wert false.
/v0/pdf/<id>
Ein GET-Request mit der id aus dem POST-Request von /v0/publish. Es wird im Erfolgsfall die PDF-Datei mit dem Statuscode 200 und dem Dateinamen publisher.pdf zurückgegeben. Der Request wartet auf die Fertigstellung des Publishing Prozesses. Im Fehlerfall wird nur ein Fehlercode zurück gegeben (Rückgabewert und Beschreibung):
- 200 OK
PDF wurde fehlerfrei generiert
- 404 Not Found
id ungültig
- 406 Not Acceptable
PDF wurde fehlerhaft generiert
/v0/data/<id>
Liefert die Daten-Datei, die vorab auf den Server kopiert wurde. Das Format kann über den URL-Parameter format angegeben werden, zum Beispiel http://127.0.0.1:5266/v0/data/1347678770?format=base64:
jsonoderJSONLiefert eine JSON-Datei im Format
{"contents":"<XML Text>"}base64Ergibt eine XML Datei, die base64 kodiert ist (
PGRhdGE+CiAgICA8....hPgo=)- (keine Angabe)
Schreibt eine XML Datei (
<data>...</data>)
/v0/layout/<id>
Liefert das Layout XML, die vorab auf den Server kopiert wurde. Das Format kann über den URL-Parameter format angegeben werden. Beispiel wie oben.
jsonoderJSONLiefert eine JSON-Datei im Format
{"contents":"<XML Text>"}base64Ergibt eine XML Datei, die base64 kodiert ist (
PGRhdGE+CiAgICA8....hPgo=)- (keine Angabe)
Schreibt eine XML Datei (
<Layout>...</Layout>)
/v0/statusfile/<id>
Liefert die Datei publisher.status, die durch den Lauf erzeugt wurde. Das Format kann über den URL-Parameter format angegeben werden, (Beispiel wie unter /v0/data/<id>).
jsonoderJSONLiefert eine JSON-Datei im Format
{"contents":"<XML Text>"}base64Ergibt eine XML Datei, die base64 kodiert ist (
PGRhdGE+CiAgICA8....hPgo=)- (keine Angabe)
Schreibt eine XML Datei (
<Status>...</Status>)
/v0/status
Liefert den Status aller Publishing-Läufe zurück, die mit /v0/publish gestartet wurden.
Die zurückgegebene JSON-Datei hat das folgende Format:
{
"1997009134": {
"errorstatus": "ok",
"result": "finished",
"message": "no errors found",
"finished": "2016-05-23T11:14:14+02:00"
},
"1997329145": {
"errorstatus": "ok",
"result": "finished",
"message": "no errors found",
"finished": "2016-05-23T11:14:14+02:00"
}
}Die einzelnen Felder haben dieselbe Bedeutung wie unter /v0/status/<id> beschrieben.
/v0/status/<id>
Ermittelt den Status des Publisher-Laufs, der per POST-Request an /v0/publish gesendet wurde.
Die zurückgegebene JSON Datei hat folgende Schlüssel:
errorstatusIst die Anfrage gültig? Mögliche Antworten
errorundok. Wennerror, dann enthält der Schlüsselmessageden Grund für den Fehler, das Feldresultist in dem Fall ohne Bedeutung. Wennok, dann enthält das Feldresultden Wertnot finished, falls die PDF-Datei noch nicht erzeugt wurde.resultNach der Erzeugung der PDF-Datei enthält das Feld
resultden Wertfailed, falls bei der PDF-Erzeugung Fehler aufgetreten sind,not finished, falls der Publishing-Prozess noch fortdauert, ansonstenok.messageEnthält eine informelle Nachricht zum Ergebnis. Bsp.
no errors foundoder2 errors occurred during publishing run.finishedEnthält den Zeitstempel, zu dem das PDF fertig gestellt wurde. Format entspricht RFC3339, zum Beispiel
2015-12-25T12:03:04+01:00.
/v0/delete/<id>
GET: Löscht das Verzeichnis mit dieser id. Gibt 200 zurück, wenn die id vorhanden ist, 404 falls nicht.