2026-03-18 20:55:02 +00:00
|
|
|
import uuid
|
|
|
|
|
from datetime import datetime, timezone
|
|
|
|
|
|
2026-03-25 21:10:10 +00:00
|
|
|
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-25 21:10:10 +00:00
|
|
|
from ..database import Base
|
2026-03-18 20:55:02 +00:00
|
|
|
|
2026-03-25 21:10:10 +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
|
|
|
|
|
)
|
2026-03-19 10:51:10 +00:00
|
|
|
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")
|
|
|
|
|
source_language: Mapped[str] = mapped_column(String(10), nullable=False, default="en")
|
|
|
|
|
target_language: Mapped[str] = mapped_column(String(10), nullable=False)
|
|
|
|
|
complexity_level: Mapped[str] = mapped_column(String(5), nullable=False)
|
|
|
|
|
input_summary: Mapped[str | None] = mapped_column(Text, nullable=True)
|
|
|
|
|
generated_text: Mapped[str | None] = mapped_column(Text, nullable=True)
|
|
|
|
|
translated_text: Mapped[str | None] = mapped_column(Text, nullable=True)
|
|
|
|
|
error_message: Mapped[str | None] = mapped_column(Text, nullable=True)
|
2026-03-19 10:51:10 +00:00
|
|
|
audio_url: Mapped[str | None] = mapped_column(Text, nullable=True)
|
2026-03-18 20:55:02 +00:00
|
|
|
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),
|
|
|
|
|
)
|