upload project source code

This commit is contained in:
2026-04-30 18:49:43 +08:00
commit 9b394ba682
2277 changed files with 660945 additions and 0 deletions

View File

@@ -0,0 +1,722 @@
# -*- coding: utf-8 -*-
from enum import Enum
from typing import Protocol
from app.config.setting import settings
class RET(Enum):
"""
系统返回码枚举
0~200: 成功状态码
400~600: HTTP标准错误码
4000+: 自定义业务错误码
"""
# 成功状态码
OK = (0, "成功")
SUCCESS = (200, "操作成功")
CREATED = (201, "创建成功")
ACCEPTED = (202, "请求已接受")
NO_CONTENT = (204, "操作成功,无返回数据")
# HTTP标准错误码
ERROR = (1, "请求错误")
BAD_REQUEST = (400, "参数错误")
UNAUTHORIZED = (401, "未授权")
FORBIDDEN = (403, "访问受限")
NOT_FOUND = (404, "资源不存在")
BAD_METHOD = (405, "不支持的请求方法")
NOT_ACCEPTABLE = (406, "不接受的请求")
CONFLICT = (409, "资源冲突")
GONE = (410, "资源已删除")
PRECONDITION_FAILED = (412, "前提条件失败")
UNSUPPORTED_MEDIA_TYPE = (415, "不支持的媒体类型")
UNPROCESSABLE_ENTITY = (422, "无法处理的实体")
TOO_MANY_REQUESTS = (429, "请求过于频繁")
# 服务器错误码
INTERNAL_SERVER_ERROR = (500, "服务器内部错误")
NOT_IMPLEMENTED = (501, "功能未实现")
BAD_GATEWAY = (502, "网关错误")
SERVICE_UNAVAILABLE = (503, "服务不可用")
GATEWAY_TIMEOUT = (504, "网关超时")
HTTP_VERSION_NOT_SUPPORTED = (505, "HTTP版本不支持")
# 自定义业务错误码
EXCEPTION = (-1, "系统异常")
DATAEXIST = (4003, "数据已存在")
DATAERR = (4004, "数据错误")
PARAMERR = (4103, "参数错误")
IOERR = (4302, "IO错误")
SERVERERR = (4500, "服务错误")
UNKOWNERR = (4501, "未知错误")
TIMEOUT = (4502, "请求超时")
RATE_LIMIT_EXCEEDED = (4503, "访问频率超限")
# Token相关错误码
INVALID_TOKEN = (4504, "无效令牌")
EXPIRED_TOKEN = (4505, "令牌过期")
# 认证授权错误码
INVALID_CREDENTIALS = (4506, "无效凭证")
INVALID_REQUEST = (4507, "无效请求")
INVALID_FORMAT = (4508, "格式错误")
INVALID_INPUT = (4509, "输入错误")
INVALID_STATE = (4510, "状态错误")
INVALID_OPERATION = (4511, "操作错误")
INVALID_PERMISSION = (4512, "权限错误")
INVALID_RESOURCE = (4513, "资源错误")
INVALID_CONFIGURATION = (4514, "配置错误")
# 会话安全错误码
INVALID_SESSION = (4515, "会话错误")
INVALID_LICENSE = (4516, "许可证错误")
INVALID_CERTIFICATE = (4517, "证书错误")
INVALID_SIGNATURE = (4518, "签名错误")
INVALID_ENCRYPTION = (4519, "加密错误")
INVALID_DECRYPTION = (4520, "解密错误")
INVALID_COMPRESSION = (4521, "压缩错误")
INVALID_DECOMPRESSION = (4522, "解压错误")
# 权限相关错误码
INVALID_AUTHENTICATION = (4523, "认证错误")
INVALID_AUTHORIZATION = (4524, "授权错误")
INVALID_ACCESS = (4525, "访问错误")
INVALID_SECURITY = (4526, "安全错误")
# 系统组件错误码
INVALID_NETWORK = (4527, "网络错误")
INVALID_DATABASE = (4528, "数据库错误")
INVALID_CACHE = (4529, "缓存错误")
INVALID_QUEUE = (4530, "队列错误")
INVALID_LOCK = (4531, "锁错误")
INVALID_TRANSACTION = (4532, "事务错误")
INVALID_LOG = (4533, "日志错误")
INVALID_MONITORING = (4534, "监控错误")
INVALID_NOTIFICATION = (4535, "通知错误")
# 任务调度错误码
INVALID_SCHEDULING = (4536, "调度错误")
INVALID_TASK = (4537, "任务错误")
INVALID_JOB = (4538, "作业错误")
INVALID_WORKFLOW = (4539, "工作流错误")
# 开发相关错误码
INVALID_SCRIPT = (4540, "脚本错误")
INVALID_PLUGIN = (4541, "插件错误")
INVALID_MODULE = (4542, "模块错误")
INVALID_PACKAGE = (4543, "包错误")
INVALID_CLASS = (4544, "类错误")
INVALID_FUNCTION = (4545, "函数错误")
INVALID_METHOD = (4546, "方法错误")
INVALID_PROPERTY = (4547, "属性错误")
INVALID_VARIABLE = (4548, "变量错误")
INVALID_CONSTANT = (4549, "常量错误")
INVALID_ENUM = (4550, "枚举错误")
INVALID_INTERFACE = (4551, "接口错误")
INVALID_PROTOCOL = (4552, "协议错误")
# 服务相关错误码
INVALID_SERVICE = (4553, "服务错误")
INVALID_CLIENT = (4554, "客户端错误")
INVALID_SERVER = (4555, "服务器错误")
INVALID_SYSTEM = (4556, "系统错误")
# 用户权限错误码
INVALID_USER = (4557, "用户错误")
INVALID_GROUP = (4558, "用户组错误")
INVALID_ROLE = (4559, "角色错误")
INVALID_PERMISSION_GROUP = (4560, "权限组错误")
INVALID_PERMISSION_ROLE = (4561, "权限角色错误")
INVALID_PERMISSION_USER = (4562, "权限用户错误")
INVALID_PERMISSION_RESOURCE = (4563, "权限资源错误")
INVALID_PERMISSION_ACTION = (4564, "权限操作错误")
INVALID_PERMISSION_SCOPE = (4565, "权限范围错误")
INVALID_PERMISSION_LEVEL = (4566, "权限级别错误")
INVALID_PERMISSION_TYPE = (4567, "权限类型错误")
INVALID_PERMISSION_STATUS = (4568, "权限状态错误")
INVALID_PERMISSION_TIME = (4569, "权限时间错误")
INVALID_PERMISSION_CONDITION = (4570, "权限条件错误")
INVALID_PERMISSION_POLICY = (4571, "权限策略错误")
INVALID_PERMISSION_RULE = (4572, "权限规则错误")
INVALID_PERMISSION_EXCEPTION = (4573, "权限异常错误")
INVALID_PERMISSION_VALIDATION = (4574, "权限验证错误")
INVALID_PERMISSION_AUTHENTICATION = (4575, "权限认证错误")
INVALID_PERMISSION_AUTHORIZATION = (4576, "权限授权错误")
INVALID_PERMISSION_ACCESS = (4577, "权限访问错误")
INVALID_PERMISSION_SECURITY = (4578, "权限安全错误")
INVALID_PERMISSION_NETWORK = (4579, "权限网络错误")
INVALID_PERMISSION_DATABASE = (4580, "权限数据库错误")
INVALID_PERMISSION_CACHE = (4581, "权限缓存错误")
INVALID_PERMISSION_QUEUE = (4582, "权限队列错误")
INVALID_PERMISSION_LOCK = (4583, "权限锁错误")
INVALID_PERMISSION_TRANSACTION = (4584, "权限事务错误")
INVALID_PERMISSION_LOG = (4585, "权限日志错误")
INVALID_PERMISSION_MONITORING = (4586, "权限监控错误")
INVALID_PERMISSION_NOTIFICATION = (4587, "权限通知错误")
INVALID_PERMISSION_SCHEDULING = (4588, "权限调度错误")
INVALID_PERMISSION_TASK = (4589, "权限任务错误")
INVALID_PERMISSION_JOB = (4590, "权限作业错误")
INVALID_PERMISSION_WORKFLOW = (4591, "权限工作流错误")
INVALID_PERMISSION_SCRIPT = (4592, "权限脚本错误")
INVALID_PERMISSION_PLUGIN = (4593, "权限插件错误")
INVALID_PERMISSION_MODULE = (4594, "权限模块错误")
INVALID_PERMISSION_PACKAGE = (4595, "权限包错误")
INVALID_PERMISSION_CLASS = (4596, "权限类错误")
INVALID_PERMISSION_FUNCTION = (4597, "权限函数错误")
INVALID_PERMISSION_METHOD = (4598, "权限方法错误")
INVALID_PERMISSION_PROPERTY = (4599, "权限属性错误")
INVALID_PERMISSION_VARIABLE = (4600, "权限变量错误")
INVALID_PERMISSION_CONSTANT = (4601, "权限常量错误")
INVALID_PERMISSION_ENUM = (4602, "权限枚举错误")
INVALID_PERMISSION_INTERFACE = (4603, "权限接口错误")
INVALID_PERMISSION_PROTOCOL = (4604, "权限协议错误")
INVALID_PERMISSION_SERVICE = (4605, "权限服务错误")
INVALID_PERMISSION_CLIENT = (4606, "权限客户端错误")
INVALID_PERMISSION_SERVER = (4607, "权限服务器错误")
INVALID_PERMISSION_SYSTEM = (4608, "权限系统错误")
def __init__(self, code: int, msg: str):
"""
初始化返回码。
参数:
- code (int): 错误码。
- msg (str): 错误信息。
返回:
- None
"""
self._code = code
self._msg = msg
@property
def code(self) -> int:
"""获取错误码"""
return self._code
@property
def msg(self) -> str:
"""获取错误信息"""
return self._msg
class CommonConstant:
"""
常用常量
WWW: www主域名
HTTP: http请求
HTTPS: https请求
LOOKUP_RMI: RMI远程方法调用
LOOKUP_LDAP: LDAP远程方法调用
LOOKUP_LDAPS: LDAPS远程方法调用
YES: 是否为系统默认(是)
NO: 是否为系统默认(否)
DEPT_NORMAL: 部门正常状态
DEPT_DISABLE: 部门停用状态
UNIQUE: 校验是否唯一的返回标识(是)
NOT_UNIQUE: 校验是否唯一的返回标识(否)
"""
# 域名相关
WWW = "www."
HTTP = "http://"
HTTPS = "https://"
# 远程调用
LOOKUP_RMI = "rmi:"
LOOKUP_LDAP = "ldap:"
LOOKUP_LDAPS = "ldaps:"
# 系统标识
YES = "Y"
NO = "N"
# 部门状态
DEPT_NORMAL = "0" # 正常
DEPT_DISABLE = "1" # 停用
# 唯一性校验
UNIQUE = True
NOT_UNIQUE = False
class JobConstant:
"""
定时任务常量
JOB_ERROR_LIST: 定时任务禁止调用模块及违规字符串列表
JOB_WHITE_LIST: 定时任务允许调用模块列表
"""
JOB_ERROR_LIST = [
"app",
"config",
"exceptions",
"import ",
"middlewares",
"module_admin",
"open(",
"os.",
"server",
"sub_applications",
"subprocess.",
"sys.",
"utils",
"while ",
"__import__",
""",
""",
",",
"?",
":",
";",
"/",
"|",
"+",
"-",
"=",
"~",
"!",
"#",
"$",
"%",
"^",
"&",
"*",
"<",
">",
"(",
")",
"[",
"]",
"{",
"}",
" ",
]
JOB_WHITE_LIST = ["function_task"]
class MenuConstant:
"""
菜单常量
TYPE_DIR: 菜单类型(目录)
TYPE_MENU: 菜单类型(菜单)
TYPE_BUTTON: 菜单类型(按钮)
YES_FRAME: 是否菜单外链(是)
NO_FRAME: 是否菜单外链(否)
LAYOUT: Layout组件标识
PARENT_VIEW: ParentView组件标识
INNER_LINK: InnerLink组件标识
"""
TYPE_DIR = "M"
TYPE_MENU = "C"
TYPE_BUTTON = "F"
YES_FRAME = 0
NO_FRAME = 1
LAYOUT = "Layout"
PARENT_VIEW = "ParentView"
INNER_LINK = "InnerLink"
class GenConstant:
"""
代码生成常量
COLUMNTYPE_STR: 数据库字符串类型
COLUMNTYPE_TEXT: 数据库文本类型
COLUMNTYPE_TIME: 数据库时间类型
COLUMNTYPE_GEOMETRY: 数据库字空间类型
COLUMNTYPE_NUMBER: 数据库数字类型
COLUMNNAME_NOT_EDIT: 页面不需要编辑字段
COLUMNNAME_NOT_LIST: 页面不需要显示的列表字段
COLUMNNAME_NOT_QUERY: 页面不需要查询字段
BASE_ENTITY: Entity基类字段
TREE_ENTITY: Tree基类字段
HTML_INPUT: 文本框
HTML_TEXTAREA: 文本域
HTML_SELECT: 下拉框
HTML_RADIO: 单选框
HTML_CHECKBOX: 复选框
HTML_DATETIME: 日期控件
HTML_IMAGE_UPLOAD: 图片上传控件
HTML_FILE_UPLOAD: 文件上传控件
HTML_EDITOR: 富文本控件
TYPE_DECIMAL: 高精度计算类型
TYPE_DATE: 时间类型
QUERY_LIKE: 模糊查询
QUERY_EQ: 相等查询
REQUIRE: 需要
DB_TO_SQLALCHEMY_TYPE_MAPPING: 数据库类型与sqlalchemy类型映射
DB_TO_PYTHON_TYPE_MAPPING: 数据库类型与python类型映射
"""
# 数据库字符串类型
COLUMNTYPE_STR = (
["character varying", "varchar", "character", "char"]
if settings.DATABASE_TYPE == "postgres"
else ["char", "varchar", "nvarchar", "varchar2"]
)
# 数据库文本类型
COLUMNTYPE_TEXT = (
["text", "citext"] if settings.DATABASE_TYPE == "postgres" else ["tinytext", "text", "mediumtext", "longtext"]
)
# 数据库时间类型
COLUMNTYPE_TIME = (
[
"date",
"time",
"time with time zone",
"time without time zone",
"timestamp",
"timestamp with time zone",
"timestamp without time zone",
"interval",
]
if settings.DATABASE_TYPE == "postgres"
else ["datetime", "time", "date", "timestamp"]
)
# 数据库字空间类型
COLUMNTYPE_GEOMETRY = (
["point", "line", "lseg", "box", "path", "polygon", "circle"]
if settings.DATABASE_TYPE == "postgres"
else [
"geometry",
"point",
"linestring",
"polygon",
"multipoint",
"multilinestring",
"multipolygon",
"geometrycollection",
]
)
# 数据库数字类型
COLUMNTYPE_NUMBER = [
"tinyint",
"smallint",
"mediumint",
"int",
"number",
"integer",
"bit",
"bigint",
"float",
"double",
"decimal",
"boolean",
"bool"
]
# 页面不需要显示的添加字段
COLUMNNAME_NOT_ADD_SHOW = ["created_time", "updated_time"]
# 页面不需要显示的编辑字段
COLUMNNAME_NOT_EDIT_SHOW = ["uuid"]
# 页面不需要编辑字段
COLUMNNAME_NOT_EDIT = ["id", "uuid", "created_time", "updated_time"]
# 页面不需要显示的列表字段
COLUMNNAME_NOT_LIST = ["id", "uuid"]
# 页面不需要查询字段
COLUMNNAME_NOT_QUERY = ["id", "uuid", "description"]
# Crud基类字段
CRUD_COLUMN_NOT_EDIT = ["create_by", "description", "created_time", "updated_time"]
# 实体基类字段
BASE_ENTITY = ["id", "uuid", "status", "description", "created_time", "updated_time", "created_id", "updated_id"]
# Tree基类字段
TREE_ENTITY = ["parent_name", "parent_id", "order", "ancestors", "children"]
# 文本框
HTML_INPUT = "input"
# 文本域
HTML_TEXTAREA = "textarea"
# 下拉框
HTML_SELECT = "select"
# 单选框
HTML_RADIO = "radio"
# 复选框
HTML_CHECKBOX = "checkbox"
# 日期控件
HTML_DATETIME = "datetime"
# 图片上传控件
HTML_IMAGE_UPLOAD = "imageUpload"
# 文件上传控件
HTML_FILE_UPLOAD = "fileUpload"
# 富文本控件
HTML_EDITOR = "editor"
# 高精度计算类型
TYPE_DECIMAL = "Decimal"
# 时间类型
TYPE_DATE = ["date", "time", "datetime"]
# 模糊查询
QUERY_LIKE = "LIKE"
# 相等查询
QUERY_EQ = "EQ"
# 需要
REQUIRE = True
# 数据库类型与sqlalchemy类型映射
DB_TO_SQLALCHEMY = {
"boolean": "Boolean",
"smallint": "SmallInteger",
"integer": "Integer",
"int4": "Integer",
"bigint": "BigInteger",
"real": "Float",
"double precision": "Float",
"numeric": "Numeric",
"character varying": "String",
"varchar": "String",
"character": "String",
"text": "Text",
"bytea": "LargeBinary",
"date": "Date",
"time": "Time",
"time with time zone": "Time",
"time without time zone": "Time",
"timestamp": "DateTime",
"timestamp with time zone": "DateTime",
"timestamp without time zone": "DateTime",
"interval": "Interval",
"json": "JSON",
"jsonb": "JSONB",
"uuid": "Uuid",
"inet": "INET",
"cidr": "CIDR",
"macaddr": "MACADDR",
"point": "Geometry",
"line": "Geometry",
"lseg": "Geometry",
"box": "Geometry",
"path": "Geometry",
"polygon": "Geometry",
"circle": "Geometry",
"bit": "Bit",
"bit varying": "Bit",
"tsvector": "TSVECTOR",
"tsquery": "TSQUERY",
"xml": "String",
"array": "ARRAY",
"composite": "JSON",
"enum": "Enum",
"range": "Range",
"money": "Numeric",
"pg_lsn": "BigInteger",
"txid_snapshot": "String",
"oid": "BigInteger",
"regproc": "String",
"regclass": "String",
"regtype": "String",
"regrole": "String",
"regnamespace": "String",
"int2vector": "ARRAY",
"oidvector": "ARRAY",
"pg_node_tree": "Text",
} if settings.DATABASE_TYPE == "postgres" else {
# 数值类型
"TINYINT": "SmallInteger",
"SMALLINT": "SmallInteger",
"MEDIUMINT": "Integer",
"INT": "Integer",
"INTEGER": "Integer",
"BIGINT": "BigInteger",
"FLOAT": "Float",
"DOUBLE": "Float",
"DECIMAL": "DECIMAL",
"BIT": "Integer",
"NUMERIC": "Numeric",
# 日期和时间类型
"DATE": "Date",
"TIME": "Time",
"DATETIME": "DateTime",
"TIMESTAMP": "TIMESTAMP",
"YEAR": "Integer",
# 字符串类型
"CHAR": "CHAR",
"VARCHAR": "String",
"TINYTEXT": "Text",
"TEXT": "Text",
"MEDIUMTEXT": "Text",
"LONGTEXT": "Text",
"BINARY": "BINARY",
"VARBINARY": "VARBINARY",
"TINYBLOB": "LargeBinary",
"BLOB": "LargeBinary",
"MEDIUMBLOB": "LargeBinary",
"LONGBLOB": "LargeBinary",
# 枚举和集合类型
"ENUM": "Enum",
"SET": "String",
# JSON 类型
"JSON": "JSON",
# 空间数据类型(需要扩展支持,如 GeoAlchemy2
"GEOMETRY": "Geometry", # 需要安装 geoalchemy2
"POINT": "Geometry",
"LINESTRING": "Geometry",
"POLYGON": "Geometry",
"MULTIPOINT": "Geometry",
"MULTILINESTRING": "Geometry",
"MULTIPOLYGON": "Geometry",
"GEOMETRYCOLLECTION": "Geometry",
# 其他类型
"BOOL": "Boolean",
"UUID": "String",
}
# 数据库类型与python类型映射
DB_TO_PYTHON = {
"boolean": "bool",
"smallint": "int",
"integer": "int",
"int4": "int",
"bigint": "int",
"real": "float",
"double precision": "float",
"numeric": "Decimal",
"character varying": "str",
"varchar": "str",
"character": "str",
"text": "str",
"bytea": "bytes",
"date": "date",
"time": "time",
"time with time zone": "time",
"time without time zone": "time",
"timestamp": "datetime",
"timestamp with time zone": "datetime",
"timestamp without time zone": "datetime",
"interval": "timedelta",
"json": "dict",
"jsonb": "dict",
"uuid": "str",
"inet": "str",
"cidr": "str",
"macaddr": "str",
"point": "list",
"line": "list",
"lseg": "list",
"box": "list",
"path": "list",
"polygon": "list",
"circle": "list",
"bit": "int",
"bit varying": "int",
"tsvector": "str",
"tsquery": "str",
"xml": "str",
"array": "list",
"composite": "dict",
"enum": "str",
"range": "list",
"money": "Decimal",
"pg_lsn": "int",
"txid_snapshot": "str",
"oid": "int",
"regproc": "str",
"regclass": "str",
"regtype": "str",
"regrole": "str",
"regnamespace": "str",
"int2vector": "list",
"oidvector": "list",
"pg_node_tree": "str",
} if settings.DATABASE_TYPE == "postgres" else {
# 数值类型
"TINYINT": "int",
"SMALLINT": "int",
"MEDIUMINT": "int",
"INT": "int",
"INTEGER": "int",
"BIGINT": "int",
"FLOAT": "float",
"DOUBLE": "float",
"NUMERIC": "float",
"DECIMAL": "Decimal",
"BIT": "int",
# 日期和时间类型
"DATE": "datetime.date",
"TIME": "datetime.time",
"DATETIME": "datetime.datetime",
"TIMESTAMP": "datetime.datetime",
"YEAR": "int",
"TINYINT UNSIGNED": "int", # 无符号小整数类型
# 布尔类型
"BOOLEAN": "bool",
"BOOL": "bool", # 布尔类型,通常与 BOOLEAN 相同
# UUID
"UUID": "str", # UUID 一般作为字符串
# 字符串类型
"CHAR": "str",
"VARCHAR": "str",
"TINYTEXT": "str",
"TEXT": "str",
"MEDIUMTEXT": "str",
"LONGTEXT": "str",
"BINARY": "bytes",
"VARBINARY": "bytes",
"TINYBLOB": "bytes",
"BLOB": "bytes",
"MEDIUMBLOB": "bytes",
"LONGBLOB": "bytes",
# 枚举和集合类型
"ENUM": "str",
"SET": "list",
# JSON 类型
"JSON": "dict",
# 空间数据类型(通常需要特殊处理)
"GEOMETRY": "bytes", # 空间数据类型,通常存储为字节流
"POINT": "bytes", # 点数据类型
"LINESTRING": "bytes", # 线数据类型
"POLYGON": "bytes", # 多边形数据类型
"MULTIPOINT": "bytes", # 多点数据类型
"MULTILINESTRING": "bytes", # 多线数据类型
"MULTIPOLYGON": "bytes", # 多多边形数据类型
"GEOMETRYCOLLECTION": "bytes", # 几何集合类型
}
class TypedContextProtocol(Protocol):
perf_time: float
ip: str
country: str | None
region: str | None
city: str | None
user_agent: str
os: str | None
browser: str | None
device: str | None
permission: str | None
# if __name__ == "__main__":
# print(RET.OK.msg) # 输出: 成功