37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
||
|
from sqlalchemy.schema import ForeignKey
|
||
|
from sqlalchemy.types import Integer, String
|
||
|
import app_db
|
||
|
import spec
|
||
|
|
||
|
|
||
|
class TeamMatch(app_db.BaseModel):
|
||
|
__tablename__ = "teams_matches"
|
||
|
|
||
|
team_id: Mapped[int] = mapped_column(ForeignKey("teams.id"), primary_key=True)
|
||
|
match_id: Mapped[int] = mapped_column(ForeignKey("matches.logs_tf_id"), primary_key=True)
|
||
|
team_color: Mapped[str] = mapped_column(String(4))
|
||
|
|
||
|
team: Mapped["Team"] = relationship("Team", back_populates="matches")
|
||
|
match: Mapped["Match"] = relationship("Match", back_populates="teams")
|
||
|
|
||
|
class TeamMatchSchema(spec.BaseModel):
|
||
|
match: "MatchSchema"
|
||
|
our_score: int
|
||
|
their_score: int
|
||
|
|
||
|
@classmethod
|
||
|
def from_model(cls, model: "TeamMatch"):
|
||
|
our_score = model.match.blue_score if model.team_color == "Blue" else model.match.red_score
|
||
|
their_score = model.match.red_score if model.team_color == "Blue" else model.match.blue_score
|
||
|
|
||
|
return cls(
|
||
|
match=MatchSchema.from_model(model.match),
|
||
|
our_score=our_score,
|
||
|
their_score=their_score,
|
||
|
)
|
||
|
|
||
|
|
||
|
from models.match import Match, MatchSchema
|
||
|
from models.team import Team
|