mirror of
https://github.com/rommapp/romm.git
synced 2026-06-28 06:46:00 +00:00
61 lines
2.0 KiB
Python
61 lines
2.0 KiB
Python
from __future__ import annotations
|
|
|
|
from datetime import datetime
|
|
from typing import TYPE_CHECKING
|
|
|
|
from sqlalchemy import (
|
|
TIMESTAMP,
|
|
BigInteger,
|
|
ForeignKey,
|
|
Index,
|
|
Integer,
|
|
String,
|
|
UniqueConstraint,
|
|
)
|
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
|
|
|
from models.base import BaseModel
|
|
|
|
if TYPE_CHECKING:
|
|
from models.device import Device
|
|
from models.rom import Rom
|
|
from models.sync_session import SyncSession
|
|
from models.user import User
|
|
|
|
|
|
class PlaySession(BaseModel):
|
|
__tablename__ = "play_sessions"
|
|
__table_args__ = (
|
|
UniqueConstraint(
|
|
"user_id",
|
|
"device_id",
|
|
"rom_id",
|
|
"start_time",
|
|
name="uq_play_session_identity",
|
|
),
|
|
Index("ix_play_sessions_user_rom", "user_id", "rom_id"),
|
|
Index("ix_play_sessions_user_time", "user_id", "start_time"),
|
|
{"extend_existing": True},
|
|
)
|
|
|
|
id: Mapped[int] = mapped_column(primary_key=True, autoincrement=True)
|
|
user_id: Mapped[int] = mapped_column(ForeignKey("users.id", ondelete="CASCADE"))
|
|
device_id: Mapped[str | None] = mapped_column(
|
|
String(255), ForeignKey("devices.id", ondelete="SET NULL")
|
|
)
|
|
rom_id: Mapped[int | None] = mapped_column(
|
|
ForeignKey("roms.id", ondelete="SET NULL")
|
|
)
|
|
sync_session_id: Mapped[int | None] = mapped_column(
|
|
Integer, ForeignKey("sync_sessions.id", ondelete="SET NULL"), default=None
|
|
)
|
|
save_slot: Mapped[str | None] = mapped_column(String(255), default=None)
|
|
start_time: Mapped[datetime] = mapped_column(TIMESTAMP(timezone=True))
|
|
end_time: Mapped[datetime] = mapped_column(TIMESTAMP(timezone=True))
|
|
duration_ms: Mapped[int] = mapped_column(BigInteger())
|
|
|
|
user: Mapped[User] = relationship(lazy="raise", back_populates="play_sessions")
|
|
device: Mapped[Device | None] = relationship(lazy="raise")
|
|
rom: Mapped[Rom | None] = relationship(lazy="raise")
|
|
sync_session: Mapped[SyncSession | None] = relationship(lazy="raise")
|