#!/usr/bin/env python3 # -*- coding: utf-8 -*- from typing import Annotated from fastapi import APIRouter, Depends, Path, Query, Request from backend.app.common.jwt import DependsJwtAuth from backend.app.common.pagination import DependsPagination, paging_data from backend.app.common.permission import RequestPermission from backend.app.common.rbac import DependsRBAC from backend.app.common.response.response_schema import ResponseModel, response_base from backend.app.database.db_mysql import CurrentSession from backend.app.schemas.user import ( AddUserParam, AvatarParam, GetCurrentUserInfoDetail, GetUserInfoListDetails, RegisterUserParam, ResetPasswordParam, UpdateUserParam, UpdateUserRoleParam, ) from backend.app.services.user_service import user_service from backend.app.utils.serializers import select_as_dict router = APIRouter() @router.post('/register', summary='用户注册') async def user_register(obj: RegisterUserParam) -> ResponseModel: await user_service.register(obj=obj) return await response_base.success() @router.post('/add', summary='添加用户', dependencies=[DependsRBAC]) async def add_user(request: Request, obj: AddUserParam) -> ResponseModel: await user_service.add(request=request, obj=obj) current_user = await user_service.get_userinfo(username=obj.username) data = GetUserInfoListDetails(**await select_as_dict(current_user)) return await response_base.success(data=data) @router.post('/password/reset', summary='密码重置', dependencies=[DependsJwtAuth]) async def password_reset(request: Request, obj: ResetPasswordParam) -> ResponseModel: count = await user_service.pwd_reset(request=request, obj=obj) if count > 0: return await response_base.success() return await response_base.fail() @router.get('/me', summary='获取当前用户信息', dependencies=[DependsJwtAuth], response_model_exclude={'password'}) async def get_current_userinfo(request: Request) -> ResponseModel: data = GetCurrentUserInfoDetail(**await select_as_dict(request.user)) return await response_base.success(data=data) @router.get('/{username}', summary='查看用户信息', dependencies=[DependsJwtAuth]) async def get_user(username: Annotated[str, Path(...)]) -> ResponseModel: current_user = await user_service.get_userinfo(username=username) data = GetUserInfoListDetails(**await select_as_dict(current_user)) return await response_base.success(data=data) @router.put('/{username}', summary='更新用户信息', dependencies=[DependsJwtAuth]) async def update_userinfo(request: Request, username: Annotated[str, Path(...)], obj: UpdateUserParam) -> ResponseModel: count = await user_service.update(request=request, username=username, obj=obj) if count > 0: return await response_base.success() return await response_base.fail() @router.put( '/{username}/role', summary='更新用户角色', dependencies=[ Depends(RequestPermission('sys:user:role:edit')), DependsRBAC, ], ) async def update_user_role( request: Request, username: Annotated[str, Path(...)], obj: UpdateUserRoleParam ) -> ResponseModel: await user_service.update_roles(request=request, username=username, obj=obj) return await response_base.success() @router.put('/{username}/avatar', summary='更新头像', dependencies=[DependsJwtAuth]) async def update_avatar(request: Request, username: Annotated[str, Path(...)], avatar: AvatarParam) -> ResponseModel: count = await user_service.update_avatar(request=request, username=username, avatar=avatar) if count > 0: return await response_base.success() return await response_base.fail() @router.get( '', summary='(模糊条件)分页获取所有用户', dependencies=[ DependsJwtAuth, DependsPagination, ], ) async def get_pagination_users( db: CurrentSession, dept: Annotated[int | None, Query()] = None, username: Annotated[str | None, Query()] = None, phone: Annotated[str | None, Query()] = None, status: Annotated[int | None, Query()] = None, ): user_select = await user_service.get_select(dept=dept, username=username, phone=phone, status=status) page_data = await paging_data(db, user_select, GetUserInfoListDetails) return await response_base.success(data=page_data) @router.put('/{pk}/super', summary='修改用户超级权限', dependencies=[DependsRBAC]) async def super_set(request: Request, pk: Annotated[int, Path(...)]) -> ResponseModel: count = await user_service.update_permission(request=request, pk=pk) if count > 0: return await response_base.success() return await response_base.fail() @router.put('/{pk}/staff', summary='修改用户后台登录权限', dependencies=[DependsRBAC]) async def staff_set(request: Request, pk: Annotated[int, Path(...)]) -> ResponseModel: count = await user_service.update_staff(request=request, pk=pk) if count > 0: return await response_base.success() return await response_base.fail() @router.put('/{pk}/status', summary='修改用户状态', dependencies=[DependsRBAC]) async def status_set(request: Request, pk: Annotated[int, Path(...)]) -> ResponseModel: count = await user_service.update_status(request=request, pk=pk) if count > 0: return await response_base.success() return await response_base.fail() @router.put('/{pk}/multi', summary='修改用户多点登录状态', dependencies=[DependsRBAC]) async def multi_set(request: Request, pk: Annotated[int, Path(...)]) -> ResponseModel: count = await user_service.update_multi_login(request=request, pk=pk) if count > 0: return await response_base.success() return await response_base.fail() @router.delete( path='/{username}', summary='用户注销', description='用户注销 != 用户登出,注销之后用户将从数据库删除', dependencies=[ Depends(RequestPermission('sys:user:del')), DependsRBAC, ], ) async def delete_user(username: Annotated[str, Path(...)]) -> ResponseModel: count = await user_service.delete(username=username) if count > 0: return await response_base.success() return await response_base.fail()