233 lines
7.2 KiB
Python
233 lines
7.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from typing import Sequence, Any
|
|
from datetime import datetime
|
|
|
|
from app.core.base_crud import CRUDBase
|
|
from app.api.v1.module_system.auth.schema import AuthSchema
|
|
from .model import UserModel
|
|
from .schema import UserCreateSchema, UserForgetPasswordSchema, UserUpdateSchema
|
|
from ..role.crud import RoleCRUD
|
|
from ..position.crud import PositionCRUD
|
|
|
|
|
|
class UserCRUD(CRUDBase[UserModel, UserCreateSchema, UserUpdateSchema]):
|
|
"""用户模块数据层"""
|
|
|
|
def __init__(self, auth: AuthSchema) -> None:
|
|
"""
|
|
初始化用户CRUD
|
|
|
|
参数:
|
|
- auth (AuthSchema): 认证信息模型
|
|
"""
|
|
self.auth = auth
|
|
super().__init__(model=UserModel, auth=auth)
|
|
|
|
async def get_by_id_crud(self, id: int, preload: list[str | Any] | None = None) -> UserModel | None:
|
|
"""
|
|
根据id获取用户信息
|
|
|
|
参数:
|
|
- id (int): 用户ID
|
|
- preload (list[str | Any] | None): 预加载关系,未提供时使用模型默认项
|
|
|
|
返回:
|
|
- UserModel | None: 用户信息,如果不存在则为None
|
|
"""
|
|
return await self.get(
|
|
preload=preload,
|
|
id=id,
|
|
)
|
|
|
|
async def get_by_username_crud(self, username: str, preload: list[str | Any] | None = None) -> UserModel | None:
|
|
"""
|
|
根据用户名获取用户信息
|
|
|
|
参数:
|
|
- username (str): 用户名
|
|
- preload (list[str | Any] | None): 预加载关系,未提供时使用模型默认项
|
|
|
|
返回:
|
|
- UserModel | None: 用户信息,如果不存在则为None
|
|
"""
|
|
return await self.get(
|
|
preload=preload,
|
|
username=username,
|
|
)
|
|
|
|
async def get_by_mobile_crud(self, mobile: str, preload: list[str | Any] | None = None) -> UserModel | None:
|
|
"""
|
|
根据手机号获取用户信息
|
|
|
|
参数:
|
|
- mobile (str): 手机号
|
|
- preload (list[str | Any] | None): 预加载关系,未提供时使用模型默认项
|
|
|
|
返回:
|
|
- UserModel | None: 用户信息,如果不存在则为None
|
|
"""
|
|
return await self.get(
|
|
preload=preload,
|
|
mobile=mobile,
|
|
)
|
|
|
|
async def get_list_crud(self, search: dict | None = None, order_by: list[dict[str, str]] | None = None, preload: list[str | Any] | None = None) -> Sequence[UserModel]:
|
|
"""
|
|
获取用户列表
|
|
|
|
参数:
|
|
- search (dict | None): 查询参数对象。
|
|
- order_by (list[dict[str, str]] | None): 排序参数列表。
|
|
- preload (list[str | Any] | None): 预加载关系,未提供时使用模型默认项
|
|
|
|
返回:
|
|
- Sequence[UserModel]: 用户列表
|
|
"""
|
|
return await self.list(
|
|
search=search,
|
|
order_by=order_by,
|
|
preload=preload,
|
|
)
|
|
|
|
async def update_last_login_crud(self, id: int) -> UserModel | None:
|
|
"""
|
|
更新用户最后登录时间
|
|
|
|
参数:
|
|
- id (int): 用户ID
|
|
|
|
返回:
|
|
- UserModel | None: 更新后的用户信息
|
|
"""
|
|
return await self.update(id=id, data={"last_login": datetime.now()})
|
|
|
|
async def set_available_crud(self, ids: list[int], status: str) -> None:
|
|
"""
|
|
批量设置用户可用状态
|
|
|
|
参数:
|
|
- ids (list[int]): 用户ID列表
|
|
- status (bool): 可用状态
|
|
|
|
返回:
|
|
- None:
|
|
"""
|
|
await self.set(ids=ids, status=status)
|
|
|
|
async def set_user_roles_crud(self, user_ids: list[int], role_ids: list[int]) -> None:
|
|
"""
|
|
批量设置用户角色
|
|
|
|
参数:
|
|
- user_ids (list[int]): 用户ID列表
|
|
- role_ids (list[int]): 角色ID列表
|
|
|
|
返回:
|
|
- None:
|
|
"""
|
|
user_objs = await self.list(search={"id": ("in", user_ids)})
|
|
if role_ids:
|
|
role_objs = await RoleCRUD(self.auth).get_list_crud(search={"id": ("in", role_ids)})
|
|
else:
|
|
role_objs = []
|
|
|
|
for obj in user_objs:
|
|
relationship = obj.roles
|
|
relationship.clear()
|
|
relationship.extend(role_objs)
|
|
await self.auth.db.flush()
|
|
|
|
async def set_user_positions_crud(self, user_ids: list[int], position_ids: list[int]) -> None:
|
|
"""
|
|
批量设置用户岗位
|
|
|
|
参数:
|
|
- user_ids (list[int]): 用户ID列表
|
|
- position_ids (list[int]): 岗位ID列表
|
|
|
|
返回:
|
|
- None:
|
|
"""
|
|
user_objs = await self.list(search={"id": ("in", user_ids)})
|
|
if position_ids:
|
|
position_objs = await PositionCRUD(self.auth).get_list_crud(search={"id": ("in", position_ids)})
|
|
else:
|
|
position_objs = []
|
|
|
|
for obj in user_objs:
|
|
relationship = obj.positions
|
|
relationship.clear()
|
|
relationship.extend(position_objs)
|
|
await self.auth.db.flush()
|
|
|
|
async def change_password_crud(self, id: int, password_hash: str) -> UserModel:
|
|
"""
|
|
修改用户密码
|
|
|
|
参数:
|
|
- id (int): 用户ID
|
|
- password_hash (str): 密码哈希值
|
|
|
|
返回:
|
|
- UserModel: 更新后的用户信息
|
|
"""
|
|
return await self.update(id=id, data=UserUpdateSchema(password=password_hash))
|
|
|
|
async def forget_password_crud(self, id: int, password_hash: str) -> UserModel:
|
|
"""
|
|
重置密码
|
|
|
|
参数:
|
|
- id (int): 用户ID
|
|
- password_hash (str): 密码哈希值
|
|
|
|
返回:
|
|
- UserModel: 更新后的用户信息
|
|
"""
|
|
return await self.update(id=id, data=UserUpdateSchema(password=password_hash))
|
|
|
|
async def register_user_crud(self, data: UserForgetPasswordSchema) -> UserModel:
|
|
"""
|
|
用户注册
|
|
|
|
参数:
|
|
- data (UserForgetPasswordSchema): 用户注册信息
|
|
|
|
返回:
|
|
- UserModel: 注册成功的用户信息
|
|
"""
|
|
return await self.create(data=UserCreateSchema(**data.model_dump()))
|
|
|
|
async def get_by_wx_openid_crud(self, wx_openid: str, preload: list[str | Any] | None = None) -> UserModel | None:
|
|
"""
|
|
根据微信小程序OpenID获取用户信息
|
|
|
|
参数:
|
|
- wx_openid (str): 微信小程序OpenID
|
|
- preload (list[str | Any] | None): 预加载关系,未提供时使用模型默认项
|
|
|
|
返回:
|
|
- UserModel | None: 用户信息,如果不存在则为None
|
|
"""
|
|
return await self.get(
|
|
preload=preload,
|
|
wx_openid=wx_openid,
|
|
)
|
|
|
|
async def bind_wx_openid_crud(self, id: int, wx_openid: str, wx_unionid: str | None = None) -> UserModel | None:
|
|
"""
|
|
绑定微信小程序OpenID
|
|
|
|
参数:
|
|
- id (int): 用户ID
|
|
- wx_openid (str): 微信小程序OpenID
|
|
- wx_unionid (str | None): 微信UnionID
|
|
|
|
返回:
|
|
- UserModel | None: 更新后的用户信息
|
|
"""
|
|
data = {"wx_openid": wx_openid}
|
|
if wx_unionid:
|
|
data["wx_unionid"] = wx_unionid
|
|
return await self.update(id=id, data=data) |