mirror of
https://github.com/evgen-app/chess_rpg_backend.git
synced 2024-11-10 19:57:12 +03:00
38 lines
1.3 KiB
Python
38 lines
1.3 KiB
Python
from django.db import models
|
|
|
|
# Create your models here.
|
|
from game.models import Player, Deck
|
|
|
|
|
|
class PlayerInQueue(models.Model):
|
|
# TODO use redis for storing
|
|
player = models.OneToOneField(Player, unique=True, on_delete=models.CASCADE)
|
|
channel_name = models.CharField(max_length=50, blank=False)
|
|
deck = models.ForeignKey(Deck, on_delete=models.CASCADE)
|
|
score = models.IntegerField()
|
|
|
|
def __str__(self):
|
|
return f"{self.player.name} in que with score {self.score}"
|
|
|
|
|
|
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")
|
|
online = models.BooleanField(default=False)
|
|
channel_name = models.CharField(max_length=50, blank=True, null=True)
|
|
|
|
def __str__(self):
|
|
return f"{self.player.name} in room {self.room.slug}"
|