from datetime import datetime, timezone from sqlalchemy import DateTime, String, Text from sqlalchemy.orm import Mapped, mapped_column from db.base import Base def _utcnow() -> datetime: return datetime.now(timezone.utc) class Document(Base): """Исходный текст документа — для переиндексации с новыми правилами чанкера.""" __tablename__ = "documents" id: Mapped[str] = mapped_column(String(36), primary_key=True) # UUID из process_document name: Mapped[str] = mapped_column(String(500), nullable=False) file_type: Mapped[str] = mapped_column(String(20), nullable=False) raw_text: Mapped[str] = mapped_column(Text, nullable=False) created_at: Mapped[datetime] = mapped_column(DateTime(timezone=True), default=_utcnow, nullable=False) updated_at: Mapped[datetime] = mapped_column( DateTime(timezone=True), default=_utcnow, onupdate=_utcnow, nullable=False )