forked from DGNum/gestioCOF
112 lines
3.6 KiB
Python
112 lines
3.6 KiB
Python
# -*- coding: utf-8 -*-
|
|
from __future__ import unicode_literals
|
|
|
|
from django.conf import settings
|
|
from django.db import migrations, models
|
|
from django.utils import timezone
|
|
|
|
|
|
def fill_tirage_fields(apps, schema_editor):
|
|
"""
|
|
Create a `Tirage` to fill new field `tirage` of `Participant`
|
|
and `Spectacle` already existing.
|
|
"""
|
|
Participant = apps.get_model("bda", "Participant")
|
|
Spectacle = apps.get_model("bda", "Spectacle")
|
|
Tirage = apps.get_model("bda", "Tirage")
|
|
|
|
# These querysets only contains instances not linked to any `Tirage`.
|
|
participants = Participant.objects.filter(tirage=None)
|
|
spectacles = Spectacle.objects.filter(tirage=None)
|
|
|
|
if not participants.count() and not spectacles.count():
|
|
# No need to create a "trash" tirage.
|
|
return
|
|
|
|
tirage = Tirage.objects.create(
|
|
title="Tirage de test (migration)",
|
|
active=False,
|
|
ouverture=timezone.now(),
|
|
fermeture=timezone.now(),
|
|
)
|
|
|
|
participants.update(tirage=tirage)
|
|
spectacles.update(tirage=tirage)
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
dependencies = [("bda", "0001_initial")]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name="Tirage",
|
|
fields=[
|
|
(
|
|
"id",
|
|
models.AutoField(
|
|
verbose_name="ID",
|
|
serialize=False,
|
|
auto_created=True,
|
|
primary_key=True,
|
|
),
|
|
),
|
|
("title", models.CharField(max_length=300, verbose_name=b"Titre")),
|
|
(
|
|
"ouverture",
|
|
models.DateTimeField(
|
|
verbose_name=b"Date et heure d'ouverture du tirage"
|
|
),
|
|
),
|
|
(
|
|
"fermeture",
|
|
models.DateTimeField(
|
|
verbose_name=b"Date et heure de fermerture du tirage"
|
|
),
|
|
),
|
|
(
|
|
"token",
|
|
models.TextField(verbose_name=b"Graine du tirage", blank=True),
|
|
),
|
|
(
|
|
"active",
|
|
models.BooleanField(default=True, verbose_name=b"Tirage actif"),
|
|
),
|
|
],
|
|
),
|
|
migrations.AlterField(
|
|
model_name="participant",
|
|
name="user",
|
|
field=models.ForeignKey(
|
|
to=settings.AUTH_USER_MODEL, on_delete=models.CASCADE
|
|
),
|
|
),
|
|
# Create fields `spectacle` for `Participant` and `Spectacle` models.
|
|
# These fields are not nullable, but we first create them as nullable
|
|
# to give a default value for existing instances of these models.
|
|
migrations.AddField(
|
|
model_name="participant",
|
|
name="tirage",
|
|
field=models.ForeignKey(
|
|
to="bda.Tirage", null=True, on_delete=models.CASCADE
|
|
),
|
|
),
|
|
migrations.AddField(
|
|
model_name="spectacle",
|
|
name="tirage",
|
|
field=models.ForeignKey(
|
|
to="bda.Tirage", null=True, on_delete=models.CASCADE
|
|
),
|
|
),
|
|
migrations.RunPython(fill_tirage_fields, migrations.RunPython.noop),
|
|
migrations.AlterField(
|
|
model_name="participant",
|
|
name="tirage",
|
|
field=models.ForeignKey(to="bda.Tirage", on_delete=models.CASCADE),
|
|
),
|
|
migrations.AlterField(
|
|
model_name="spectacle",
|
|
name="tirage",
|
|
field=models.ForeignKey(to="bda.Tirage", on_delete=models.CASCADE),
|
|
),
|
|
]
|