After_Chido_Api/api/v1/roles.py

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)