bgg_api/src/classes/play_classes.py

60 lines
1.6 KiB
Python
Raw Normal View History

from sqlmodel import Field, SQLModel, Relationship
from typing import Union
2024-08-02 11:43:30 +02:00
from datetime import date
class PlayPlayerBase(SQLModel):
2024-08-02 11:43:30 +02:00
username: str
score: Union[float, None]
2024-08-02 11:51:25 +02:00
first_play : bool
has_won : bool
play_id : int = Field(default=None, foreign_key="play.id")
class PlayPlayer(PlayPlayerBase, table=True):
id: int | None = Field(default=None, primary_key=True)
2024-08-24 17:39:13 +02:00
name: str = Field(default=None, foreign_key="player.name")
play: "Play" = Relationship(back_populates="players")
2024-08-24 17:39:13 +02:00
player: "Player" = Relationship(back_populates="playplayers")
class PlayPlayerPublic(PlayPlayerBase):
id: int
2024-08-24 17:39:13 +02:00
name: str
player: "PlayerPublicNoPlayPlayers"
class PlayPlayerPublicWithPlay(PlayPlayerPublic):
2024-08-24 17:39:13 +02:00
name: str
play: "PlayPublic"
class PlayBase(SQLModel):
boardgame_id: int | None = Field(default=None, foreign_key="boardgame.id")
play_date: date
2024-08-02 11:43:30 +02:00
duration: int #In minutes
ignore_for_stats : bool
location: str
class Play(PlayBase, table=True):
id: int | None = Field(default=None, primary_key=True)
players: list[PlayPlayer] = Relationship(back_populates="play")
boardgame: "BoardGame" = Relationship(back_populates="plays")
2024-08-11 21:45:27 +02:00
model_config = {
2024-08-11 21:45:27 +02:00
'validate_assignment':True
}
class PlayPublic(PlayBase):
players: list[PlayPlayerPublic]
boardgame: "BoardGamePublicNoPlays"
class PlayPublicNoGame(PlayBase):
players: list[PlayPlayerPublic] = []
from src.classes.boardgame_classes import BoardGame, BoardGamePublicNoPlays
2024-08-24 17:39:13 +02:00
from src.classes.player_classes import Player, PlayerPublic, PlayerPublicNoPlayPlayers
Play.model_rebuild()