Class attributes and properties + more verbose log

SpectacleRevente gets brand new properties and attributes to simplify
code ; also, manage_reventes command output is more verbose
This commit is contained in:
Ludovic Stephan 2017-10-23 20:30:11 +02:00
parent 1b0e4285ec
commit 684603709e
2 changed files with 69 additions and 24 deletions

View file

@ -6,7 +6,6 @@ Gestion en ligne de commande des reventes.
from __future__ import unicode_literals from __future__ import unicode_literals
from datetime import timedelta
from django.core.management import BaseCommand from django.core.management import BaseCommand
from django.utils import timezone from django.utils import timezone
from bda.models import SpectacleRevente from bda.models import SpectacleRevente
@ -21,23 +20,36 @@ class Command(BaseCommand):
now = timezone.now() now = timezone.now()
reventes = SpectacleRevente.objects.all() reventes = SpectacleRevente.objects.all()
for revente in reventes: for revente in reventes:
# Check si < 24h # Le spectacle est bientôt et on a pas encore envoyé de mail :
if (revente.attribution.spectacle.date <= # on met la place au shotgun et on prévient.
revente.date + timedelta(days=1)) and \ if revente.is_urgent and not revente.notif_sent:
now >= revente.date + timedelta(minutes=15) and \ if revente.can_notif:
not revente.notif_sent: self.stdout.write(str(now))
self.stdout.write(str(now)) revente.mail_shotgun()
revente.mail_shotgun() self.stdout.write(
self.stdout.write("Mail de disponibilité immédiate envoyé") "Mails de disponibilité immédiate envoyés "
# Check si délai de retrait dépassé "pour la revente [%s]" % revente
elif (now >= revente.date + timedelta(hours=1) and )
not revente.notif_sent):
# Le spectacle est dans plus longtemps : on prévient
elif (revente.can_notif and not revente.notif_sent):
self.stdout.write(str(now)) self.stdout.write(str(now))
revente.send_notif() revente.send_notif()
self.stdout.write("Mail d'inscription à une revente envoyé") self.stdout.write(
# Check si tirage à faire "Mails d'inscription à la revente [%s] envoyés"
elif (now >= revente.date_tirage and % revente
not revente.tirage_done): )
# On fait le tirage
elif (now >= revente.date_tirage and not revente.tirage_done):
self.stdout.write(str(now)) self.stdout.write(str(now))
revente.tirage() winner = revente.tirage()
self.stdout.write("Tirage effectué, mails envoyés") self.stdout.write(
"Tirage effectué pour la revente [%s]"
% revente
)
if winner:
self.stdout.write("Gagnant : %s" % winner.user)
else:
self.stdout.write("Pas de gagnant ; place au shotgun")

View file

@ -233,17 +233,46 @@ class SpectacleRevente(models.Model):
default=False) default=False)
shotgun = models.BooleanField("Disponible immédiatement", shotgun = models.BooleanField("Disponible immédiatement",
default=False) default=False)
####
# Some class attributes
###
# TODO : settings ?
# Temps minimum entre le tirage et le spectacle
min_margin = timedelta(days=5)
# Temps entre la création d'une revente et l'envoi du mail
remorse_time = timedelta(hours=1)
# Temps min/max d'attente avant le tirage
max_wait_time = timedelta(days=3)
min_wait_time = timedelta(days=1)
@property @property
def date_tirage(self): def date_tirage(self):
"""Renvoie la date du tirage au sort de la revente.""" """Renvoie la date du tirage au sort de la revente."""
# L'acheteur doit être connu au plus 12h avant le spectacle notif_time = self.date + self.remorse_time
remaining_time = (self.attribution.spectacle.date remaining_time = (self.attribution.spectacle.date
- self.date - timedelta(hours=13)) - notif_time - self.min_margin)
# Au minimum, on attend 2 jours avant le tirage
delay = min(remaining_time, timedelta(days=2)) delay = min(remaining_time, self.max_wait_time)
# Le vendeur a aussi 1h pour changer d'avis
return self.date + delay + timedelta(hours=1) return notif_time + delay
@property
def is_urgent(self):
"""
Renvoie True iff la revente doit être mise au shotgun directement.
Plus précisément, on doit avoir min_margin + min_wait_time de marge.
"""
spectacle_date = self.attribution.spectacle.date
return (spectacle_date <= timezone.now() + self.min_margin
+ self.min_wait_time)
@property
def can_notif(self):
return (timezone.now() >= self.date + self.remorse_time)
def __str__(self): def __str__(self):
return "%s -- %s" % (self.seller, return "%s -- %s" % (self.seller,
@ -353,8 +382,12 @@ class SpectacleRevente(models.Model):
[inscrit.user.email] [inscrit.user.email]
)) ))
send_mass_custom_mail(datatuple) send_mass_custom_mail(datatuple)
return winner
# Si personne ne veut de la place, elle part au shotgun # Si personne ne veut de la place, elle part au shotgun
else: else:
self.shotgun = True self.shotgun = True
return None
self.tirage_done = True self.tirage_done = True
self.save() self.save()