from fastapi.encoders import jsonable_encoder from tortoise import connections from dbhelper.role import get_role from models import UserModel, UserRoleModel from schemas import UserPut async def get_user(kwargs): """ 根据条件查询到第一条符合结果的数据 Args: kwargs: Returns: """ return await UserModel.filter(**kwargs).first() async def get_user_info(user: UserModel): """ 根据id查用户角色列表 按激活角色倒序显示 """ db = connections.get("default") sql_result = await db.execute_query_dict( """ select r.id, r.name, ur.status from sys_role as r left join sys_user_role as ur on r.id = ur.rid where ur.uid = (?) and ur.status != 9 and r.status != 9 order by ur.status desc """, [user.id], ) return {**jsonable_encoder(user), "roles": sql_result} async def get_users(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 = ( UserModel.filter(status__not_in=[9, 5], **kwargs).all().order_by("-created") ) return await result.offset(skip).limit(limit), await result.count() async def insert_user(user, roles): """新增用户,选择角色""" for role in roles: if await get_role({"id": role.rid, "status__not": 9}) is None: return role.rid # 创建用户 obj = await UserModel.create(**user.dict()) await UserRoleModel.bulk_create( [UserRoleModel(rid=role.rid, uid=obj.id, status=role.status) for role in roles] ) return obj async def del_user(uid: int): """删除用户""" return await UserModel.filter(id=uid).update(status=9) async def put_user(uid: int, data: UserPut): """更新用户""" from core.security import get_password_hash roles = data.rids del data.rids for role in roles: if await get_role({"id": role.rid, "status__not": 9}) is None: return role.rid # 更新用户 data.password = get_password_hash(data.password) await UserModel.filter(id=uid).update(**data.dict()) # todo 1. 先前有的角色,这次更新成没有 2. 先前没有的角色 这次更新成有, 3. 只更新了状态 db = connections.get("default") # 1. 先把所有数据做删除 await db.execute_query_dict( """ update sys_user_role set status = 9 where uid = (?) """, [uid], ) # 2. 新增次此更新的数据 await UserRoleModel.bulk_create( [UserRoleModel(uid=uid, **role.dict()) for role in roles] ) async def select_role(uid: int, rid: int): """用户切换角色""" await UserRoleModel.filter(uid=uid, rid__not=rid).update(status=1) return await UserRoleModel.filter(uid=uid, rid=rid).update(status=5)