[enh] ajout des migrations au code

pull/30/head
Vincent Adolphe 2018-01-09 16:27:42 +01:00
Parent 3cff19f6ea
révision 66b13c9874
4 fichiers modifiés avec 227 ajouts et 5 suppressions

5
.gitignore externe
Voir le fichier

@ -37,8 +37,3 @@ config.env
# Local overrides and variable content
local/
var/
### temporaire dev:
## en attendant que les migrations soient fixees
/betg/apps/*/migrations/

Voir le fichier

@ -0,0 +1,77 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.4 on 2018-01-09 15:26
from __future__ import unicode_literals
import betg.apps.evenements.models
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
initial = True
dependencies = [
('main', '0001_initial'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='Evenement',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('nom', models.CharField(max_length=60, verbose_name='Nom')),
('description', models.TextField(blank=True, verbose_name='Description')),
('date_debut', models.DateTimeField(verbose_name='Date et heure')),
('ordweek', models.PositiveIntegerField(editable=False, verbose_name='Ordinal de la semaine')),
('date_ouv_resa', models.DateField(blank=True, help_text="si non renseigné, utilise la date d'aujourd'hui", null=True, verbose_name="Date d'ouverture des réservations")),
('date_ferm_resa', models.DateField(blank=True, help_text='si non renseigné, utilise la valeur par défaut', null=True, verbose_name='Date de fermeture des réservations')),
('duree', models.DurationField(help_text='format: HH:MM:SS', verbose_name='Durée')),
('nb_places', models.PositiveIntegerField(verbose_name='Nombre total de places')),
('actif', models.BooleanField(default=True, help_text="Permet d'annuler un évenement")),
('verif_auto_faite', models.BooleanField(default=False, editable=False)),
('annulation_auto_nb_inscrit', models.BooleanField(default=True, help_text="annulation automatique si le nb d'inscrit est insuffisant à la 'date d'alerte inscription'", verbose_name='Annulation auto')),
('nb_places_min', models.PositiveIntegerField(blank=True, help_text="Alerter si le nb d'inscrit est inférieur à ce nombre", null=True, verbose_name="Nb minimum d'inscrit")),
('date_alert_nb_inscrit', models.DateField(blank=True, editable=False, help_text="Alerter a cette date si le nb d'inscrit est insuffisant", null=True, verbose_name="Date d'alerte inscription")),
('illustration', models.ImageField(blank=True, null=True, upload_to=betg.apps.evenements.models.upload_illustration_to, verbose_name='Illustration')),
('vignette', models.ImageField(blank=True, editable=False, null=True, upload_to=betg.apps.evenements.models.upload_vignette_to, verbose_name='Vignette')),
('lieu', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='evenements', related_query_name='evenement', to='main.Lieu')),
('organisateur', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
],
options={
'verbose_name_plural': 'Événements',
'verbose_name': 'Événement',
},
),
migrations.CreateModel(
name='Reservation',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('statut', models.CharField(choices=[('att', 'En attente'), ('acc', 'Accepté'), ('ref', 'Refusé'), ('nul', 'Annulé')], default='att', max_length=3, verbose_name='Statut')),
('present', models.BooleanField(default=False)),
('date_val', models.DateTimeField(blank=True, editable=False, null=True, verbose_name='date de validation')),
('message', models.TextField(blank=True, verbose_name='Message de refus')),
('evenement', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='reservations', related_query_name='reservation', to='evenements.Evenement')),
('personne', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='reservations', related_query_name='reservation', to=settings.AUTH_USER_MODEL)),
('resp', models.ForeignKey(blank=True, editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='resa_validees', related_query_name='resa_validee', to=settings.AUTH_USER_MODEL)),
],
options={
'verbose_name_plural': 'Réservations',
'verbose_name': 'Réservation',
},
),
migrations.AlterUniqueTogether(
name='reservation',
unique_together=set([('personne', 'evenement')]),
),
migrations.AlterUniqueTogether(
name='evenement',
unique_together=set([('nom', 'date_debut')]),
),
]

Voir le fichier

@ -0,0 +1,58 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.4 on 2018-01-09 15:26
from __future__ import unicode_literals
from django.conf import settings
import django.core.validators
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('contenttypes', '0002_remove_content_type_name'),
]
operations = [
migrations.CreateModel(
name='Commentaire',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('message', models.TextField(error_messages={'blank': 'Le message ne peut pas être vide.'}, verbose_name='Message')),
('object_id', models.PositiveIntegerField()),
('content_type', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='contenttypes.ContentType', verbose_name='Type de contenu')),
('personne', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='commentaires', related_query_name='commentaire', to=settings.AUTH_USER_MODEL)),
],
options={
'verbose_name': 'Commentaire',
'verbose_name_plural': 'Commentaires',
'ordering': ('-date_added',),
},
),
migrations.CreateModel(
name='Lieu',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('nom', models.CharField(max_length=60, verbose_name='Nom')),
('description', models.TextField(blank=True, verbose_name='Description')),
('adresse', models.TextField(verbose_name='Adresse')),
('commune', models.CharField(default='Grenay', max_length=60, verbose_name='Commune')),
('telephone', models.CharField(blank=True, max_length=16, validators=[django.core.validators.RegexValidator(message="Le numéro de téléphone doit être au format : '+33320000000'.", regex='^\\+?1?\\d{9,15}$')], verbose_name='Téléphone')),
('email', models.EmailField(blank=True, max_length=254, verbose_name='Adresse courriel')),
],
options={
'verbose_name': 'Lieu',
'verbose_name_plural': 'Lieux',
},
),
migrations.AlterUniqueTogether(
name='lieu',
unique_together=set([('nom', 'commune')]),
),
]

Voir le fichier

@ -0,0 +1,92 @@
# -*- coding: utf-8 -*-
# Generated by Django 1.11.4 on 2018-01-09 15:25
from __future__ import unicode_literals
import betg.apps.organisation.models
from django.conf import settings
import django.contrib.auth.validators
from django.db import migrations, models
import django.db.models.deletion
import mptt.fields
class Migration(migrations.Migration):
initial = True
dependencies = [
('auth', '0008_alter_user_username_max_length'),
]
operations = [
migrations.CreateModel(
name='Personne',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('password', models.CharField(max_length=128, verbose_name='password')),
('last_login', models.DateTimeField(blank=True, null=True, verbose_name='last login')),
('is_superuser', models.BooleanField(default=False, help_text='Designates that this user has all permissions without explicitly assigning them.', verbose_name='superuser status')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('username', models.CharField(error_messages={'unique': "Une personne avec ce nom d'utilisateur existe déjà."}, help_text='Un nom unique qui ne doit contenir que des caractères alphanumériques ainsi que @, ., +, - ou _.', max_length=150, unique=True, validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name="Nom d'utilisateur")),
('nom', models.CharField(max_length=30, verbose_name='Nom')),
('prenom', models.CharField(blank=True, max_length=30, verbose_name='Prénom')),
('email', models.EmailField(max_length=254, unique=True, verbose_name='Adresse courriel')),
('is_active', models.BooleanField(default=True, help_text="Indique si la personne doit être considérée comme active dans l'application.", verbose_name='Actif')),
('is_admin', models.BooleanField(default=False, help_text="Indique si la personne peut accéder à l'administration de l'application.", verbose_name='Administrateur')),
('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.Group', verbose_name='groups')),
('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.Permission', verbose_name='user permissions')),
],
options={
'verbose_name': 'Personne',
'verbose_name_plural': 'Personnes',
},
managers=[
('objects', betg.apps.organisation.models.PersonneManager()),
],
),
migrations.CreateModel(
name='Service',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('nom', models.CharField(max_length=60, unique=True, verbose_name='Nom')),
('description', models.TextField(blank=True, verbose_name='Description')),
('lft', models.PositiveIntegerField(db_index=True, editable=False)),
('rght', models.PositiveIntegerField(db_index=True, editable=False)),
('tree_id', models.PositiveIntegerField(db_index=True, editable=False)),
('level', models.PositiveIntegerField(db_index=True, editable=False)),
('parent', mptt.fields.TreeForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='children', related_query_name='child', to='organisation.Service', verbose_name='Service parent')),
],
options={
'verbose_name': 'Service',
'verbose_name_plural': 'Services',
},
),
migrations.CreateModel(
name='ServiceComposition',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('date_added', models.DateTimeField(auto_now_add=True, verbose_name="Date d'ajout")),
('date_updated', models.DateTimeField(auto_now=True, verbose_name='Date de modification')),
('fonction', models.CharField(choices=[('agent', 'Agent'), ('resp', 'Responsable')], default='agent', max_length=6, verbose_name='Fonction')),
('is_active', models.BooleanField(default=True, help_text='Indique si la personne fait toujours partie du service.', verbose_name='Actif')),
('personne', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
('service', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='organisation.Service')),
],
options={
'verbose_name': 'Composition du service',
'verbose_name_plural': 'Compositions du service',
},
),
migrations.AddField(
model_name='service',
name='personnes',
field=models.ManyToManyField(through='organisation.ServiceComposition', to=settings.AUTH_USER_MODEL),
),
migrations.AlterUniqueTogether(
name='servicecomposition',
unique_together=set([('personne', 'service', 'is_active')]),
),
]