1
0
forked from ScoDoc/ScoDoc

Assiduite API: fix bug in _edit_one

This commit is contained in:
Emmanuel Viennet 2023-12-08 13:42:24 +01:00
parent 1c59cfdd93
commit 7ebec0bdcd

View File

@ -10,6 +10,7 @@ from datetime import datetime
from flask import g, request from flask import g, request
from flask_json import as_json from flask_json import as_json
from flask_login import current_user, login_required from flask_login import current_user, login_required
from flask_sqlalchemy.query import Query
from app import db, log, set_sco_dept from app import db, log, set_sco_dept
import app.scodoc.sco_assiduites as scass import app.scodoc.sco_assiduites as scass
@ -24,7 +25,6 @@ from app.models import (
ModuleImpl, ModuleImpl,
Scolog, Scolog,
) )
from flask_sqlalchemy.query import Query
from app.models.assiduites import ( from app.models.assiduites import (
get_assiduites_justif, get_assiduites_justif,
get_justifs_from_date, get_justifs_from_date,
@ -84,7 +84,7 @@ def assiduite_justificatifs(assiduite_id: int = None, long: bool = False):
] ]
""" """
return get_assiduites_justif(assiduite_id, True) return get_assiduites_justif(assiduite_id, long)
# etudid # etudid
@ -839,9 +839,6 @@ def assiduite_edit(assiduite_id: int):
# Récupération des valeurs à modifier # Récupération des valeurs à modifier
data = request.get_json(force=True) data = request.get_json(force=True)
# Préparation du retour
errors: list[str] = []
# Code 200 si modification réussie # Code 200 si modification réussie
# Code 404 si raté + message d'erreur # Code 404 si raté + message d'erreur
code, obj = _edit_one(assiduite_unique, data) code, obj = _edit_one(assiduite_unique, data)
@ -988,9 +985,7 @@ def _edit_one(assiduite_unique: Assiduite, data: dict) -> tuple[int, str]:
if moduleimpl is None: if moduleimpl is None:
errors.append("param 'moduleimpl_id': invalide") errors.append("param 'moduleimpl_id': invalide")
else: else:
if not moduleimpl.est_inscrit( if not moduleimpl.est_inscrit(assiduite_unique.etudiant):
Identite.query.filter_by(id=assiduite_unique.etudid).first()
):
errors.append("param 'moduleimpl_id': etud non inscrit") errors.append("param 'moduleimpl_id': etud non inscrit")
else: else:
# Mise à jour du moduleimpl # Mise à jour du moduleimpl
@ -1006,7 +1001,9 @@ def _edit_one(assiduite_unique: Assiduite, data: dict) -> tuple[int, str]:
if formsemestre: if formsemestre:
force = scu.is_assiduites_module_forced(formsemestre_id=formsemestre.id) force = scu.is_assiduites_module_forced(formsemestre_id=formsemestre.id)
else: else:
force = scu.is_assiduites_module_forced(dept_id=etud.dept_id) force = scu.is_assiduites_module_forced(
dept_id=assiduite_unique.etudiant.dept_id
)
external_data = ( external_data = (
external_data external_data