session.py 1.1 KB

12345678910111213141516171819202122
  1. from datetime import datetime
  2. from core_db import AuditMixin, Base, EntityMixin
  3. from sqlalchemy import DateTime, String
  4. from sqlalchemy.orm import Mapped, mapped_column
  5. class Session(EntityMixin, AuditMixin, Base):
  6. __tablename__ = "session"
  7. app_id: Mapped[str] = mapped_column(String(36), index=True)
  8. user_id: Mapped[str] = mapped_column(String(36), index=True)
  9. channel_type: Mapped[str] = mapped_column(String(32))
  10. session_status: Mapped[str] = mapped_column(String(32), default="active")
  11. title: Mapped[str | None] = mapped_column(String(256), nullable=True)
  12. runtime_target_type: Mapped[str | None] = mapped_column(String(32), nullable=True)
  13. runtime_target_id: Mapped[str | None] = mapped_column(String(36), nullable=True)
  14. runtime_target_config_id: Mapped[str | None] = mapped_column(String(36), nullable=True)
  15. started_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  16. last_active_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  17. closed_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)