Files
----/后端源码/yifan.action-ai.cn/app/api/v1/module_system/user/crud.py

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)