tournament: game: finish event
This commit is contained in:
@ -21,43 +21,28 @@ class GameModel(models.Model):
|
||||
stop_timestamp = models.BigIntegerField(null = True, blank = True)
|
||||
game_type = models.CharField(max_length = 60, default = "pong")
|
||||
|
||||
def create(self, players: list[User]):
|
||||
def create(self, players: set[User]) -> GameModel:
|
||||
self.save()
|
||||
for player in players:
|
||||
GameMembersModel(game = self, player=player).save()
|
||||
return self.pk
|
||||
return self
|
||||
|
||||
def start(self):
|
||||
self.start_timestamp = round(time.time() * 1000, 1)
|
||||
self.started = True
|
||||
self.save()
|
||||
|
||||
def get_tournament(self) -> None | TournamentGameModel:
|
||||
|
||||
from tournament.models import TournamentGameModel
|
||||
|
||||
query = TournamentGameModel.objects.filter(game=self)
|
||||
if (not query.exists()):
|
||||
return None
|
||||
return query[0]
|
||||
|
||||
def finish(self, winner_id):
|
||||
self.winner_id = winner_id
|
||||
def finish(self, winner: User):
|
||||
self.winner = winner
|
||||
self.finished = True
|
||||
self.stop_timestamp = round(time.time() * 1000, 1)
|
||||
self.save()
|
||||
|
||||
tournament = self.get_tournament()
|
||||
if tournament is not None:
|
||||
from tournament.consumers import tournament_manager
|
||||
room = tournament_manager.get(tournament)
|
||||
room.set_game_as_finished(self)
|
||||
|
||||
def get_players(self) -> list[User]:
|
||||
return [game_player.player for game_player in GameMembersModel.objects.filter(game = self)]
|
||||
def get_players(self) -> set[User]:
|
||||
return {game_player.player for game_player in GameMembersModel.objects.filter(game = self)}
|
||||
|
||||
def get_players_profiles(self) -> list[User]:
|
||||
return [game_player.player.profilemodel for game_player in GameMembersModel.objects.filter(game = self)]
|
||||
def get_players_profiles(self) -> set[User]:
|
||||
return {game_player.player.profilemodel for game_player in GameMembersModel.objects.filter(game = self)}
|
||||
|
||||
def get_score_by_player_id(self, player_id: int) -> list[int]:
|
||||
query: QuerySet = GameGoalModel.objects.filter(game_id = self.pk, player_id = player_id)
|
||||
|
Reference in New Issue
Block a user