ScoDoc/app/models/assiduites.py

162 lines
4.7 KiB
Python
Raw Normal View History

2022-10-28 11:42:52 +02:00
# -*- coding: UTF-8 -*
"""Gestion de l'assiduité (assiduités + justificatifs)
"""
from app import db
from app.models import ModuleImpl, ModuleImplInscription
from app.models.etudiants import Identite
from app.scodoc.sco_utils import EtatAssiduite, localize_datetime, is_period_overlapping
from app.scodoc.sco_exceptions import ScoValueError
from datetime import datetime
2022-10-28 11:42:52 +02:00
class Assiduite(db.Model):
"""
Représente une assiduité:
- une plage horaire lié à un état et un étudiant
- un module si spécifiée
- une description si spécifiée
2022-10-28 11:42:52 +02:00
"""
__tablename__ = "assiduites"
id = db.Column(db.Integer, primary_key=True)
assiduite_id = db.synonym("id")
2022-10-28 11:42:52 +02:00
date_debut = db.Column(
db.DateTime(timezone=True), server_default=db.func.now(), nullable=False
)
date_fin = db.Column(
db.DateTime(timezone=True), server_default=db.func.now(), nullable=False
)
moduleimpl_id = db.Column(
db.Integer,
db.ForeignKey("notes_moduleimpl.id", ondelete="SET NULL"),
)
etudid = db.Column(
db.Integer,
db.ForeignKey("identite.id", ondelete="CASCADE"),
index=True,
nullable=False,
)
etat = db.Column(db.Integer, nullable=False)
2022-10-28 11:42:52 +02:00
desc = db.Column(db.Text)
2022-10-28 11:42:52 +02:00
def to_dict(self) -> dict:
data = {
"assiduite_id": self.assiduite_id,
2022-10-28 11:42:52 +02:00
"etudid": self.etudid,
"moduleimpl_id": self.moduleimpl_id,
2022-10-28 11:42:52 +02:00
"date_debut": self.date_debut,
"date_fin": self.date_fin,
"etat": self.etat,
"desc": self.desc,
2022-10-28 11:42:52 +02:00
}
return data
@classmethod
def create_assiduite(
cls,
etud: Identite,
date_debut: datetime,
date_fin: datetime,
etat: EtatAssiduite,
moduleimpl: ModuleImpl = None,
description: str = None,
) -> object or int:
"""Créer une nouvelle assiduité pour l'étudiant"""
# Vérification de non duplication des périodes
assiduites: list[Assiduite] = etud.assiduites.all()
2022-12-19 21:32:45 +01:00
date_debut = localize_datetime(date_debut)
date_fin = localize_datetime(date_fin)
assiduites = [
ass
for ass in assiduites
if is_period_overlapping(
2022-12-19 21:32:45 +01:00
(date_debut, date_fin),
(ass.date_debut, ass.date_fin),
)
]
if len(assiduites) != 0:
raise ScoValueError(
"Duplication des assiduités (la période rentrée rentre en conflit avec une assiduité enregistrée)"
)
if moduleimpl is not None:
# Vérification de l'existence du module pour l'étudiant
if moduleimpl.est_inscrit(etud):
nouv_assiduite = Assiduite(
date_debut=date_debut,
date_fin=date_fin,
etat=etat,
etudiant=etud,
moduleimpl_id=moduleimpl.id,
desc=description,
)
else:
raise ScoValueError("L'étudiant n'est pas inscrit au moduleimpl")
else:
nouv_assiduite = Assiduite(
2022-12-19 21:32:45 +01:00
date_debut=date_debut,
date_fin=date_fin,
etat=etat,
etudiant=etud,
desc=description,
)
return nouv_assiduite
2022-10-28 11:42:52 +02:00
class Justificatif(db.Model):
"""
Représente un justificatif:
- une plage horaire lié à un état et un étudiant
- une raison si spécifiée
- un fichier si spécifié
"""
__tablename__ = "justificatifs"
justif_id = db.Column(db.Integer, primary_key=True)
2022-10-28 11:42:52 +02:00
date_debut = db.Column(
db.DateTime(timezone=True), server_default=db.func.now(), nullable=False
)
date_fin = db.Column(
db.DateTime(timezone=True), server_default=db.func.now(), nullable=False
)
etudid = db.Column(
db.Integer,
db.ForeignKey("identite.id", ondelete="CASCADE"),
index=True,
nullable=False,
)
etat = db.Column(
db.Integer,
)
raison = db.Column(db.Text())
"""
Les justificatifs sont enregistrés dans
<archivedir>/justificatifs/<dept_id>/<etudid>/<nom_fichier.extension>
d'après sco_archives.py#JustificatifArchiver
"""
fichier = db.Column(db.Text())
2022-10-28 11:42:52 +02:00
def to_dict(self) -> dict:
data = {
"justif_id": self.assiduite_id,
2022-10-28 11:42:52 +02:00
"etudid": self.etudid,
"date_debut": self.date_debut,
"date_fin": self.date_fin,
"etat": self.etat,
"raison": self.raison,
"fichier": self.fichier,
2022-10-28 11:42:52 +02:00
}
return data