Grundlagen

Die OneGov GEVER API ist eine RESTful HTTP API.

Dies bedeutet, dass Operationen über die API via HTTP Requests durchgeführt werden, welche von einem HTTP Client abgesetzt werden.

HTTP ist ein Protokoll für die Kommunikation zwischen einem Client und einem Server, und basiert auf dem Austausch von Anfragen des Clients (Request) und Antworten des Servers (Response).

Die Verwendung der API funktioniert so, dass Requests auf die URL des entsprechenden Inhaltsobjekts gemacht werden, aber ein spezieller HTTP-Header verwendet wird welchen den Request als API-Request auszeichnet (um ihn von einem Request eines normales Browsers abzugrenzen).

Für die meisten Requests ist es notwendig, dass sich der Benutzer zuerst an der API authentisiert, siehe dazu das Kapitel zur Authentisierung.


Request

Requests an die API setzen sich zusammen aus einem HTTP Verb, einer URL, Request-Headern, und für gewisse Typen von Requests, einem Request-Body im JSON Format.

HTTP Verb

Im Kapitel Operationen ist beschrieben, auf welche HTTP Verben die verfügbaren Operationen gemappt sind.

URL

Die URL eines Requests ist bestimmt durch das Objekt, für welches eine Operation durchgeführt werden soll. Diese URL ist in der Regel für das entsprechende Objekt in der Adresszeile des Browsers sichtbar.

Headers

Die API verwendet JSON für die Serialisierung von Daten (für die Eingabe wie auch die Ausgabe).

Dementsprechend muss bei der Anfrage (Request) der HTTP-Header Accept: application/json gesetzt werden, damit ein Request an die API weitergeleitet wird.

Beispiel-Request:

GET /ordnungssystem HTTP/1.1
Accept: application/json

Dieser Header muss bei jedem Request auf die API gesetzt werden, und wird in den folgenden Beispielen daher nicht mehr immer explizit erwähnt.

Body

Bestimmte Request-Typen (POST und PATCH) brauchen weitere Informationen, welche in Form eines Request-Bodies im JSON Format mitgegeben werden. Wie der Inhalt dieses Bodies genau beschaffen sein muss, ist im Kapitel Operationen beschrieben.


Response

Wenn eine Response einen Body hat, ist dies immer ein JSON-Dokument:

Beispiel-Response:

HTTP/1.1 200 OK
Content-Type: application/json

{
   "@context": "http://www.w3.org/ns/hydra/context.jsonld",
   "@id": "https://example.org/ordnungssystem/fuehrung/dossier-23",
   "@type": "opengever.dossier.businesscasedossier",
   "title": "Titel des Objekts",
   "review_state": "dossier-state-active",
    "...": "..."
}

(Gekürzt - vollständige Beispiele von konkreten Responses sind in späteren Abschnitten zu finden)

Die mit einem @ Zeichen präfixten Keys haben eine spezielle Beduetung, und entsprechen nicht einem Feld auf dem Inhaltstyp, sondern sind JSON-LD (Linked Data) Metadaten:

Key Bedeutung Beschreibung
@context Kontext Wird immer denselben Wert haben, eine URI zum Hydra Kontext - dieser Key hat für die OneGov GEVER API im Moment keine Relevanz.
@id Eindeutige URL Die eindeutige URL zu einem Objekt.
@type Typ eines Objekts Der Typ eines Objekts. Dieser Typ entspricht einem der unter Inhaltstypen angegebenen Typen, und lässt den Client so wissen, welche Felder mit welchen Datentypen in einer Antwort zu erwarten sind.

Zusätzlich zu den oben aufgeführten JSON-LD Attributen gibt es für Objekttypen, welche einen Workflow haben, ein allgemeines Property review_state, welches den aktuellen Workflow-State enthält:

Key Bedeutung Beschreibung
review_state Workflow-State Falls das Objekt einen Workflow hat, enthält dieses Property den aktuellen Worflow-State.

Siehe Workflow für Details bezüglich Workflows.