2022-03-02 16:45:47 +01:00
|
|
|
|
#################################################### Absences #########################################################
|
|
|
|
|
from datetime import datetime
|
|
|
|
|
|
|
|
|
|
from flask import jsonify
|
|
|
|
|
|
|
|
|
|
from app import models
|
|
|
|
|
from app.api import bp
|
|
|
|
|
from app.api.errors import error_response
|
2022-04-25 15:25:45 +02:00
|
|
|
|
from app.api.auth import token_permission_required
|
2022-04-26 17:12:30 +02:00
|
|
|
|
from app.api.tools import get_etu_from_etudid_or_nip_or_ine
|
2022-04-27 05:19:13 +02:00
|
|
|
|
from app.scodoc import ndb
|
|
|
|
|
from app.scodoc import sco_abs
|
2022-04-25 15:25:45 +02:00
|
|
|
|
from app.scodoc.sco_abs import (
|
|
|
|
|
annule_absence,
|
|
|
|
|
annule_justif,
|
|
|
|
|
list_abs_date,
|
|
|
|
|
)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
from app.scodoc.sco_groups import get_group_members
|
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("/absences/etudid/<int:etudid>", methods=["GET"])
|
|
|
|
|
@bp.route("/absences/nip/<int:nip>", methods=["GET"])
|
|
|
|
|
@bp.route("/absences/ine/<int:ine>", methods=["GET"])
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIView)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
def absences(etudid: int = None, nip: int = None, ine: int = None):
|
|
|
|
|
"""
|
|
|
|
|
Retourne la liste des absences d'un étudiant donné
|
|
|
|
|
|
|
|
|
|
etudid : l'etudid d'un étudiant
|
|
|
|
|
nip: le code nip d'un étudiant
|
|
|
|
|
ine : le code ine d'un étudiant
|
|
|
|
|
"""
|
2022-04-25 15:25:45 +02:00
|
|
|
|
if etudid is None:
|
|
|
|
|
# Récupération de l'étudiant
|
2022-04-27 05:19:13 +02:00
|
|
|
|
etud = get_etu_from_etudid_or_nip_or_ine(etudid, nip, ine)
|
|
|
|
|
if etud is None:
|
2022-04-25 15:25:45 +02:00
|
|
|
|
return error_response(
|
|
|
|
|
409,
|
|
|
|
|
message="La requête ne peut être traitée en l’état actuel.\n "
|
2022-04-27 05:19:13 +02:00
|
|
|
|
"Veuillez vérifier que l'id de l'étudiant (etudid, nip, ine) est valide",
|
2022-04-25 15:25:45 +02:00
|
|
|
|
)
|
2022-04-27 05:19:13 +02:00
|
|
|
|
etudid = etud.etudid
|
2022-04-25 15:25:45 +02:00
|
|
|
|
|
|
|
|
|
# Récupération des absences de l'étudiant
|
2022-04-27 05:19:13 +02:00
|
|
|
|
ndb.open_db_connection()
|
|
|
|
|
absences = sco_abs.list_abs_date(etudid)
|
|
|
|
|
for absence in absences:
|
|
|
|
|
absence["jour"] = absence["jour"].isoformat()
|
|
|
|
|
return jsonify(absences)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
|
2022-04-25 15:25:45 +02:00
|
|
|
|
|
2022-04-27 05:19:13 +02:00
|
|
|
|
@bp.route("/absences/etudid/<int:etudid>/just", methods=["GET"])
|
|
|
|
|
@bp.route("/absences/nip/<int:nip>/just", methods=["GET"])
|
|
|
|
|
@bp.route("/absences/ine/<int:ine>/just", methods=["GET"])
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIView)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
def absences_justify(etudid: int = None, nip: int = None, ine: int = None):
|
|
|
|
|
"""
|
|
|
|
|
Retourne la liste des absences justifiées d'un étudiant donné
|
|
|
|
|
|
|
|
|
|
etudid : l'etudid d'un étudiant
|
|
|
|
|
nip: le code nip d'un étudiant
|
|
|
|
|
ine : le code ine d'un étudiant
|
|
|
|
|
"""
|
2022-04-25 15:25:45 +02:00
|
|
|
|
if etudid is None:
|
|
|
|
|
# Récupération de l'étudiant
|
|
|
|
|
try:
|
2022-04-26 17:12:30 +02:00
|
|
|
|
etu = get_etu_from_etudid_or_nip_or_ine(etudid, nip, ine)
|
2022-04-25 15:25:45 +02:00
|
|
|
|
etudid = etu.etudid
|
|
|
|
|
except AttributeError:
|
|
|
|
|
return error_response(
|
|
|
|
|
409,
|
|
|
|
|
message="La requête ne peut être traitée en l’état actuel.\n "
|
2022-04-27 05:19:13 +02:00
|
|
|
|
"Veuillez vérifier que l'id de l'étudiant (etudid, nip, ine) est valide",
|
2022-04-25 15:25:45 +02:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
# Récupération des absences justifiées de l'étudiant
|
2022-04-27 05:19:13 +02:00
|
|
|
|
absences = sco_abs.list_abs_date(etudid)
|
|
|
|
|
for absence in [absence for absence in absences if absence["estjust"]]:
|
|
|
|
|
absence["jour"] = absence["jour"].isoformat()
|
|
|
|
|
return jsonify(absences)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule?etudid=<int:etudid>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule?nip=<int:nip>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule?ine=<int:ine>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @token_permission_required(Permission.APIAbsChange)
|
|
|
|
|
# def abs_annule(
|
|
|
|
|
# jour: datetime, matin: str, etudid: int = None, nip: int = None, ine: int = None
|
|
|
|
|
# ):
|
|
|
|
|
# """
|
|
|
|
|
# Retourne un html
|
|
|
|
|
|
|
|
|
|
# jour : la date de l'absence a annulé
|
|
|
|
|
# matin : True ou False
|
|
|
|
|
# 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_abs.annule_absence()
|
|
|
|
|
|
|
|
|
|
# if etudid is None:
|
|
|
|
|
# # Récupération de l'étudiant
|
|
|
|
|
# try:
|
|
|
|
|
# etu = get_etu_from_etudid_or_nip_or_ine(etudid, nip, ine)
|
|
|
|
|
# etudid = etu.etudid
|
|
|
|
|
# except AttributeError:
|
|
|
|
|
# return error_response(
|
|
|
|
|
# 409,
|
|
|
|
|
# message="La requête ne peut être traitée en l’état actuel.\n "
|
|
|
|
|
# "Veilliez vérifier que l'id de l'étudiant (etudid, nip, ine) est valide",
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
# try:
|
|
|
|
|
# # Utilisation de la fonction annule_absence
|
|
|
|
|
# annule_absence(etudid, jour, matin)
|
|
|
|
|
# except AttributeError:
|
|
|
|
|
# return error_response(
|
|
|
|
|
# 409,
|
|
|
|
|
# message="La requête ne peut être traitée en l’état actuel.\n "
|
|
|
|
|
# "Veilliez vérifier que le 'jour' et le 'matin' sont valides",
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
# return error_response(200, message="OK")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule_justif?etudid=<int:etudid>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule_justif?nip=<int:nip>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @bp.route(
|
|
|
|
|
# "/absences/abs_annule_justif?ine=<int:ine>&jour=<string:jour>&matin=<string:matin>",
|
|
|
|
|
# methods=["POST"],
|
|
|
|
|
# )
|
|
|
|
|
# @token_permission_required(Permission.APIAbsChange)
|
|
|
|
|
# def abs_annule_justif(
|
|
|
|
|
# jour: datetime, matin: str, etudid: int = None, nip: int = None, ine: int = None
|
|
|
|
|
# ):
|
|
|
|
|
# """
|
|
|
|
|
# Retourne un html
|
|
|
|
|
|
|
|
|
|
# jour : la date de l'absence a annulé
|
|
|
|
|
# matin : True ou False
|
|
|
|
|
# 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_abs.annule_justif()
|
|
|
|
|
|
|
|
|
|
# if etudid is None:
|
|
|
|
|
# # Récupération de l'étudiant
|
|
|
|
|
# try:
|
|
|
|
|
# etu = get_etu_from_etudid_or_nip_or_ine(etudid, nip, ine)
|
|
|
|
|
# etudid = etu.etudid
|
|
|
|
|
# except AttributeError:
|
|
|
|
|
# return error_response(
|
|
|
|
|
# 409,
|
|
|
|
|
# message="La requête ne peut être traitée en l’état actuel.\n "
|
|
|
|
|
# "Veilliez vérifier que l'id de l'étudiant (etudid, nip, ine) est valide",
|
|
|
|
|
# )
|
|
|
|
|
# try:
|
|
|
|
|
# # Utilisation de la fonction annule_justif
|
|
|
|
|
# annule_justif(etudid, jour, matin)
|
|
|
|
|
# except ValueError:
|
|
|
|
|
# return error_response(
|
|
|
|
|
# 409,
|
|
|
|
|
# message="La requête ne peut être traitée en l’état actuel.\n "
|
|
|
|
|
# "Veilliez vérifier que le 'jour' et le 'matin' sont valides",
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
# return error_response(200, message="OK")
|
2022-03-02 16:45:47 +01:00
|
|
|
|
|
|
|
|
|
|
2022-04-25 15:25:45 +02:00
|
|
|
|
@bp.route(
|
|
|
|
|
"/absences/abs_group_etat/?group_id=<int:group_id>&date_debut=date_debut&date_fin=date_fin",
|
|
|
|
|
methods=["GET"],
|
|
|
|
|
)
|
2022-04-14 14:56:36 +02:00
|
|
|
|
@token_permission_required(Permission.APIView)
|
2022-04-27 05:19:13 +02:00
|
|
|
|
def abs_groupe_etat( # XXX A REVOIR XXX
|
2022-04-25 15:25:45 +02:00
|
|
|
|
group_id: int, date_debut, date_fin, with_boursier=True, format="html"
|
|
|
|
|
):
|
2022-03-02 16:45:47 +01:00
|
|
|
|
"""
|
|
|
|
|
Retoune la liste des absences d'un ou plusieurs groupes entre deux dates
|
|
|
|
|
"""
|
|
|
|
|
# Fonction utilisée : app.scodoc.sco_groups.get_group_members() et app.scodoc.sco_abs.list_abs_date()
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
# Utilisation de la fonction get_group_members
|
|
|
|
|
members = get_group_members(group_id)
|
|
|
|
|
except ValueError:
|
2022-04-25 15:25:45 +02:00
|
|
|
|
return error_response(
|
|
|
|
|
409, message="La requête ne peut être traitée en l’état actuel"
|
|
|
|
|
)
|
2022-03-02 16:45:47 +01:00
|
|
|
|
|
|
|
|
|
data = []
|
|
|
|
|
# Filtre entre les deux dates renseignées
|
|
|
|
|
for member in members:
|
|
|
|
|
abs = list_abs_date(member.id, date_debut, date_fin)
|
|
|
|
|
data.append(abs)
|
|
|
|
|
|
|
|
|
|
# return jsonify(data) # XXX TODO faire en sorte de pouvoir renvoyer sa (ex to_dict() dans absences)
|
2022-04-25 15:25:45 +02:00
|
|
|
|
return error_response(501, message="Not implemented")
|