58 lines
2.0 KiB
Python
58 lines
2.0 KiB
Python
from fastapi import APIRouter, Depends, HTTPException
|
|
from sqlalchemy.ext.asyncio import AsyncSession
|
|
from config.database import get_db
|
|
from services.role_service import RoleService
|
|
from models.schemas import Permission, Role, PermissionResponse
|
|
from fastapi.security import OAuth2PasswordBearer
|
|
from typing import List
|
|
|
|
router = APIRouter()
|
|
oauth2_scheme = OAuth2PasswordBearer(tokenUrl="/api/v1/auth/token")
|
|
|
|
@router.post("/", status_code=201)
|
|
async def create_role(name: str, token: str = Depends(oauth2_scheme)):
|
|
"""
|
|
Créer un nouveau rôle avec des permissions associées (réservé aux administrateurs).
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.create_role(name, db, token)
|
|
|
|
@router.get("/{role_id}", response_model=Role)
|
|
async def get_role(role_id: int):
|
|
"""
|
|
Récupérer les détails d'un rôle spécifique.
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.get_role(role_id, db)
|
|
|
|
@router.get("/", response_model=List[Role])
|
|
async def get_all_roles():
|
|
"""
|
|
Récupérer tous les rôles avec leurs permissions associées.
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.get_all_roles(db)
|
|
|
|
@router.put("/{role_id}")
|
|
async def update_role(role_id: int, role: Role, token: str = Depends(oauth2_scheme)):
|
|
"""
|
|
Mettre à jour un rôle existant (réservé aux administrateurs).
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.update_role(role_id, role.dict(), db, token)
|
|
|
|
@router.delete("/{role_id}")
|
|
async def delete_role(role_id: int, token: str = Depends(oauth2_scheme)):
|
|
"""
|
|
Supprimer un rôle (réservé aux administrateurs).
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.delete_role(role_id, db, token)
|
|
|
|
@router.get("/roles/permissions", response_model=List[Permission])
|
|
async def get_all_permissions():
|
|
"""
|
|
Récupérer toutes les permissions disponibles.
|
|
"""
|
|
async with get_db() as db:
|
|
return await RoleService.get_all_permissions(db) |