2022-06-11 23:34:55 +03:00
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
# Create your models here.
|
2022-06-24 01:04:35 +03:00
|
|
|
from game.models import Player, Deck
|
2022-06-21 11:36:55 +03:00
|
|
|
|
|
|
|
|
2022-06-21 20:26:32 +03:00
|
|
|
class PlayerInQueue(models.Model):
|
2022-06-21 11:36:55 +03:00
|
|
|
# TODO use redis for storing
|
2022-06-22 00:11:52 +03:00
|
|
|
player = models.OneToOneField(Player, unique=True, on_delete=models.CASCADE)
|
2022-06-23 14:45:34 +03:00
|
|
|
channel_name = models.CharField(max_length=50, blank=False)
|
2022-06-24 01:04:35 +03:00
|
|
|
deck = models.ForeignKey(Deck, on_delete=models.CASCADE)
|
|
|
|
score = models.IntegerField()
|
2022-06-21 11:36:55 +03:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return f"{self.player.name} in que with score {self.score}"
|
2022-06-24 01:04:35 +03:00
|
|
|
|
|
|
|
|
|
|
|
class Room(models.Model):
|
|
|
|
slug = models.SlugField(max_length=16, unique=True)
|
|
|
|
created = models.DateTimeField(auto_now_add=True)
|
|
|
|
ended = models.BooleanField(default=False)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return f"room with slug {self.slug}"
|
|
|
|
|
|
|
|
|
|
|
|
class PlayerInRoom(models.Model):
|
|
|
|
player = models.OneToOneField(Player, unique=True, on_delete=models.CASCADE)
|
|
|
|
room = models.ForeignKey(Room, on_delete=models.CASCADE, related_name="players")
|
|
|
|
first = models.BooleanField()
|
|
|
|
score = models.IntegerField(blank=False)
|
|
|
|
deck = models.ForeignKey(Deck, on_delete=models.CASCADE, related_name="decks")
|
2022-06-26 18:04:09 +03:00
|
|
|
online = models.BooleanField(default=False)
|
2022-06-26 19:00:53 +03:00
|
|
|
channel_name = models.CharField(max_length=50, blank=True, null=True)
|
2022-06-24 01:04:35 +03:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return f"{self.player.name} in room {self.room.slug}"
|