"""对话 数据库表"""
import uuid
from datetime import UTC, datetime
from enum import Enum as PyEnum
from sqlalchemy import BigInteger, Boolean, DateTime, Enum, ForeignKey, String
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import Mapped, mapped_column
from apps.constants import NEW_CHAT
from .base import Base
class Conversation(Base):
"""对话"""
__tablename__ = "framework_conversation"
userId: Mapped[str] = mapped_column(String(50), ForeignKey("framework_user.id"), nullable=False)
"""用户ID"""
appId: Mapped[uuid.UUID | None] = mapped_column(
UUID(as_uuid=True), nullable=True,
)
"""对话使用的App的ID"""
title: Mapped[str] = mapped_column(String(255), default=NEW_CHAT, nullable=False)
"""对话标题"""
id: Mapped[uuid.UUID] = mapped_column(
UUID(as_uuid=True), primary_key=True, default_factory=lambda: uuid.uuid4(),
)
"""对话ID"""
createdAt: Mapped[datetime] = mapped_column(
DateTime(timezone=True), default_factory=lambda: datetime.now(tz=UTC),
nullable=False, index=True,
)
"""对话创建时间"""
isTemporary: Mapped[bool] = mapped_column(Boolean, default=False, nullable=False)
"""是否为临时对话"""
class ConvDocAssociated(str, PyEnum):
"""问答对文件的关联类型"""
QUESTION = "question"
ANSWER = "answer"
class ConversationDocument(Base):
"""对话所用的临时文件"""
__tablename__ = "framework_conversation_document"
id: Mapped[int] = mapped_column(BigInteger, primary_key=True, autoincrement=True, init=False)
"""主键ID"""
conversationId: Mapped[uuid.UUID] = mapped_column(
UUID(as_uuid=True), ForeignKey("framework_conversation.id"), nullable=False, index=True,
)
"""对话ID"""
documentId: Mapped[uuid.UUID] = mapped_column(
UUID(as_uuid=True), ForeignKey("framework_document.id"), nullable=False, index=True,
)
"""文件ID"""
isUnused: Mapped[bool] = mapped_column(Boolean, default=True, nullable=False)
"""是否未使用"""
associated: Mapped[ConvDocAssociated | None] = mapped_column(
Enum(ConvDocAssociated), nullable=True, default=None,
)
"""关联类型"""
recordId: Mapped[uuid.UUID | None] = mapped_column(ForeignKey("framework_record.id"), nullable=True, default=None)
"""问答对ID"""