mini-rbac/backend/controller/role.py

75 lines
2.1 KiB
Python
Raw Normal View History

2022-09-11 10:34:18 +00:00
import json
2022-09-12 15:22:18 +00:00
from fastapi import Query
2022-09-11 10:34:18 +00:00
from core.utils import list_to_tree
from dbhelper.menu import get_menu
from dbhelper.role import (
del_role,
get_role,
get_role_menus,
get_roles,
new_role,
put_role,
)
from schemas import ListAll, Response, RoleIn, RoleInfo, RoleQuery, RoleRead
2022-09-11 10:34:18 +00:00
2022-09-12 07:11:12 +00:00
async def role_add(data: RoleIn) -> Response[RoleInfo]:
2022-09-16 03:52:08 +00:00
if result := await new_role(data):
return Response(data=result)
return Response(code=400, msg="菜单不存在")
2022-09-11 10:34:18 +00:00
2022-09-12 07:11:12 +00:00
async def role_has_menu(rid: int):
"""
rid: 角色ID
"""
menus = await get_role_menus(rid)
2022-09-11 10:34:18 +00:00
for obj in menus:
obj["meta"] = json.loads(obj["meta"]) if obj["meta"] is not None else None
try:
result = list_to_tree(menus)
except KeyError:
return Response(code=400, msg="菜单缺少根节点.")
return Response(data=result)
2022-09-12 15:22:18 +00:00
async def role_arr(
offset: int = Query(default=1, description="偏移量-页码"),
limit: int = Query(default=10, description="数据量"),
) -> Response[ListAll[list[RoleRead]]]:
skip = (offset - 1) * limit
roles, count = await get_roles(skip, limit)
return Response(data=ListAll(total=count, items=roles))
async def role_del(pk: int) -> Response:
if await del_role(pk) == 0:
return Response(code=400, msg="角色不存在")
return Response()
async def role_put(pk: int, data: RoleIn) -> Response:
"""更新角色"""
print(await get_role({"id": pk}))
if await get_role({"id": pk}) is None:
return Response(code=400, msg="角色不存在")
# 如果不为ture -> 有菜单id不存在
if not all([await get_menu({"id": mid}) for mid in data.menus]):
return Response(code=400, msg="菜单不存在")
2022-09-12 15:22:18 +00:00
if await put_role(pk, data) == 0:
return Response(code=400, msg="角色不存在")
return Response()
async def role_query(query: RoleQuery) -> Response[ListAll[list[RoleRead]]]:
"""post条件查询角色表"""
2022-09-15 10:54:19 +00:00
size = query.limit
skip = (query.offset - 1) * size
del query.offset, query.limit
users, count = await get_roles(skip, size, query.dict())
2022-09-12 15:22:18 +00:00
return Response(data=ListAll(total=count, items=users))