feat&perf: 用户管理模块vo层优化,新增字段校验
This commit is contained in:
@@ -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信息')
|
||||||
|
Reference in New Issue
Block a user