|
|
""" |
|
|
数据库模型模块 |
|
|
""" |
|
|
import datetime |
|
|
from sqlalchemy import Column, Integer, String, Text, DateTime, JSON, Boolean, BigInteger, Enum |
|
|
import enum |
|
|
|
|
|
from app.database.connection import Base |
|
|
|
|
|
|
|
|
class Settings(Base): |
|
|
""" |
|
|
设置表,对应.env中的配置项 |
|
|
""" |
|
|
__tablename__ = "t_settings" |
|
|
|
|
|
id = Column(Integer, primary_key=True, autoincrement=True) |
|
|
key = Column(String(100), nullable=False, unique=True, comment="配置项键名") |
|
|
value = Column(Text, nullable=True, comment="配置项值") |
|
|
description = Column(String(255), nullable=True, comment="配置项描述") |
|
|
created_at = Column(DateTime, default=datetime.datetime.now, comment="创建时间") |
|
|
updated_at = Column(DateTime, default=datetime.datetime.now, onupdate=datetime.datetime.now, comment="更新时间") |
|
|
|
|
|
def __repr__(self): |
|
|
return f"<Settings(key='{self.key}', value='{self.value}')>" |
|
|
|
|
|
|
|
|
class ErrorLog(Base): |
|
|
""" |
|
|
错误日志表 |
|
|
""" |
|
|
__tablename__ = "t_error_logs" |
|
|
|
|
|
id = Column(Integer, primary_key=True, autoincrement=True) |
|
|
gemini_key = Column(String(100), nullable=True, comment="Gemini API密钥") |
|
|
model_name = Column(String(100), nullable=True, comment="模型名称") |
|
|
error_type = Column(String(50), nullable=True, comment="错误类型") |
|
|
error_log = Column(Text, nullable=True, comment="错误日志") |
|
|
error_code = Column(Integer, nullable=True, comment="错误代码") |
|
|
request_msg = Column(JSON, nullable=True, comment="请求消息") |
|
|
request_time = Column(DateTime, default=datetime.datetime.now, comment="请求时间") |
|
|
|
|
|
def __repr__(self): |
|
|
return f"<ErrorLog(id='{self.id}', gemini_key='{self.gemini_key}')>" |
|
|
|
|
|
|
|
|
class RequestLog(Base): |
|
|
""" |
|
|
API 请求日志表 |
|
|
""" |
|
|
|
|
|
__tablename__ = "t_request_log" |
|
|
|
|
|
id = Column(Integer, primary_key=True, autoincrement=True) |
|
|
request_time = Column(DateTime, default=datetime.datetime.now, comment="请求时间") |
|
|
model_name = Column(String(100), nullable=True, comment="模型名称") |
|
|
api_key = Column(String(100), nullable=True, comment="使用的API密钥") |
|
|
is_success = Column(Boolean, nullable=False, comment="请求是否成功") |
|
|
status_code = Column(Integer, nullable=True, comment="API响应状态码") |
|
|
latency_ms = Column(Integer, nullable=True, comment="请求耗时(毫秒)") |
|
|
|
|
|
def __repr__(self): |
|
|
return f"<RequestLog(id='{self.id}', key='{self.api_key[:4]}...', success='{self.is_success}')>" |
|
|
|
|
|
|
|
|
class FileState(enum.Enum): |
|
|
"""文件状态枚举""" |
|
|
PROCESSING = "PROCESSING" |
|
|
ACTIVE = "ACTIVE" |
|
|
FAILED = "FAILED" |
|
|
|
|
|
|
|
|
class FileRecord(Base): |
|
|
""" |
|
|
文件记录表,用于存储上传到 Gemini 的文件信息 |
|
|
""" |
|
|
__tablename__ = "t_file_records" |
|
|
|
|
|
id = Column(Integer, primary_key=True, autoincrement=True) |
|
|
|
|
|
|
|
|
name = Column(String(255), unique=True, nullable=False, comment="文件名称,格式: files/{file_id}") |
|
|
display_name = Column(String(255), nullable=True, comment="用户上传时的原始文件名") |
|
|
mime_type = Column(String(100), nullable=False, comment="MIME 类型") |
|
|
size_bytes = Column(BigInteger, nullable=False, comment="文件大小(字节)") |
|
|
sha256_hash = Column(String(255), nullable=True, comment="文件的 SHA256 哈希值") |
|
|
|
|
|
|
|
|
state = Column(Enum(FileState), nullable=False, default=FileState.PROCESSING, comment="文件状态") |
|
|
|
|
|
|
|
|
create_time = Column(DateTime, nullable=False, comment="创建时间") |
|
|
update_time = Column(DateTime, nullable=False, comment="更新时间") |
|
|
expiration_time = Column(DateTime, nullable=False, comment="过期时间") |
|
|
|
|
|
|
|
|
uri = Column(String(500), nullable=False, comment="文件访问 URI") |
|
|
api_key = Column(String(100), nullable=False, comment="上传时使用的 API Key") |
|
|
upload_url = Column(Text, nullable=True, comment="临时上传 URL(用于分块上传)") |
|
|
|
|
|
|
|
|
user_token = Column(String(100), nullable=True, comment="上传用户的 token") |
|
|
upload_completed = Column(DateTime, nullable=True, comment="上传完成时间") |
|
|
|
|
|
def __repr__(self): |
|
|
return f"<FileRecord(name='{self.name}', state='{self.state.value if self.state else 'None'}', api_key='{self.api_key[:8]}...')>" |
|
|
|
|
|
def to_dict(self): |
|
|
"""转换为字典格式,用于 API 响应""" |
|
|
return { |
|
|
"name": self.name, |
|
|
"displayName": self.display_name, |
|
|
"mimeType": self.mime_type, |
|
|
"sizeBytes": str(self.size_bytes), |
|
|
"createTime": self.create_time.isoformat() + "Z", |
|
|
"updateTime": self.update_time.isoformat() + "Z", |
|
|
"expirationTime": self.expiration_time.isoformat() + "Z", |
|
|
"sha256Hash": self.sha256_hash, |
|
|
"uri": self.uri, |
|
|
"state": self.state.value if self.state else "PROCESSING" |
|
|
} |
|
|
|
|
|
def is_expired(self): |
|
|
"""检查文件是否已过期""" |
|
|
|
|
|
expiration_time = self.expiration_time |
|
|
if expiration_time.tzinfo is None: |
|
|
expiration_time = expiration_time.replace(tzinfo=datetime.timezone.utc) |
|
|
return datetime.datetime.now(datetime.timezone.utc) > expiration_time |
|
|
|