Browse Source

feat&perf: 用户管理模块vo层优化,新增字段校验

master
insistence 11 months ago
parent
commit
0fa264a7bc
  1. 163
      ruoyi-fastapi-backend/module_admin/entity/vo/user_vo.py

163
ruoyi-fastapi-backend/module_admin/entity/vo/user_vo.py

@ -1,12 +1,13 @@
import re import re
from pydantic import BaseModel, ConfigDict, model_validator from pydantic import BaseModel, Field, ConfigDict, model_validator
from pydantic.alias_generators import to_camel from pydantic.alias_generators import to_camel
from typing import Union, Optional, List from typing import Union, Optional, List, Literal
from datetime import datetime from datetime import datetime
from module_admin.entity.vo.role_vo import RoleModel from module_admin.entity.vo.role_vo import RoleModel
from module_admin.entity.vo.dept_vo import DeptModel from module_admin.entity.vo.dept_vo import DeptModel
from module_admin.entity.vo.post_vo import PostModel from module_admin.entity.vo.post_vo import PostModel
from module_admin.annotation.pydantic_annotation import as_query, as_form from module_admin.annotation.pydantic_annotation import as_query, as_form
from module_admin.annotation.validate_annotation import NetWork, NotBlank, Size, Xss
from exceptions.exception import ModelValidatorException from exceptions.exception import ModelValidatorException
@ -14,7 +15,7 @@ class TokenData(BaseModel):
""" """
token解析结果 token解析结果
""" """
user_id: Union[int, None] = None user_id: Union[int, None] = Field(default=None, description='用户ID')
class UserModel(BaseModel): class UserModel(BaseModel):
@ -23,26 +24,26 @@ class UserModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True) model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
user_id: Optional[int] = None user_id: Optional[int] = Field(default=None, description='用户ID')
dept_id: Optional[int] = None dept_id: Optional[int] = Field(default=None, description='部门ID')
user_name: Optional[str] = None user_name: Optional[str] = Field(default=None, description='用户账号')
nick_name: Optional[str] = None nick_name: Optional[str] = Field(default=None, description='用户昵称')
user_type: Optional[str] = None user_type: Optional[str] = Field(default=None, description='用户类型(00系统用户)')
email: Optional[str] = None email: Optional[str] = Field(default=None, description='用户邮箱')
phonenumber: Optional[str] = None phonenumber: Optional[str] = Field(default=None, description='手机号码')
sex: Optional[str] = None sex: Optional[Literal['0', '1', '2']] = Field(default=None, description='用户性别(0男 1女 2未知)')
avatar: Optional[str] = None avatar: Optional[str] = Field(default=None, description='头像地址')
password: Optional[str] = None password: Optional[str] = Field(default=None, description='密码')
status: Optional[str] = None status: Optional[Literal['0', '1']] = Field(default=None, description='帐号状态(0正常 1停用)')
del_flag: Optional[str] = None del_flag: Optional[Literal['0', '2']] = Field(default=None, description='删除标志(0代表存在 2代表删除)')
login_ip: Optional[str] = None login_ip: Optional[str] = Field(default=None, description='最后登录IP')
login_date: Optional[datetime] = None login_date: Optional[datetime] = Field(default=None, description='最后登录时间')
create_by: Optional[str] = None create_by: Optional[str] = Field(default=None, description='创建者')
create_time: Optional[datetime] = None create_time: Optional[datetime] = Field(default=None, description='创建时间')
update_by: Optional[str] = None update_by: Optional[str] = Field(default=None, description='更新者')
update_time: Optional[datetime] = None update_time: Optional[datetime] = Field(default=None, description='更新时间')
remark: Optional[str] = None remark: Optional[str] = Field(default=None, description='备注')
admin: Optional[bool] = False admin: Optional[bool] = Field(default=False, description='是否为admin')
@model_validator(mode='after') @model_validator(mode='after')
def check_password(self) -> 'UserModel': def check_password(self) -> 'UserModel':
@ -60,6 +61,32 @@ class UserModel(BaseModel):
self.admin = False self.admin = False
return self return self
@Xss(field_name='user_name', message='用户账号不能包含脚本字符')
@NotBlank(field_name='user_name', message='用户账号不能为空')
@Size(field_name='user_name', min_length=0, max_length=30, message='用户账号长度不能超过30个字符')
def get_user_name(self):
return self.user_name
@Xss(field_name='nick_name', message='用户昵称不能包含脚本字符')
@Size(field_name='nick_name', min_length=0, max_length=30, message='用户昵称长度不能超过30个字符')
def get_nick_name(self):
return self.nick_name
@NetWork(field_name='email', field_type='EmailStr', message='邮箱格式不正确')
@Size(field_name='email', min_length=0, max_length=50, message='邮箱长度不能超过50个字符')
def get_email(self):
return self.email
@Size(field_name='phonenumber', min_length=0, max_length=11, message='手机号码长度不能超过11个字符')
def get_phonenumber(self):
return self.phonenumber
def validate_fields(self):
self.get_user_name()
self.get_nick_name()
self.get_email()
self.get_phonenumber()
class UserRoleModel(BaseModel): class UserRoleModel(BaseModel):
""" """
@ -67,8 +94,8 @@ class UserRoleModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True) model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
user_id: Optional[int] = None user_id: Optional[int] = Field(default=None, description='用户ID')
role_id: Optional[int] = None role_id: Optional[int] = Field(default=None, description='角色ID')
class UserPostModel(BaseModel): class UserPostModel(BaseModel):
@ -77,23 +104,23 @@ class UserPostModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True) model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
user_id: Optional[int] = None user_id: Optional[int] = Field(default=None, description='用户ID')
post_id: Optional[int] = None post_id: Optional[int] = Field(default=None, description='岗位ID')
class UserInfoModel(UserModel): class UserInfoModel(UserModel):
post_ids: Optional[Union[str, None]] = None post_ids: Optional[Union[str, None]] = Field(default=None, description='岗位ID信息')
role_ids: Optional[Union[str, None]] = None role_ids: Optional[Union[str, None]] = Field(default=None, description='角色ID信息')
dept: Optional[Union[DeptModel, None]] = None dept: Optional[Union[DeptModel, None]] = Field(default=None, description='部门信息')
role: Optional[List[Union[RoleModel, None]]] = [] role: Optional[List[Union[RoleModel, None]]] = Field(default=[], description='角色信息')
class CurrentUserModel(BaseModel): class CurrentUserModel(BaseModel):
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
permissions: List permissions: List = Field(description='权限信息')
roles: List roles: List = Field(description='角色信息')
user: Union[UserInfoModel, None] user: Union[UserInfoModel, None] = Field(description='用户信息')
class UserDetailModel(BaseModel): class UserDetailModel(BaseModel):
@ -102,11 +129,11 @@ class UserDetailModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
data: Optional[Union[UserInfoModel, None]] = None data: Optional[Union[UserInfoModel, None]] = Field(default=None, description='用户信息')
post_ids: Optional[List] = None post_ids: Optional[List] = Field(default=None, description='岗位ID信息')
posts: List[Union[PostModel, None]] posts: List[Union[PostModel, None]] = Field(description='岗位信息')
role_ids: Optional[List] = None role_ids: Optional[List] = Field(default=None, description='角色ID信息')
roles: List[Union[RoleModel, None]] roles: List[Union[RoleModel, None]] = Field(description='角色信息')
class UserProfileModel(BaseModel): class UserProfileModel(BaseModel):
@ -115,17 +142,17 @@ class UserProfileModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
data: Union[UserInfoModel, None] data: Union[UserInfoModel, None] = Field(description='用户信息')
post_group: Union[str, None] post_group: Union[str, None] = Field(description='岗位信息')
role_group: Union[str, None] role_group: Union[str, None] = Field(description='角色信息')
class UserQueryModel(UserModel): class UserQueryModel(UserModel):
""" """
用户管理不分页查询模型 用户管理不分页查询模型
""" """
begin_time: Optional[str] = None begin_time: Optional[str] = Field(default=None, description='开始时间')
end_time: Optional[str] = None end_time: Optional[str] = Field(default=None, description='结束时间')
@as_query @as_query
@ -134,24 +161,24 @@ class UserPageQueryModel(UserQueryModel):
""" """
用户管理分页查询模型 用户管理分页查询模型
""" """
page_num: int = 1 page_num: int = Field(default=1, description='当前页码')
page_size: int = 10 page_size: int = Field(default=10, description='每页记录数')
class AddUserModel(UserModel): class AddUserModel(UserModel):
""" """
新增用户模型 新增用户模型
""" """
role_ids: Optional[List] = [] role_ids: Optional[List] = Field(default=[], description='角色ID信息')
post_ids: Optional[List] = [] post_ids: Optional[List] = Field(default=[], description='岗位ID信息')
type: Optional[str] = None type: Optional[str] = Field(default=None, description='操作类型')
class EditUserModel(AddUserModel): class EditUserModel(AddUserModel):
""" """
编辑用户模型 编辑用户模型
""" """
role: Optional[List] = [] role: Optional[List] = Field(default=[], description='角色信息')
@as_query @as_query
@ -161,8 +188,8 @@ class ResetPasswordModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
old_password: Optional[str] = None old_password: Optional[str] = Field(default=None, description='旧密码')
new_password: Optional[str] = None new_password: Optional[str] = Field(default=None, description='新密码')
@model_validator(mode='after') @model_validator(mode='after')
def check_new_password(self) -> 'ResetPasswordModel': def check_new_password(self) -> 'ResetPasswordModel':
@ -177,9 +204,9 @@ class ResetUserModel(UserModel):
""" """
重置用户密码模型 重置用户密码模型
""" """
old_password: Optional[str] = None old_password: Optional[str] = Field(default=None, description='旧密码')
sms_code: Optional[str] = None sms_code: Optional[str] = Field(default=None, description='验证码')
session_id: Optional[str] = None session_id: Optional[str] = Field(default=None, description='会话id')
class DeleteUserModel(BaseModel): class DeleteUserModel(BaseModel):
@ -188,16 +215,16 @@ class DeleteUserModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
user_ids: str user_ids: str = Field(description='需要删除的用户ID')
update_by: Optional[str] = None update_by: Optional[str] = Field(default=None, description='更新者')
update_time: Optional[datetime] = None update_time: Optional[datetime] = Field(default=None, description='更新时间')
class UserRoleQueryModel(UserModel): class UserRoleQueryModel(UserModel):
""" """
用户角色关联管理不分页查询模型 用户角色关联管理不分页查询模型
""" """
role_id: Optional[int] = None role_id: Optional[int] = Field(default=None, description='角色ID')
@as_query @as_query
@ -205,15 +232,15 @@ class UserRolePageQueryModel(UserRoleQueryModel):
""" """
用户角色关联管理分页查询模型 用户角色关联管理分页查询模型
""" """
page_num: int = 1 page_num: int = Field(default=1, description='当前页码')
page_size: int = 10 page_size: int = Field(default=10, description='每页记录数')
class SelectedRoleModel(RoleModel): class SelectedRoleModel(RoleModel):
""" """
是否选择角色模型 是否选择角色模型
""" """
flag: Optional[bool] = False flag: Optional[bool] = Field(default=False, description='选择标识')
class UserRoleResponseModel(BaseModel): class UserRoleResponseModel(BaseModel):
@ -222,8 +249,8 @@ class UserRoleResponseModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
roles: List[Union[SelectedRoleModel, None]] = [] roles: List[Union[SelectedRoleModel, None]] = Field(default=[], description='角色信息')
user: UserInfoModel user: UserInfoModel = Field(description='用户信息')
@as_query @as_query
@ -233,7 +260,7 @@ class CrudUserRoleModel(BaseModel):
""" """
model_config = ConfigDict(alias_generator=to_camel) model_config = ConfigDict(alias_generator=to_camel)
user_id: Optional[int] = None user_id: Optional[int] = Field(default=None, description='用户ID')
user_ids: Optional[str] = None user_ids: Optional[str] = Field(default=None, description='用户ID信息')
role_id: Optional[int] = None role_id: Optional[int] = Field(default=None, description='角色ID')
role_ids: Optional[str] = None role_ids: Optional[str] = Field(default=None, description='角色ID信息')

Loading…
Cancel
Save