upload project source code
This commit is contained in:
722
后端源码/yifan.action-ai.cn/api/app/common/constant.py
Normal file
722
后端源码/yifan.action-ai.cn/api/app/common/constant.py
Normal 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) # 输出: 成功
|
||||
Reference in New Issue
Block a user