# Generated by Django 6.0.5 on 2026-05-28 15:03 import django.contrib.auth.models import django.contrib.auth.validators import django.db.models.deletion import django.utils.timezone from django.conf import settings from django.db import migrations, models class Migration(migrations.Migration): initial = True dependencies = [ ('auth', '0012_alter_user_first_name_max_length'), ] operations = [ migrations.CreateModel( name='User', fields=[ ('id', models.BigAutoField(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')), ('username', models.CharField(error_messages={'unique': 'A user with that username already exists.'}, help_text='Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.', max_length=150, unique=True, validators=[django.contrib.auth.validators.UnicodeUsernameValidator()], verbose_name='username')), ('first_name', models.CharField(blank=True, max_length=150, verbose_name='first name')), ('last_name', models.CharField(blank=True, max_length=150, verbose_name='last name')), ('is_staff', models.BooleanField(default=False, help_text='Designates whether the user can log into this admin site.', verbose_name='staff status')), ('is_active', models.BooleanField(default=True, help_text='Designates whether this user should be treated as active. Unselect this instead of deleting accounts.', verbose_name='active')), ('date_joined', models.DateTimeField(default=django.utils.timezone.now, verbose_name='date joined')), ('email', models.EmailField(max_length=254, unique=True, verbose_name='email')), ('initials', models.CharField(blank=True, max_length=5, verbose_name='initiales')), ('color', models.CharField(blank=True, max_length=7, verbose_name='couleur')), ('image', models.ImageField(blank=True, null=True, upload_to='user_images/', verbose_name='image')), ('phone_number', models.CharField(blank=True, max_length=20, verbose_name='numéro de téléphone')), ('c2c_extension', models.CharField(blank=True, max_length=10, verbose_name='extension click to call')), ('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': 'user', 'verbose_name_plural': 'users', }, managers=[ ('objects', django.contrib.auth.models.UserManager()), ], ), migrations.CreateModel( name='Authorization', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='créé le')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='modifié le')), ('obsolete', models.BooleanField(default=False, verbose_name='obsolète')), ('obsolete_at', models.DateTimeField(blank=True, null=True, verbose_name='obsolète le')), ('name', models.CharField(max_length=100, unique=True, verbose_name='nom')), ('code', models.CharField(max_length=100, unique=True, verbose_name='code')), ('description', models.TextField(blank=True, default='', verbose_name='description')), ('created_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='créé par')), ('updated_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='modifié par')), ], options={ 'verbose_name': 'Authorization', 'verbose_name_plural': 'Authorizations', }, ), migrations.CreateModel( name='M2M_RoleAuthorizations', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='créé le')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='modifié le')), ('obsolete', models.BooleanField(default=False, verbose_name='obsolète')), ('obsolete_at', models.DateTimeField(blank=True, null=True, verbose_name='obsolète le')), ('authorization', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='users.authorization')), ('created_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='créé par')), ('updated_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='modifié par')), ], ), migrations.CreateModel( name='Role', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='créé le')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='modifié le')), ('obsolete', models.BooleanField(default=False, verbose_name='obsolète')), ('obsolete_at', models.DateTimeField(blank=True, null=True, verbose_name='obsolète le')), ('name', models.CharField(max_length=100, unique=True, verbose_name='nom')), ('description', models.TextField(blank=True, default='', verbose_name='description')), ('authorizations', models.ManyToManyField(blank=True, related_name='roles', through='users.M2M_RoleAuthorizations', to='users.authorization', verbose_name='authorisations')), ('created_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='créé par')), ('updated_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='modifié par')), ], options={ 'verbose_name': 'role', 'verbose_name_plural': 'roles', }, ), migrations.AddField( model_name='m2m_roleauthorizations', name='role', field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='users.role'), ), migrations.CreateModel( name='Team', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='créé le')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='modifié le')), ('obsolete', models.BooleanField(default=False, verbose_name='obsolète')), ('obsolete_at', models.DateTimeField(blank=True, null=True, verbose_name='obsolète le')), ('name', models.CharField(max_length=255, unique=True, verbose_name='nom')), ('description', models.TextField(blank=True, default='', verbose_name='description')), ('created_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='créé par')), ('updated_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='modifié par')), ], options={ 'verbose_name': 'Team', 'verbose_name_plural': 'Teams', }, ), migrations.CreateModel( name='UserTeamRole', fields=[ ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='créé le')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='modifié le')), ('obsolete', models.BooleanField(default=False, verbose_name='obsolète')), ('obsolete_at', models.DateTimeField(blank=True, null=True, verbose_name='obsolète le')), ('created_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='créé par')), ('role', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='user_teams', to='users.role', verbose_name='rôle')), ('team', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='user_roles', to='users.team', verbose_name='équipe')), ('updated_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.PROTECT, related_name='+', to=settings.AUTH_USER_MODEL, verbose_name='modifié par')), ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='team_roles', to=settings.AUTH_USER_MODEL, verbose_name='utilisateur')), ], options={ 'abstract': False, }, ), migrations.AddConstraint( model_name='m2m_roleauthorizations', constraint=models.UniqueConstraint(fields=('role', 'authorization'), name='unique_role_authorization'), ), ]