262 lines
12 KiB
Python
262 lines
12 KiB
Python
from datetime import datetime
|
||
from pydantic import BaseModel, ConfigDict, Field, model_validator
|
||
from pydantic.alias_generators import to_camel
|
||
from pydantic_validation_decorator import NotBlank
|
||
from typing import List, Literal, Optional
|
||
from config.constant import GenConstant
|
||
from module_admin.annotation.pydantic_annotation import as_query
|
||
from utils.string_util import StringUtil
|
||
|
||
|
||
class GenTableBaseModel(BaseModel):
|
||
"""
|
||
代码生成业务表对应pydantic模型
|
||
"""
|
||
|
||
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
|
||
|
||
table_id: Optional[int] = Field(default=None, description='编号')
|
||
table_name: Optional[str] = Field(default=None, description='表名称')
|
||
table_comment: Optional[str] = Field(default=None, description='表描述')
|
||
sub_table_name: Optional[str] = Field(default=None, description='关联子表的表名')
|
||
sub_table_fk_name: Optional[str] = Field(default=None, description='子表关联的外键名')
|
||
class_name: Optional[str] = Field(default=None, description='实体类名称')
|
||
tpl_category: Optional[str] = Field(default=None, description='使用的模板(crud单表操作 tree树表操作)')
|
||
tpl_web_type: Optional[str] = Field(default=None, description='前端模板类型(element-ui模版 element-plus模版)')
|
||
package_name: Optional[str] = Field(default=None, description='生成包路径')
|
||
module_name: Optional[str] = Field(default=None, description='生成模块名')
|
||
business_name: Optional[str] = Field(default=None, description='生成业务名')
|
||
function_name: Optional[str] = Field(default=None, description='生成功能名')
|
||
function_author: Optional[str] = Field(default=None, description='生成功能作者')
|
||
gen_type: Optional[Literal['0', '1']] = Field(default=None, description='生成代码方式(0zip压缩包 1自定义路径)')
|
||
gen_path: Optional[str] = Field(default=None, description='生成路径(不填默认项目路径)')
|
||
options: Optional[str] = Field(default=None, description='其它生成选项')
|
||
create_by: Optional[str] = Field(default=None, description='创建者')
|
||
create_time: Optional[datetime] = Field(default=None, description='创建时间')
|
||
update_by: Optional[str] = Field(default=None, description='更新者')
|
||
update_time: Optional[datetime] = Field(default=None, description='更新时间')
|
||
remark: Optional[str] = Field(default=None, description='备注')
|
||
|
||
@NotBlank(field_name='table_name', message='表名称不能为空')
|
||
def get_table_name(self):
|
||
return self.table_name
|
||
|
||
@NotBlank(field_name='table_comment', message='表描述不能为空')
|
||
def get_table_comment(self):
|
||
return self.table_comment
|
||
|
||
@NotBlank(field_name='class_name', message='实体类名称不能为空')
|
||
def get_class_name(self):
|
||
return self.class_name
|
||
|
||
@NotBlank(field_name='package_name', message='生成包路径不能为空')
|
||
def get_package_name(self):
|
||
return self.package_name
|
||
|
||
@NotBlank(field_name='module_name', message='生成模块名不能为空')
|
||
def get_module_name(self):
|
||
return self.module_name
|
||
|
||
@NotBlank(field_name='business_name', message='生成业务名不能为空')
|
||
def get_business_name(self):
|
||
return self.business_name
|
||
|
||
@NotBlank(field_name='function_name', message='生成功能名不能为空')
|
||
def get_function_name(self):
|
||
return self.function_name
|
||
|
||
@NotBlank(field_name='function_author', message='生成功能作者不能为空')
|
||
def get_function_author(self):
|
||
return self.function_author
|
||
|
||
def validate_fields(self):
|
||
self.get_table_name()
|
||
self.get_table_comment()
|
||
self.get_class_name()
|
||
self.get_package_name()
|
||
self.get_module_name()
|
||
self.get_business_name()
|
||
self.get_function_name()
|
||
self.get_function_author()
|
||
|
||
|
||
class GenTableModel(GenTableBaseModel):
|
||
"""
|
||
代码生成业务表模型
|
||
"""
|
||
|
||
pk_column: Optional['GenTableColumnModel'] = Field(default=None, description='主键信息')
|
||
sub_table: Optional['GenTableModel'] = Field(default=None, description='子表信息')
|
||
columns: Optional[List['GenTableColumnModel']] = Field(default=None, description='表列信息')
|
||
tree_code: Optional[str] = Field(default=None, description='树编码字段')
|
||
tree_parent_code: Optional[str] = Field(default=None, description='树父编码字段')
|
||
tree_name: Optional[str] = Field(default=None, description='树名称字段')
|
||
parent_menu_id: Optional[int] = Field(default=None, description='上级菜单ID字段')
|
||
parent_menu_name: Optional[str] = Field(default=None, description='上级菜单名称字段')
|
||
sub: Optional[bool] = Field(default=None, description='是否为子表')
|
||
tree: Optional[bool] = Field(default=None, description='是否为树表')
|
||
crud: Optional[bool] = Field(default=None, description='是否为单表')
|
||
|
||
@model_validator(mode='after')
|
||
def check_some_is(self) -> 'GenTableModel':
|
||
self.sub = True if self.tpl_category and self.tpl_category == GenConstant.TPL_SUB else False
|
||
self.tree = True if self.tpl_category and self.tpl_category == GenConstant.TPL_TREE else False
|
||
self.crud = True if self.tpl_category and self.tpl_category == GenConstant.TPL_CRUD else False
|
||
return self
|
||
|
||
|
||
class EditGenTableModel(GenTableModel):
|
||
"""
|
||
修改代码生成业务表模型
|
||
"""
|
||
|
||
params: Optional['GenTableParamsModel'] = Field(default=None, description='业务表参数')
|
||
|
||
|
||
class GenTableParamsModel(BaseModel):
|
||
"""
|
||
代码生成业务表参数模型
|
||
"""
|
||
|
||
model_config = ConfigDict(alias_generator=to_camel)
|
||
|
||
tree_code: Optional[str] = Field(default=None, description='树编码字段')
|
||
tree_parent_code: Optional[str] = Field(default=None, description='树父编码字段')
|
||
tree_name: Optional[str] = Field(default=None, description='树名称字段')
|
||
parent_menu_id: Optional[int] = Field(default=None, description='上级菜单ID字段')
|
||
|
||
|
||
class GenTableQueryModel(GenTableBaseModel):
|
||
"""
|
||
代码生成业务表不分页查询模型
|
||
"""
|
||
|
||
begin_time: Optional[str] = Field(default=None, description='开始时间')
|
||
end_time: Optional[str] = Field(default=None, description='结束时间')
|
||
|
||
|
||
@as_query
|
||
class GenTablePageQueryModel(GenTableQueryModel):
|
||
"""
|
||
代码生成业务表分页查询模型
|
||
"""
|
||
|
||
page_num: int = Field(default=1, description='当前页码')
|
||
page_size: int = Field(default=10, description='每页记录数')
|
||
|
||
|
||
class DeleteGenTableModel(BaseModel):
|
||
"""
|
||
删除代码生成业务表模型
|
||
"""
|
||
|
||
model_config = ConfigDict(alias_generator=to_camel)
|
||
|
||
table_ids: str = Field(description='需要删除的代码生成业务表ID')
|
||
|
||
|
||
class GenTableColumnBaseModel(BaseModel):
|
||
"""
|
||
代码生成业务表字段对应pydantic模型
|
||
"""
|
||
|
||
model_config = ConfigDict(alias_generator=to_camel, from_attributes=True)
|
||
|
||
column_id: Optional[int] = Field(default=None, description='编号')
|
||
table_id: Optional[int] = Field(default=None, description='归属表编号')
|
||
column_name: Optional[str] = Field(default=None, description='列名称')
|
||
column_comment: Optional[str] = Field(default=None, description='列描述')
|
||
column_type: Optional[str] = Field(default=None, description='列类型')
|
||
python_type: Optional[str] = Field(default=None, description='PYTHON类型')
|
||
python_field: Optional[str] = Field(default=None, description='PYTHON字段名')
|
||
is_pk: Optional[str] = Field(default=None, description='是否主键(1是)')
|
||
is_increment: Optional[str] = Field(default=None, description='是否自增(1是)')
|
||
is_required: Optional[str] = Field(default=None, description='是否必填(1是)')
|
||
is_insert: Optional[str] = Field(default=None, description='是否为插入字段(1是)')
|
||
is_edit: Optional[str] = Field(default=None, description='是否编辑字段(1是)')
|
||
is_list: Optional[str] = Field(default=None, description='是否列表字段(1是)')
|
||
is_query: Optional[str] = Field(default=None, description='是否查询字段(1是)')
|
||
query_type: Optional[str] = Field(default=None, description='查询方式(等于、不等于、大于、小于、范围)')
|
||
html_type: Optional[str] = Field(
|
||
default=None, description='显示类型(文本框、文本域、下拉框、复选框、单选框、日期控件)'
|
||
)
|
||
dict_type: Optional[str] = Field(default=None, description='字典类型')
|
||
sort: Optional[int] = Field(default=None, description='排序')
|
||
create_by: Optional[str] = Field(default=None, description='创建者')
|
||
create_time: Optional[datetime] = Field(default=None, description='创建时间')
|
||
update_by: Optional[str] = Field(default=None, description='更新者')
|
||
update_time: Optional[datetime] = Field(default=None, description='更新时间')
|
||
|
||
@NotBlank(field_name='python_field', message='Python属性不能为空')
|
||
def get_python_field(self):
|
||
return self.python_field
|
||
|
||
def validate_fields(self):
|
||
self.get_python_field()
|
||
|
||
|
||
class GenTableColumnModel(GenTableColumnBaseModel):
|
||
"""
|
||
代码生成业务表字段模型
|
||
"""
|
||
|
||
cap_python_field: Optional[str] = Field(default=None, description='字段大写形式')
|
||
pk: Optional[bool] = Field(default=None, description='是否主键')
|
||
increment: Optional[bool] = Field(default=None, description='是否自增')
|
||
required: Optional[bool] = Field(default=None, description='是否必填')
|
||
insert: Optional[bool] = Field(default=None, description='是否为插入字段')
|
||
edit: Optional[bool] = Field(default=None, description='是否编辑字段')
|
||
list: Optional[bool] = Field(default=None, description='是否列表字段')
|
||
query: Optional[bool] = Field(default=None, description='是否查询字段')
|
||
super_column: Optional[bool] = Field(default=None, description='是否为基类字段')
|
||
usable_column: Optional[bool] = Field(default=None, description='是否为基类字段白名单')
|
||
|
||
@model_validator(mode='after')
|
||
def check_some_is(self) -> 'GenTableModel':
|
||
self.cap_python_field = self.python_field[0].upper() + self.python_field[1:] if self.python_field else None
|
||
self.pk = True if self.is_pk and self.is_pk == '1' else False
|
||
self.increment = True if self.is_increment and self.is_increment == '1' else False
|
||
self.required = True if self.is_required and self.is_required == '1' else False
|
||
self.insert = True if self.is_insert and self.is_insert == '1' else False
|
||
self.edit = True if self.is_edit and self.is_edit == '1' else False
|
||
self.list = True if self.is_list and self.is_list == '1' else False
|
||
self.query = True if self.is_query and self.is_query == '1' else False
|
||
self.super_column = (
|
||
True
|
||
if StringUtil.equals_any_ignore_case(self.python_field, GenConstant.TREE_ENTITY + GenConstant.BASE_ENTITY)
|
||
else False
|
||
)
|
||
self.usable_column = (
|
||
True if StringUtil.equals_any_ignore_case(self.python_field, ['parentId', 'orderNum', 'remark']) else False
|
||
)
|
||
return self
|
||
|
||
|
||
class GenTableColumnQueryModel(GenTableColumnBaseModel):
|
||
"""
|
||
代码生成业务表字段不分页查询模型
|
||
"""
|
||
|
||
begin_time: Optional[str] = Field(default=None, description='开始时间')
|
||
end_time: Optional[str] = Field(default=None, description='结束时间')
|
||
|
||
|
||
@as_query
|
||
class GenTableColumnPageQueryModel(GenTableColumnQueryModel):
|
||
"""
|
||
代码生成业务表字段分页查询模型
|
||
"""
|
||
|
||
page_num: int = Field(default=1, description='当前页码')
|
||
page_size: int = Field(default=10, description='每页记录数')
|
||
|
||
|
||
class DeleteGenTableColumnModel(BaseModel):
|
||
"""
|
||
删除代码生成业务表字段模型
|
||
"""
|
||
|
||
model_config = ConfigDict(alias_generator=to_camel)
|
||
|
||
column_ids: str = Field(description='需要删除的代码生成业务表字段ID')
|