2024-11-11 18:05:27 -08:00
|
|
|
from datetime import datetime, timedelta
|
|
|
|
import spec
|
2024-11-10 17:21:25 -08:00
|
|
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
|
|
|
from sqlalchemy.schema import ForeignKeyConstraint
|
|
|
|
from sqlalchemy.types import Integer
|
|
|
|
from sqlalchemy_utc import UtcDateTime
|
|
|
|
import app_db
|
|
|
|
|
|
|
|
|
|
|
|
class PlayerTeamAvailability(app_db.BaseModel):
|
|
|
|
__tablename__ = "players_teams_availability"
|
|
|
|
|
|
|
|
player_id: Mapped[int] = mapped_column(primary_key=True)
|
|
|
|
team_id: Mapped[int] = mapped_column(primary_key=True)
|
|
|
|
start_time: Mapped[datetime] = mapped_column(UtcDateTime, primary_key=True)
|
|
|
|
|
|
|
|
player_team: Mapped["PlayerTeam"] = relationship(
|
|
|
|
"PlayerTeam", back_populates="availability")
|
|
|
|
|
|
|
|
availability: Mapped[int] = mapped_column(Integer, default=2)
|
|
|
|
end_time: Mapped[datetime] = mapped_column(UtcDateTime)
|
|
|
|
|
|
|
|
|
|
|
|
from models.player_team import PlayerTeam
|
|
|
|
|
|
|
|
__table_args__ = (
|
|
|
|
ForeignKeyConstraint(
|
|
|
|
[player_id, team_id],
|
|
|
|
[PlayerTeam.player_id, PlayerTeam.team_id]
|
|
|
|
),
|
|
|
|
)
|
2024-11-11 18:05:27 -08:00
|
|
|
|
2024-11-13 16:05:15 -08:00
|
|
|
class AvailabilitySchema(spec.BaseModel):
|
|
|
|
steam_id: str
|
|
|
|
username: str
|
|
|
|
availability: list[int] = [0] * 168
|
|
|
|
|
|
|
|
def add_availability_region(
|
|
|
|
self,
|
|
|
|
region: PlayerTeamAvailability,
|
|
|
|
window_start: datetime,
|
|
|
|
):
|
|
|
|
relative_start_time = region.start_time - window_start
|
|
|
|
relative_start_hour = int(relative_start_time.total_seconds() // 3600)
|
|
|
|
relative_end_time = region.end_time - window_start
|
|
|
|
relative_end_hour = int(relative_end_time.total_seconds() // 3600)
|
|
|
|
window_size_hours = 168 # TODO: change me if window_size is variable
|
|
|
|
|
|
|
|
i = max(0, relative_start_hour)
|
|
|
|
while i < window_size_hours and i < relative_end_hour:
|
|
|
|
print(i, "=", region.availability)
|
|
|
|
self.availability[i] = region.availability
|
|
|
|
i += 1
|
|
|
|
|
2024-11-11 18:05:27 -08:00
|
|
|
class PlayerTeamAvailabilityRoleSchema(spec.BaseModel):
|
|
|
|
from models.player import PlayerSchema
|
|
|
|
from models.player_team_role import RoleSchema
|
|
|
|
|
|
|
|
player: PlayerSchema
|
|
|
|
playtime: int
|
|
|
|
availability: int
|
|
|
|
roles: list[RoleSchema]
|