language-learning-app/api/app/outbound/postgres/entities/summarise_job_entity.py

35 lines
1.3 KiB
Python
Raw Permalink Normal View History

2026-03-18 20:55:02 +00:00
import uuid
from datetime import datetime, timezone
from sqlalchemy import String, Text, DateTime, ForeignKey
2026-03-18 20:55:02 +00:00
from sqlalchemy.orm import Mapped, mapped_column
from sqlalchemy.dialects.postgresql import UUID
2026-03-18 20:55:02 +00:00
from ..database import Base
2026-03-18 20:55:02 +00:00
class SummariseJobEntity(Base):
2026-03-18 20:55:02 +00:00
__tablename__ = "jobs"
id: Mapped[uuid.UUID] = mapped_column(
UUID(as_uuid=True), primary_key=True, default=uuid.uuid4
)
user_id: Mapped[uuid.UUID | None] = mapped_column(
UUID(as_uuid=True), ForeignKey("users.id"), nullable=True, index=True
)
2026-03-18 20:55:02 +00:00
status: Mapped[str] = mapped_column(String(20), nullable=False, default="pending")
translated_article_id: Mapped[uuid.UUID | None] = mapped_column(
UUID(as_uuid=True), ForeignKey("translated_articles.id"), nullable=True
)
2026-03-18 20:55:02 +00:00
error_message: Mapped[str | None] = mapped_column(Text, nullable=True)
created_at: Mapped[datetime] = mapped_column(
DateTime(timezone=True),
default=lambda: datetime.now(timezone.utc),
)
started_at: Mapped[datetime | None] = mapped_column(DateTime(timezone=True), nullable=True)
completed_at: Mapped[datetime | None] = mapped_column(DateTime(timezone=True), nullable=True)
updated_at: Mapped[datetime] = mapped_column(
DateTime(timezone=True),
default=lambda: datetime.now(timezone.utc),
)