2022-03-02 16:45:47 +01:00
|
|
|
|
############################################### Evaluations ###########################################################
|
|
|
|
|
from flask import jsonify
|
|
|
|
|
|
|
|
|
|
from app import models
|
|
|
|
|
from app.api import bp
|
2022-04-25 15:25:45 +02:00
|
|
|
|
from app.api.auth import token_permission_required
|
2022-03-02 16:45:47 +01:00
|
|
|
|
from app.api.errors import error_response
|
|
|
|
|
from app.scodoc.sco_evaluation_db import do_evaluation_get_all_notes
|
2022-03-04 17:16:08 +01:00
|
|
|
|
from app.scodoc.sco_permissions import Permission
|
2022-03-02 16:45:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@bp.route("/evaluations/<int:moduleimpl_id>", methods=["GET"])
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIView)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
def evaluations(moduleimpl_id: int):
|
|
|
|
|
"""
|
|
|
|
|
Retourne la liste des évaluations à partir de l'id d'un moduleimpl
|
|
|
|
|
|
|
|
|
|
moduleimpl_id : l'id d'un moduleimpl
|
|
|
|
|
"""
|
|
|
|
|
# Récupération de toutes les évaluations
|
|
|
|
|
evals = models.Evaluation.query.filter_by(id=moduleimpl_id).all()
|
|
|
|
|
|
|
|
|
|
# Mise en forme des données
|
|
|
|
|
data = [d.to_dict() for d in evals]
|
|
|
|
|
|
|
|
|
|
return jsonify(data)
|
|
|
|
|
# return error_response(501, message="Not implemented")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@bp.route("/evaluations/eval_notes/<int:evaluation_id>", methods=["GET"])
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIView)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
def evaluation_notes(evaluation_id: int):
|
|
|
|
|
"""
|
|
|
|
|
Retourne la liste des notes à partir de l'id d'une évaluation donnée
|
|
|
|
|
|
|
|
|
|
evaluation_id : l'id d'une évaluation
|
|
|
|
|
"""
|
|
|
|
|
# Fonction utilisée : app.scodoc.sco_evaluation_db.do_evaluation_get_all_notes()
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
# Utilisation de la fonction do_evaluation_get_all_notes
|
|
|
|
|
data = do_evaluation_get_all_notes(evaluation_id)
|
2022-04-25 15:25:45 +02:00
|
|
|
|
except AttributeError:
|
|
|
|
|
return error_response(
|
|
|
|
|
409,
|
|
|
|
|
message="La requête ne peut être traitée en l’état actuel. \n"
|
|
|
|
|
"Veillez vérifier la conformité du 'evaluation_id'",
|
|
|
|
|
)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
|
|
|
|
|
return jsonify(data)
|
|
|
|
|
|
|
|
|
|
|
2022-04-25 15:25:45 +02:00
|
|
|
|
@bp.route(
|
|
|
|
|
"/evaluations/eval_set_notes?eval_id=<int:eval_id>&etudid=<int:etudid>¬e=<float:note>",
|
|
|
|
|
methods=["POST"],
|
|
|
|
|
)
|
|
|
|
|
@bp.route(
|
|
|
|
|
"/evaluations/eval_set_notes?eval_id=<int:eval_id>&nip=<int:nip>¬e=<float:note>",
|
|
|
|
|
methods=["POST"],
|
|
|
|
|
)
|
|
|
|
|
@bp.route(
|
|
|
|
|
"/evaluations/eval_set_notes?eval_id=<int:eval_id>&ine=<int:ine>¬e=<float:note>",
|
|
|
|
|
methods=["POST"],
|
|
|
|
|
)
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIEditAllNotes)
|
2022-04-25 15:25:45 +02:00
|
|
|
|
def evaluation_set_notes(
|
|
|
|
|
eval_id: int, note: float, etudid: int = None, nip: int = None, ine: int = None
|
|
|
|
|
):
|
2022-03-02 16:45:47 +01:00
|
|
|
|
"""
|
|
|
|
|
Set les notes d'une évaluation pour un étudiant donnée
|
|
|
|
|
|
|
|
|
|
eval_id : l'id d'une évaluation
|
|
|
|
|
note : la note à attribuer
|
|
|
|
|
etudid : l'etudid d'un étudiant
|
|
|
|
|
nip : le code nip d'un étudiant
|
|
|
|
|
ine : le code ine d'un étudiant
|
|
|
|
|
"""
|
|
|
|
|
# Fonction utilisée : app.scodoc.sco_saisie_notes.notes_add()
|
|
|
|
|
|
|
|
|
|
# Qu'est ce qu'un user ???
|
|
|
|
|
# notes_add()
|
2022-04-25 15:25:45 +02:00
|
|
|
|
return error_response(501, message="Not implemented")
|