Authentifizierung
Einleitung
Um Clientsysteme von Drittanbietern zu authentifizieren, wird der Standard OAuth2 mit dem Client Credentials Flow eingesetzt. Nähere Information dazu sind im RFC 6749 The OAuth 2.0 Authorization Framework
in Abschnitt 4.4 Client Credentials Grant zu finden.
Authentifizierungsverfahren
Jeder Drittanbieter für die Vermittlung von Terminen für telemedizinische Leistungen hat dabei die Rolle eines Clients inne. Die kv.digital GmbH stellt einen OAuth 2.0 Authorization Server bereit, um mittels Client ID und Client Secret einen Access Token zu erstellen. Der Access Token berechtigt den Drittanbieter die Schnittstelle (API bzw. OAuth 2.0 Resource Server) zu nutzen.
Access Token & Gültigkeit
Mit dem Access Token werden keine einzelnen Personen identifiziert und autorisiert, um die Schnittstelle zu nutzen, sondern der Drittanbieter.
Der Access Token ist 5 Minuten lang gültig. Nach Ablauf dieser 5 Minuten muss der Drittanbieter einen neuen Access Token Request an den OAuth 2.0 Authorization Server stellen, um einen neuen Access Token zu erhalten.
Sequenzdiagramm
Der Ablauf der Authentifizierung wird in folgendem Sequenzdiagramm veranschaulicht:
Legende
◼ Server der kv.digital
◼ System des Dritten
→ Schritt zur Authentifizierung
→ Schritt nach der Authentifizierung
Die oben in rosa dargestellten Schritte 4 und 5 sind nicht Teil des Authentifizierungsprozesses; sie zeigen lediglich, was der Client (hier also der Dritte) nach erfolgreicher Authentifizierung mit dem dadurch erhaltenen Access Token machen kann.
Beispiel-Request
Beispiel für cURL
Beim folgenden Request muss die Client ID als username
und das Client Secret als password
angegeben werden.
curl --request POST \
--url https://auth-server.kvtg.de/oauth2/token \
--data grant_type=client_credentials \
--data scope=terminefuerdritte
Beispiel für Postman etc.
Sollen Requests mithilfe von entsprechenden Anwendungen (bspw. Postman) gesendet werden, sind die im Folgenden genannten Parameter zu nutzen.
Request Body (Form URL Encoded)
Key | Value |
---|---|
grant_type |
client_credentials |
scope |
terminefuerdritte |
Basic Auth
Key | Value |
---|---|
username |
<YOUR_CLIENT_ID> |
password |
<YOUR_CLIENT_SECRET> |