| import uuid | |
| from datetime import datetime | |
| from sqlalchemy import String, Text, DateTime, Integer, func | |
| from sqlalchemy.orm import Mapped, mapped_column | |
| from sqlalchemy.dialects.postgresql import UUID | |
| from ..database import Base | |
| class Session(Base): | |
| __tablename__ = "sessions" | |
| id: Mapped[uuid.UUID] = mapped_column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4) | |
| name: Mapped[str] = mapped_column(String(255)) | |
| description: Mapped[str | None] = mapped_column(Text, nullable=True) | |
| candidate_count: Mapped[int] = mapped_column(Integer, default=0) | |
| status: Mapped[str] = mapped_column(String(32), default="active") | |
| created_at: Mapped[datetime] = mapped_column(DateTime(timezone=True), server_default=func.now()) | |
| updated_at: Mapped[datetime] = mapped_column(DateTime(timezone=True), server_default=func.now(), onupdate=func.now()) | |