Init models
This commit is contained in:
parent
a2597dec19
commit
c04794081b
|
@ -39,3 +39,6 @@ media/
|
|||
env/
|
||||
venv/
|
||||
db.sqlite3
|
||||
|
||||
# Don't commit migrations now
|
||||
migrations/
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
from django.contrib import admin
|
||||
|
||||
# Register your models here.
|
|
@ -0,0 +1,5 @@
|
|||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class LgConfig(AppConfig):
|
||||
name = 'lg'
|
|
@ -0,0 +1,310 @@
|
|||
from django.contrib.auth.models import User
|
||||
from django.db import models
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from polymorphic.models import PolymorphicModel
|
||||
|
||||
|
||||
class Player(PolymorphicModel):
|
||||
user = models.OneToOneField(
|
||||
User,
|
||||
on_delete=models.CASCADE,
|
||||
verbose_name=_("user"),
|
||||
)
|
||||
|
||||
dead = models.BooleanField(
|
||||
default=False,
|
||||
verbose_name=_("dead"),
|
||||
)
|
||||
|
||||
infected = models.BooleanField(
|
||||
default=False,
|
||||
verbose_name=_("infected"),
|
||||
)
|
||||
|
||||
hacked = models.BooleanField(
|
||||
default=False,
|
||||
verbose_name=_("hacked"),
|
||||
)
|
||||
|
||||
captain = models.BooleanField(
|
||||
default=False,
|
||||
verbose_name=_("captain"),
|
||||
)
|
||||
|
||||
in_love_with = models.ForeignKey(
|
||||
"lg.Player",
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
null=True,
|
||||
default=None,
|
||||
)
|
||||
|
||||
@property
|
||||
def alive(self):
|
||||
return not self.dead
|
||||
|
||||
def action_class(self):
|
||||
raise NotImplementedError
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("player")
|
||||
verbose_name_plural = _("players")
|
||||
|
||||
|
||||
class Werewolf(Player):
|
||||
def action_class(self):
|
||||
return WerewolfAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("werewolf")
|
||||
verbose_name_plural = _("werewolves")
|
||||
|
||||
|
||||
class Cupidon(Player):
|
||||
def action_class(self):
|
||||
return CupidonAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("cupidon")
|
||||
verbose_name_plural = _("cupidons")
|
||||
|
||||
|
||||
class Witch(Player):
|
||||
def action_class(self):
|
||||
return WitchAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("witch")
|
||||
verbose_name_plural = _("witches")
|
||||
|
||||
|
||||
class Raven(Player):
|
||||
def action_class(self):
|
||||
return RavenAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("raven")
|
||||
verbose_name_plural = _("ravens")
|
||||
|
||||
|
||||
class Dove(Player):
|
||||
def action_class(self):
|
||||
return DoveAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("dove")
|
||||
verbose_name_plural = _("doves")
|
||||
|
||||
|
||||
class Hacker(Player):
|
||||
def action_class(self):
|
||||
return HackerAction
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("hacker")
|
||||
verbose_name_plural = _("hackers")
|
||||
|
||||
|
||||
class Action(PolymorphicModel):
|
||||
player = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
verbose_name=_("player"),
|
||||
related_name="actions",
|
||||
)
|
||||
|
||||
night = models.PositiveSmallIntegerField(
|
||||
verbose_name=_("night"),
|
||||
)
|
||||
|
||||
def act_night(self, night: int) -> None:
|
||||
pass
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("action")
|
||||
verbose_name_plural = _("actions")
|
||||
|
||||
|
||||
class WerewolfAction(Action):
|
||||
target = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("werewolf action")
|
||||
verbose_name_plural = _("werewolf actions")
|
||||
|
||||
|
||||
class CupidonAction(Action):
|
||||
target1 = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
target2 = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
def act_night(self, night: int) -> None:
|
||||
if night > 1:
|
||||
return
|
||||
self.target1.in_love_with = self.target2
|
||||
self.target2.in_love_with = self.target1
|
||||
self.target1.save()
|
||||
self.target2.save()
|
||||
|
||||
|
||||
class WitchAction(Action):
|
||||
saved = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("saved"),
|
||||
)
|
||||
|
||||
killed = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("killed"),
|
||||
)
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("witch action")
|
||||
verbose_name_plural = _("witch actions")
|
||||
|
||||
|
||||
class RavenAction(Action):
|
||||
target = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
message = models.TextField(
|
||||
verbose_name=_("message"),
|
||||
)
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("raven action")
|
||||
verbose_name_plural = _("raven actions")
|
||||
|
||||
|
||||
class DoveAction(Action):
|
||||
target = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
message = models.TextField(
|
||||
verbose_name=_("message"),
|
||||
)
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("dove action")
|
||||
verbose_name_plural = _("dove actions")
|
||||
|
||||
|
||||
class HackerAction(Action):
|
||||
target1 = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
target2 = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
def act_night(self, night: int):
|
||||
self.target1.hacked = True
|
||||
self.target2.hacked = True
|
||||
self.target1.save()
|
||||
self.target2.save()
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("hacker action")
|
||||
verbose_name_plural = _("hacker actions")
|
||||
|
||||
|
||||
class Vote(PolymorphicModel):
|
||||
day = models.PositiveSmallIntegerField(
|
||||
verbose_name=_("day"),
|
||||
)
|
||||
|
||||
voter = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("voter"),
|
||||
)
|
||||
|
||||
target = models.ForeignKey(
|
||||
Player,
|
||||
on_delete=models.CASCADE,
|
||||
related_name="+",
|
||||
verbose_name=_("target"),
|
||||
)
|
||||
|
||||
@classmethod
|
||||
def get_votes(cls, day: int):
|
||||
votes = cls.objects.filter(day=day).all()
|
||||
d = {}
|
||||
for vote in votes:
|
||||
d.setdefault(vote.target, 0)
|
||||
d[vote.target] += 1
|
||||
return d
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("vote")
|
||||
verbose_name_plural = _("votes")
|
||||
|
||||
|
||||
class CaptainVote(Vote):
|
||||
class Meta:
|
||||
verbose_name = _("captain vote")
|
||||
verbose_name_plural = _("captain votes")
|
||||
|
||||
|
||||
class EjectVote(Vote):
|
||||
@classmethod
|
||||
def get_votes(cls, day: int):
|
||||
votes = cls.objects.filter(day=day).all()
|
||||
d = {}
|
||||
for vote in votes:
|
||||
vote: Vote
|
||||
d.setdefault(vote.target, 0)
|
||||
d[vote.target] += 1
|
||||
if vote.voter.captain:
|
||||
d[vote.target] += 1
|
||||
|
||||
for dove_action in DoveAction.objects.filter(day=day).all():
|
||||
dove_action: DoveAction
|
||||
d.setdefault(dove_action.target, 0)
|
||||
d[dove_action.target] -= 2
|
||||
|
||||
for raven_action in RavenAction.objects.filter(day=day).all():
|
||||
raven_action: RavenAction
|
||||
d.setdefault(raven_action.target, 0)
|
||||
d[raven_action.target] += 2
|
||||
|
||||
return d
|
||||
|
||||
class Meta:
|
||||
verbose_name = _("eject vote")
|
||||
verbose_name_plural = _("eject votes")
|
|
@ -0,0 +1,3 @@
|
|||
from django.test import TestCase
|
||||
|
||||
# Create your tests here.
|
|
@ -0,0 +1,3 @@
|
|||
from django.shortcuts import render
|
||||
|
||||
# Create your views here.
|
|
@ -37,6 +37,8 @@ INSTALLED_APPS = [
|
|||
'django.contrib.sessions',
|
||||
'django.contrib.messages',
|
||||
'django.contrib.staticfiles',
|
||||
|
||||
'lg',
|
||||
]
|
||||
|
||||
MIDDLEWARE = [
|
||||
|
|
4
tox.ini
4
tox.ini
|
@ -13,7 +13,7 @@ deps =
|
|||
django-polymorphic~=3.0
|
||||
django-tables2~=2.3
|
||||
commands =
|
||||
coverage run --source=lglog ./manage.py test lglog/
|
||||
coverage run --source=lglog,lg ./manage.py test lglog/ lg/
|
||||
coverage report -m
|
||||
|
||||
[testenv:linters]
|
||||
|
@ -26,7 +26,7 @@ deps =
|
|||
pep8-naming
|
||||
pyflakes
|
||||
commands =
|
||||
flake8 lglog/
|
||||
flake8 lglog/ lg/
|
||||
|
||||
[flake8]
|
||||
exclude =
|
||||
|
|
Loading…
Reference in New Issue