41 lines
1.1 KiB
Python
41 lines
1.1 KiB
Python
from datetime import datetime
|
|
|
|
from fastapi import APIRouter
|
|
from pydantic import BaseModel
|
|
from typing import Optional, List
|
|
from backend.services.permission.role_service import RoleService
|
|
from common.token.token_manager import TokenManager
|
|
|
|
router = APIRouter()
|
|
token_manager = TokenManager()
|
|
role_service = RoleService()
|
|
|
|
class UpdateRoleRequest(BaseModel):
|
|
role_id: str
|
|
role_key: str
|
|
role_name: str
|
|
role_description: Optional[str] = None
|
|
role_level: int
|
|
|
|
class RoleResponse(BaseModel):
|
|
id: str
|
|
role_key: str
|
|
role_name: str
|
|
role_description: Optional[str] = None
|
|
permission_ids: List[str]
|
|
role_level: int
|
|
created_at: datetime
|
|
updated_at: datetime
|
|
|
|
@router.post(
|
|
"/update",
|
|
response_model=RoleResponse,
|
|
operation_id="update-role",
|
|
summary="Update Role",
|
|
description="Update an existing role by id. Only Admin role allowed."
|
|
)
|
|
async def update_role(
|
|
req: UpdateRoleRequest,
|
|
) -> RoleResponse:
|
|
doc = await role_service.update_role(req.role_id, req.role_key, req.role_name, req.role_description, req.role_level)
|
|
return RoleResponse(**doc.dict()) |