mirror of
https://git.v0id.ovh/n3wt-innov/n3wt-school.git
synced 2026-01-28 23:43:22 +00:00
chore: Lors de la création d'un établissement, création d'un directeur
et d'un SMTP Settings (utilisé pour les envois de dossiers)
This commit is contained in:
@ -13,7 +13,7 @@ class EvaluationFrequency(models.IntegerChoices):
|
||||
YEAR = 3, _("Année")
|
||||
|
||||
class Establishment(models.Model):
|
||||
name = models.CharField(max_length=255, unique=True)
|
||||
name = models.CharField(max_length=255)
|
||||
address = models.CharField(max_length=255)
|
||||
total_capacity = models.IntegerField()
|
||||
establishment_type = ArrayField(models.IntegerField(choices=StructureType.choices))
|
||||
|
||||
@ -9,6 +9,8 @@ from .serializers import EstablishmentSerializer
|
||||
from N3wtSchool.bdd import delete_object, getAllObjects
|
||||
from School.models import EstablishmentCompetency, Competency
|
||||
from django.db.models import Q
|
||||
from Auth.models import Profile, ProfileRole, Directeur
|
||||
from Settings.models import SMTPSettings
|
||||
|
||||
@method_decorator(csrf_protect, name='dispatch')
|
||||
@method_decorator(ensure_csrf_cookie, name='dispatch')
|
||||
@ -20,9 +22,8 @@ class EstablishmentListCreateView(APIView):
|
||||
|
||||
def post(self, request):
|
||||
establishment_data = JSONParser().parse(request)
|
||||
establishment_serializer = EstablishmentSerializer(data=establishment_data)
|
||||
if establishment_serializer.is_valid():
|
||||
establishment = establishment_serializer.save()
|
||||
try:
|
||||
establishment, data = create_establishment_with_directeur(establishment_data)
|
||||
# Création des EstablishmentCompetency pour chaque compétence existante
|
||||
competencies = Competency.objects.filter(
|
||||
Q(end_of_cycle=True) | ~Q(level=None)
|
||||
@ -33,8 +34,9 @@ class EstablishmentListCreateView(APIView):
|
||||
competency=competency,
|
||||
defaults={'is_required': True}
|
||||
)
|
||||
return JsonResponse(establishment_serializer.data, safe=False, status=status.HTTP_201_CREATED)
|
||||
return JsonResponse(establishment_serializer.errors, safe=False, status=status.HTTP_400_BAD_REQUEST)
|
||||
return JsonResponse(data, safe=False, status=status.HTTP_201_CREATED)
|
||||
except Exception as e:
|
||||
return JsonResponse({"error": str(e)}, status=status.HTTP_400_BAD_REQUEST)
|
||||
|
||||
@method_decorator(csrf_protect, name='dispatch')
|
||||
@method_decorator(ensure_csrf_cookie, name='dispatch')
|
||||
@ -60,4 +62,56 @@ class EstablishmentDetailView(APIView):
|
||||
return JsonResponse(establishment_serializer.errors, safe=False, status=status.HTTP_400_BAD_REQUEST)
|
||||
|
||||
def delete(self, request, id):
|
||||
return delete_object(Establishment, id)
|
||||
return delete_object(Establishment, id)
|
||||
|
||||
def create_establishment_with_directeur(establishment_data):
|
||||
# Extraction des sous-objets
|
||||
directeur_data = establishment_data.pop("directeur", None)
|
||||
smtp_settings_data = establishment_data.pop("smtp_settings", {})
|
||||
|
||||
# Vérification de la présence du directeur
|
||||
if not directeur_data or not directeur_data.get("email"):
|
||||
raise ValueError("Le champ 'directeur.email' est obligatoire.")
|
||||
|
||||
directeur_email = directeur_data.get("email")
|
||||
last_name = directeur_data.get("last_name", "")
|
||||
first_name = directeur_data.get("first_name", "")
|
||||
password = directeur_data.get("password", "Provisoire01!")
|
||||
|
||||
# Création ou récupération du profil utilisateur
|
||||
profile, created = Profile.objects.get_or_create(
|
||||
email=directeur_email,
|
||||
defaults={"username": directeur_email}
|
||||
)
|
||||
if created or not profile.has_usable_password():
|
||||
profile.set_password(password)
|
||||
profile.save()
|
||||
|
||||
# Création de l'établissement
|
||||
establishment_serializer = EstablishmentSerializer(data=establishment_data)
|
||||
establishment_serializer.is_valid(raise_exception=True)
|
||||
establishment = establishment_serializer.save()
|
||||
|
||||
# Création ou récupération du ProfileRole ADMIN pour ce profil et cet établissement
|
||||
profile_role, _ = ProfileRole.objects.get_or_create(
|
||||
profile=profile,
|
||||
establishment=establishment,
|
||||
role_type=ProfileRole.RoleType.PROFIL_ADMIN,
|
||||
defaults={"is_active": True}
|
||||
)
|
||||
|
||||
# Création ou mise à jour du Directeur lié à ce ProfileRole
|
||||
Directeur.objects.update_or_create(
|
||||
profile_role=profile_role,
|
||||
defaults={
|
||||
"last_name": last_name,
|
||||
"first_name": first_name
|
||||
}
|
||||
)
|
||||
|
||||
# Création du SMTPSettings rattaché à l'établissement si des données sont fournies
|
||||
if smtp_settings_data:
|
||||
smtp_settings_data["establishment"] = establishment
|
||||
SMTPSettings.objects.create(**smtp_settings_data)
|
||||
|
||||
return establishment, establishment_serializer.data
|
||||
Reference in New Issue
Block a user