feat: Implement role management API endpoints
Some checks are pending
Docker Test / test (push) Waiting to run

This commit is contained in:
BibaBot Jarvis 2026-03-16 05:07:56 +00:00
parent 1f3e567d3a
commit fddbb167c2
6 changed files with 355 additions and 35 deletions

View file

@ -0,0 +1,96 @@
const express = require('express');
const router = express.Router();
const { requireAdmin } = require('../middleware/role.middleware');
const { getUserRoles, updateUserRoles, deleteUserRoles } = require('../controllers/roles.controller');
/**
* @swagger
* /api/users/{userId}/roles:
* get:
* summary: Liefert die Rollen eines Benutzers
* tags: [Roles]
* parameters:
* - in: path
* name: userId
* required: true
* schema:
* type: string
* description: Die ID des Benutzers
* responses:
* 200:
* description: Die Rollen des Benutzers
* content:
* application/json:
* schema:
* type: array
* items:
* type: string
* 404:
* description: Benutzer nicht gefunden
* 500:
* description: Interner Serverfehler
*/
router.get('/:userId/roles', getUserRoles);
/**
* @swagger
* /api/users/{userId}/roles:
* put:
* summary: Ändert die Rollen eines Benutzers
* tags: [Roles]
* parameters:
* - in: path
* name: userId
* required: true
* schema:
* type: string
* description: Die ID des Benutzers
* requestBody:
* required: true
* content:
* application/json:
* schema:
* type: array
* items:
* type: string
* description: Die neuen Rollen des Benutzers
* responses:
* 200:
* description: Rollen erfolgreich aktualisiert
* 400:
* description: Ungültige Rollen
* 403:
* description: Keine Berechtigung
* 404:
* description: Benutzer nicht gefunden
* 500:
* description: Interner Serverfehler
*/
router.put('/:userId/roles', requireAdmin, updateUserRoles);
/**
* @swagger
* /api/users/{userId}/roles:
* delete:
* summary: Entfernt alle Rollen eines Benutzers
* tags: [Roles]
* parameters:
* - in: path
* name: userId
* required: true
* schema:
* type: string
* description: Die ID des Benutzers
* responses:
* 200:
* description: Rollen erfolgreich entfernt
* 403:
* description: Keine Berechtigung
* 404:
* description: Benutzer nicht gefunden
* 500:
* description: Interner Serverfehler
*/
router.delete('/:userId/roles', requireAdmin, deleteUserRoles);
module.exports = router;