2022-09-11 10:34:18 +00:00
|
|
|
from tortoise import connections
|
|
|
|
|
2022-09-12 07:11:12 +00:00
|
|
|
from models import RoleModel
|
|
|
|
from schemas.role import RoleIn
|
|
|
|
|
2022-09-11 10:34:18 +00:00
|
|
|
|
|
|
|
async def get_role_menus(rid: int):
|
|
|
|
"""
|
|
|
|
根据角色id 获取菜单
|
|
|
|
"""
|
|
|
|
db = connections.get("default")
|
|
|
|
return await db.execute_query_dict(
|
|
|
|
"""
|
2022-09-13 05:31:15 +00:00
|
|
|
select m.id, m.name, m.meta, m.path, m.type, m.component, m.pid, m.identifier
|
2022-09-11 10:34:18 +00:00
|
|
|
FROM sys_menu as m, sys_role_menu WHERE m.id = sys_role_menu.mid
|
2022-09-12 15:22:18 +00:00
|
|
|
AND sys_role_menu.rid = (?) AND m.`status` = 1""",
|
2022-09-11 10:34:18 +00:00
|
|
|
[rid],
|
|
|
|
)
|
2022-09-12 07:11:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def new_role(role: RoleIn):
|
|
|
|
"""新增角色"""
|
|
|
|
return await RoleModel.create(**role.dict())
|
2022-09-12 15:22:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def get_roles(skip: int, limit: int, kwargs: dict = None):
|
|
|
|
"""
|
|
|
|
分页获取用户并且支持字段模糊查询
|
|
|
|
Args:
|
|
|
|
skip: 偏移量
|
|
|
|
limit: 数量
|
|
|
|
kwargs: 查询字典
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
"""
|
|
|
|
if kwargs is not None:
|
|
|
|
kwargs = {f"{k}__contains": v for k, v in kwargs.items()}
|
|
|
|
else:
|
|
|
|
kwargs = {}
|
|
|
|
result = RoleModel.filter(status__not=9, **kwargs).all().order_by("-created")
|
|
|
|
return await result.offset(skip).limit(limit), await result.count()
|
|
|
|
|
|
|
|
|
|
|
|
async def get_role(kwargs):
|
|
|
|
"""
|
|
|
|
根据条件查询到第一条符合结果的数据
|
|
|
|
Args:
|
|
|
|
kwargs:
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
"""
|
|
|
|
return await RoleModel.filter(**kwargs).first()
|
|
|
|
|
|
|
|
|
|
|
|
async def del_role(rid: int):
|
|
|
|
"""删除用户"""
|
|
|
|
return await RoleModel.filter(id=rid).update(status=9)
|
|
|
|
|
|
|
|
|
|
|
|
async def put_role(pk: int, data):
|
|
|
|
"""更新角色"""
|
|
|
|
return await RoleModel.filter(id=pk).update(**data.dict())
|