API-Authentifizierung
Die Authentifizierungsmechanismen werden zwischen allen DTZ-APIs geteilt. Somit sind alle hier beschriebenen Mechanismen für alle APIs verfügbar.
Die Authentifizierungsdaten können über die folgenden Felder übertragen werden:
- Bearer Token
- Cookie-basiert
- API-Schlüssel
- Basic Auth
Authentifizierung
Die Authentifizierung wird vom DTZ Identity Service gehandhabt.
Mögliche Login-Szenarien:
WebUI
https://identity.dtz.rocks/login/
Mit HTTP Apikey Header
Um sich mit einem API-Schlüssel zu authentifizieren, muss der API-Schlüssel als Header-Feld X-API-KEY
übergeben werden.
Hier ein Beispiel für einen curl-Befehl:
curl -X GET "https://api.dtz.rocks/v1/me" -H "X-API-KEY: YOUR_API_KEY"
Mit HTTP Bearer Token
Um sich mit einem Bearer Token zu authentifizieren, muss das Token als Header-Feld Authorization: Bearer YOUR_BEARER_TOKEN
übergeben werden.
Hier ein Beispiel, wie man ein Bearer Token erhält:
> POST https://identity.dtz.rocks/api/2021-02-21/token/auth
> Content-Type: application/json
>
> {
> "username": "user",
> "password": "password"
> }
< {
< "access_token": "eyJhb...",
< "scope": "00000000-0000-0000-0000-000000000000",
< "token_type": "Bearer",
< "expires_in": 86400
< }
Hier ein Beispiel, wie das Bearer Token verwendet wird:
curl -X GET "https://identity.dtz.rocks/api/2021-02-21/me" -H "Authorization: Bearer {bearer token}"
> GET https://identity.dtz.rocks/api/2021-02-21/me
> Authorization: Bearer eyJhb...
< {
< "roles": [ ]
< }
Mit HTTP Basic Auth Header
Hier ein Beispiel für einen curl-Befehl, wie man Basic Auth verwendet, um auf die dtz API zuzugreifen.
curl -X GET -u 'apikey:apikey-1234' "https://identity.dtz.rocks/api/2021-02-21/me"
Mit HTTP Cookie
Die Verwendung des JWT-Tokens als Cookie ist ebenfalls erlaubt. Das Token muss als Cookie mit dem Namen dtz-auth
übergeben werden.
Mit Get-Parameter
Manchmal erlauben Drittanbieter keine Authentifizierung über Header. In diesem Fall kann ein API-Schlüssel auch als GET-Parameter mit dem Namen apiKey
übergeben werden.