API #4
Labels
No Label
bug
chore
discussion
documentation
doing
duplicate
enhancement
help wanted
invalid
prio
1
prio
2
prio
3
quality
review
tooling
No Milestone
No project
No Assignees
1 Participants
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: kompetenzinventar/ki-doku#4
Loading…
Reference in New Issue
Block a user
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Für Datenmodell siehe #3.
Authentifizierung
HTTP Bearer Token. Wird vom Backend verwaltet. Es gibt eine konfigurierbare, maximale Gültigkeit für einen Token.
Allgemeine Antworten:
Authorisierung
Endpunkte
POST
/users/login
Hiermit kann sich ein Benutzer anmelden. Der Endpunkt authentifiziert gegen LDAP.
Anfrage:
Antwort:
Status 200
Login hat geklappt
Status 403
Login hat nicht geklappt. Grund ist Benutzer existiert nicht oder Passwort war falsch. Kein weiterer Text über die API wegen Sicherheit.
DELETE
/users/login
Markiert den zur Request Authentifizierung verwendeten Token als nicht mehr gültig.
POST
/users/profile
Speichert ein Profil ab. Übertragene Daten entsprechen #3 im JSON Format.
Anfrage:
Antwort:
Status 200
Gespeichert, ok
Status 400
Validierung fehlgeschlagen
GET
/users/{id}/profile
Endpunkt um ein Profil gezielt nach ID abzurufen.
Antwort:
Status 200
Profil gefunden
GET
/users/profiles
Suche nach Profilen mit Query-Parametern:
skill[]=23
page=1
für die Paginierungpage_size=20
Einträge pro Seite(Liste wird erweitert).
Antwort:
total
Gesamtanzahl der passenden Profileprofils
Liste mit ProfilenGET
/skills
Hier können die auswählbaren Fähigkeiten inkl. Autovervollständigung abgerufen werden sowie "Ich Suche".
search=an
Antwort:
GET
/skills/{id}/icon
Icon einer Fähigkeit (weils gut ausschaut).
GET
/languages
Abruf der Sprachen.
search=fra
Antwort:
GET
/languages/{id}/icon
Icon einer Sprache (weils gut ausschaut).
Ich denke das ist erstmal erledigt. Weiteres dann in neuen Tickets.