diff --git a/app/models/modules.py b/app/models/modules.py index d4c70c03..c0bb84ac 100644 --- a/app/models/modules.py +++ b/app/models/modules.py @@ -6,6 +6,7 @@ from app.models import APO_CODE_STR_LEN from app.models.but_refcomp import ApcParcours, app_critiques_modules, parcours_modules from app.scodoc import sco_utils as scu from app.scodoc.sco_codes_parcours import UE_SPORT +from app.scodoc.sco_exceptions import ScoValueError from app.scodoc.sco_utils import ModuleType @@ -175,6 +176,8 @@ class Module(db.Model): ue_coef_dict = { ue_id : coef } Les coefs nuls (zéro) ne sont pas stockés: la relation est supprimée. """ + if self.formation.has_locked_sems(): + raise ScoValueError("Formation verrouillée") changed = False for ue_id, coef in ue_coef_dict.items(): # Existant ? @@ -201,6 +204,8 @@ class Module(db.Model): def update_ue_coef_dict(self, ue_coef_dict: dict): """update coefs vers UE (ajoute aux existants)""" + if self.formation.has_locked_sems(): + raise ScoValueError("Formation verrouillée") current = self.get_ue_coef_dict() current.update(ue_coef_dict) self.set_ue_coef_dict(current) @@ -211,6 +216,8 @@ class Module(db.Model): def delete_ue_coef(self, ue): """delete coef""" + if self.formation.has_locked_sems(): + raise ScoValueError("Formation verrouillée") ue_coef = ModuleUECoef.query.get((self.id, ue.id)) if ue_coef: db.session.delete(ue_coef) diff --git a/app/scodoc/sco_edit_ue.py b/app/scodoc/sco_edit_ue.py index 906493a2..576319fa 100644 --- a/app/scodoc/sco_edit_ue.py +++ b/app/scodoc/sco_edit_ue.py @@ -811,7 +811,7 @@ du programme" (menu "Semestre") si vous avez un semestre en cours); f"""