forked from ScoDoc/ScoDoc
Assiduites: api routes nip ine
This commit is contained in:
parent
e5b1082e1d
commit
3aa5629d1b
@ -15,7 +15,7 @@ from app import db, log
|
|||||||
import app.scodoc.sco_assiduites as scass
|
import app.scodoc.sco_assiduites as scass
|
||||||
import app.scodoc.sco_utils as scu
|
import app.scodoc.sco_utils as scu
|
||||||
from app.api import api_bp as bp
|
from app.api import api_bp as bp
|
||||||
from app.api import api_web_bp, get_model_api_object
|
from app.api import api_web_bp, get_model_api_object, tools
|
||||||
from app.decorators import permission_required, scodoc
|
from app.decorators import permission_required, scodoc
|
||||||
from app.models import Assiduite, FormSemestre, Identite, ModuleImpl, Scolog
|
from app.models import Assiduite, FormSemestre, Identite, ModuleImpl, Scolog
|
||||||
from app.scodoc.sco_exceptions import ScoValueError
|
from app.scodoc.sco_exceptions import ScoValueError
|
||||||
@ -47,15 +47,35 @@ def assiduite(assiduite_id: int = None):
|
|||||||
return get_model_api_object(Assiduite, assiduite_id, Identite)
|
return get_model_api_object(Assiduite, assiduite_id, Identite)
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/assiduites/<int:etudid>/count", defaults={"with_query": False})
|
# etudid
|
||||||
@bp.route("/assiduites/<int:etudid>/count/query", defaults={"with_query": True})
|
@bp.route("/assiduites/<etudid>/count", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/assiduites/<int:etudid>/count", defaults={"with_query": False})
|
@api_web_bp.route("/assiduites/<etudid>/count", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/assiduites/<int:etudid>/count/query", defaults={"with_query": True})
|
@bp.route("/assiduites/<etudid>/count/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/<etudid>/count/query", defaults={"with_query": True})
|
||||||
|
@bp.route("/assiduites/etudid/<etudid>/count", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/etudid/<etudid>/count", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/etudid/<etudid>/count/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route(
|
||||||
|
"/assiduites/etudid/<etudid>/count/query", defaults={"with_query": True}
|
||||||
|
)
|
||||||
|
# nip
|
||||||
|
@bp.route("/assiduites/nip/<nip>/count", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/nip/<nip>/count", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/nip/<nip>/count/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/nip/<nip>/count/query", defaults={"with_query": True})
|
||||||
|
# ine
|
||||||
|
@bp.route("/assiduites/ine/<ine>/count", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/ine/<ine>/count", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/ine/<ine>/count/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/ine/<ine>/count/query", defaults={"with_query": True})
|
||||||
|
#
|
||||||
@login_required
|
@login_required
|
||||||
@scodoc
|
@scodoc
|
||||||
@as_json
|
@as_json
|
||||||
@permission_required(Permission.ScoView)
|
@permission_required(Permission.ScoView)
|
||||||
def count_assiduites(etudid: int = None, with_query: bool = False):
|
def count_assiduites(
|
||||||
|
etudid: int = None, nip: str = None, ine: str = None, with_query: bool = False
|
||||||
|
):
|
||||||
"""
|
"""
|
||||||
Retourne le nombre d'assiduités d'un étudiant
|
Retourne le nombre d'assiduités d'un étudiant
|
||||||
chemin : /assiduites/<int:etudid>/count
|
chemin : /assiduites/<int:etudid>/count
|
||||||
@ -100,11 +120,20 @@ def count_assiduites(etudid: int = None, with_query: bool = False):
|
|||||||
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
query = Identite.query.filter_by(id=etudid)
|
# query = Identite.query.filter_by(id=etudid)
|
||||||
if g.scodoc_dept:
|
# if g.scodoc_dept:
|
||||||
query = query.filter_by(dept_id=g.scodoc_dept_id)
|
# query = query.filter_by(dept_id=g.scodoc_dept_id)
|
||||||
|
|
||||||
|
# etud: Identite = query.first_or_404(etudid)
|
||||||
|
|
||||||
|
etud: Identite = tools.get_etud(etudid, nip, ine)
|
||||||
|
|
||||||
|
if etud is None:
|
||||||
|
return json_error(
|
||||||
|
404,
|
||||||
|
message="étudiant inconnu",
|
||||||
|
)
|
||||||
|
|
||||||
etud: Identite = query.first_or_404(etudid)
|
|
||||||
filtered: dict[str, object] = {}
|
filtered: dict[str, object] = {}
|
||||||
metric: str = "all"
|
metric: str = "all"
|
||||||
|
|
||||||
@ -116,15 +145,31 @@ def count_assiduites(etudid: int = None, with_query: bool = False):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/assiduites/<int:etudid>", defaults={"with_query": False})
|
# etudid
|
||||||
@bp.route("/assiduites/<int:etudid>/query", defaults={"with_query": True})
|
@bp.route("/assiduites/<etudid>", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/assiduites/<int:etudid>", defaults={"with_query": False})
|
@api_web_bp.route("/assiduites/<etudid>", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/assiduites/<int:etudid>/query", defaults={"with_query": True})
|
@bp.route("/assiduites/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@bp.route("/assiduites/etudid/<etudid>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/etudid/<etudid>", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/etudid/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/etudid/<etudid>/query", defaults={"with_query": True})
|
||||||
|
# nip
|
||||||
|
@bp.route("/assiduites/nip/<nip>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/nip/<nip>", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/nip/<nip>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/nip/<nip>/query", defaults={"with_query": True})
|
||||||
|
# ine
|
||||||
|
@bp.route("/assiduites/ine/<ine>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/assiduites/ine/<ine>", defaults={"with_query": False})
|
||||||
|
@bp.route("/assiduites/ine/<ine>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/assiduites/ine/<ine>/query", defaults={"with_query": True})
|
||||||
|
#
|
||||||
@login_required
|
@login_required
|
||||||
@scodoc
|
@scodoc
|
||||||
@as_json
|
@as_json
|
||||||
@permission_required(Permission.ScoView)
|
@permission_required(Permission.ScoView)
|
||||||
def assiduites(etudid: int = None, with_query: bool = False):
|
def assiduites(etudid: int = None, nip=None, ine=None, with_query: bool = False):
|
||||||
"""
|
"""
|
||||||
Retourne toutes les assiduités d'un étudiant
|
Retourne toutes les assiduités d'un étudiant
|
||||||
chemin : /assiduites/<int:etudid>
|
chemin : /assiduites/<int:etudid>
|
||||||
@ -164,11 +209,18 @@ def assiduites(etudid: int = None, with_query: bool = False):
|
|||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
query = Identite.query.filter_by(id=etudid)
|
# query = Identite.query.filter_by(id=etudid)
|
||||||
if g.scodoc_dept:
|
# if g.scodoc_dept:
|
||||||
query = query.filter_by(dept_id=g.scodoc_dept_id)
|
# query = query.filter_by(dept_id=g.scodoc_dept_id)
|
||||||
|
|
||||||
etud: Identite = query.first_or_404(etudid)
|
# etud: Identite = query.first_or_404(etudid)
|
||||||
|
etud: Identite = tools.get_etud(etudid, nip, ine)
|
||||||
|
|
||||||
|
if etud is None:
|
||||||
|
return json_error(
|
||||||
|
404,
|
||||||
|
message="étudiant inconnu",
|
||||||
|
)
|
||||||
assiduites_query = etud.assiduites
|
assiduites_query = etud.assiduites
|
||||||
|
|
||||||
if with_query:
|
if with_query:
|
||||||
@ -340,13 +392,23 @@ def count_assiduites_formsemestre(
|
|||||||
return scass.get_assiduites_stats(assiduites_query, metric, filtered)
|
return scass.get_assiduites_stats(assiduites_query, metric, filtered)
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/assiduite/<int:etudid>/create", methods=["POST"])
|
# etudid
|
||||||
@api_web_bp.route("/assiduite/<int:etudid>/create", methods=["POST"])
|
@bp.route("/assiduite/<etudid>/create", methods=["POST"])
|
||||||
|
@api_web_bp.route("/assiduite/<etudid>/create", methods=["POST"])
|
||||||
|
@bp.route("/assiduite/etudid/<etudid>/create", methods=["POST"])
|
||||||
|
@api_web_bp.route("/assiduite/etudid/<etudid>/create", methods=["POST"])
|
||||||
|
# nip
|
||||||
|
@bp.route("/assiduite/nip/<nip>/create", methods=["POST"])
|
||||||
|
@api_web_bp.route("/assiduite/nip/<nip>/create", methods=["POST"])
|
||||||
|
# ine
|
||||||
|
@bp.route("/assiduite/ine/<ine>/create", methods=["POST"])
|
||||||
|
@api_web_bp.route("/assiduite/ine/<ine>/create", methods=["POST"])
|
||||||
|
#
|
||||||
@scodoc
|
@scodoc
|
||||||
@as_json
|
@as_json
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required(Permission.ScoAbsChange)
|
@permission_required(Permission.ScoAbsChange)
|
||||||
def assiduite_create(etudid: int = None):
|
def assiduite_create(etudid: int = None, nip=None, ine=None):
|
||||||
"""
|
"""
|
||||||
Création d'une assiduité pour l'étudiant (etudid)
|
Création d'une assiduité pour l'étudiant (etudid)
|
||||||
La requête doit avoir un content type "application/json":
|
La requête doit avoir un content type "application/json":
|
||||||
@ -367,7 +429,13 @@ def assiduite_create(etudid: int = None):
|
|||||||
]
|
]
|
||||||
|
|
||||||
"""
|
"""
|
||||||
etud: Identite = Identite.query.filter_by(id=etudid).first_or_404()
|
etud: Identite = tools.get_etud(etudid, nip, ine)
|
||||||
|
|
||||||
|
if etud is None:
|
||||||
|
return json_error(
|
||||||
|
404,
|
||||||
|
message="étudiant inconnu",
|
||||||
|
)
|
||||||
|
|
||||||
create_list: list[object] = request.get_json(force=True)
|
create_list: list[object] = request.get_json(force=True)
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ import app.scodoc.sco_utils as scu
|
|||||||
from app import db
|
from app import db
|
||||||
from app.api import api_bp as bp
|
from app.api import api_bp as bp
|
||||||
from app.api import api_web_bp
|
from app.api import api_web_bp
|
||||||
from app.api import get_model_api_object
|
from app.api import get_model_api_object, tools
|
||||||
from app.decorators import permission_required, scodoc
|
from app.decorators import permission_required, scodoc
|
||||||
from app.models import Identite, Justificatif, Departement
|
from app.models import Identite, Justificatif, Departement
|
||||||
from app.models.assiduites import compute_assiduites_justified
|
from app.models.assiduites import compute_assiduites_justified
|
||||||
@ -52,15 +52,31 @@ def justificatif(justif_id: int = None):
|
|||||||
return get_model_api_object(Justificatif, justif_id, Identite)
|
return get_model_api_object(Justificatif, justif_id, Identite)
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/justificatifs/<int:etudid>", defaults={"with_query": False})
|
# etudid
|
||||||
@bp.route("/justificatifs/<int:etudid>/query", defaults={"with_query": True})
|
@bp.route("/justificatifs/<etudid>", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/justificatifs/<int:etudid>", defaults={"with_query": False})
|
@api_web_bp.route("/justificatifs/<etudid>", defaults={"with_query": False})
|
||||||
@api_web_bp.route("/justificatifs/<int:etudid>/query", defaults={"with_query": True})
|
@bp.route("/justificatifs/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/justificatifs/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@bp.route("/justificatifs/etudid/<etudid>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/justificatifs/etudid/<etudid>", defaults={"with_query": False})
|
||||||
|
@bp.route("/justificatifs/etudid/<etudid>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/justificatifs/etudid/<etudid>/query", defaults={"with_query": True})
|
||||||
|
# nip
|
||||||
|
@bp.route("/justificatifs/nip/<nip>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/justificatifs/nip/<nip>", defaults={"with_query": False})
|
||||||
|
@bp.route("/justificatifs/nip/<nip>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/justificatifs/nip/<nip>/query", defaults={"with_query": True})
|
||||||
|
# ine
|
||||||
|
@bp.route("/justificatifs/ine/<ine>", defaults={"with_query": False})
|
||||||
|
@api_web_bp.route("/justificatifs/ine/<ine>", defaults={"with_query": False})
|
||||||
|
@bp.route("/justificatifs/ine/<ine>/query", defaults={"with_query": True})
|
||||||
|
@api_web_bp.route("/justificatifs/ine/<ine>/query", defaults={"with_query": True})
|
||||||
|
#
|
||||||
@login_required
|
@login_required
|
||||||
@scodoc
|
@scodoc
|
||||||
@as_json
|
@as_json
|
||||||
@permission_required(Permission.ScoView)
|
@permission_required(Permission.ScoView)
|
||||||
def justificatifs(etudid: int = None, with_query: bool = False):
|
def justificatifs(etudid: int = None, nip=None, ine=None, with_query: bool = False):
|
||||||
"""
|
"""
|
||||||
Retourne toutes les assiduités d'un étudiant
|
Retourne toutes les assiduités d'un étudiant
|
||||||
chemin : /justificatifs/<int:etudid>
|
chemin : /justificatifs/<int:etudid>
|
||||||
@ -87,11 +103,13 @@ def justificatifs(etudid: int = None, with_query: bool = False):
|
|||||||
ex query?user_id=3
|
ex query?user_id=3
|
||||||
"""
|
"""
|
||||||
|
|
||||||
query = Identite.query.filter_by(id=etudid)
|
etud: Identite = tools.get_etud(etudid, nip, ine)
|
||||||
if g.scodoc_dept:
|
|
||||||
query = query.filter_by(dept_id=g.scodoc_dept_id)
|
|
||||||
|
|
||||||
etud: Identite = query.first_or_404(etudid)
|
if etud is None:
|
||||||
|
return json_error(
|
||||||
|
404,
|
||||||
|
message="étudiant inconnu",
|
||||||
|
)
|
||||||
justificatifs_query = etud.justificatifs
|
justificatifs_query = etud.justificatifs
|
||||||
|
|
||||||
if with_query:
|
if with_query:
|
||||||
@ -136,7 +154,7 @@ def justificatifs_dept(dept_id: int = None, with_query: bool = False):
|
|||||||
@login_required
|
@login_required
|
||||||
@as_json
|
@as_json
|
||||||
@permission_required(Permission.ScoAbsChange)
|
@permission_required(Permission.ScoAbsChange)
|
||||||
def justif_create(etudid: int = None):
|
def justif_create(etudid: int = None, nip = None, ine = None):
|
||||||
"""
|
"""
|
||||||
Création d'un justificatif pour l'étudiant (etudid)
|
Création d'un justificatif pour l'étudiant (etudid)
|
||||||
La requête doit avoir un content type "application/json":
|
La requête doit avoir un content type "application/json":
|
||||||
@ -156,7 +174,13 @@ def justif_create(etudid: int = None):
|
|||||||
]
|
]
|
||||||
|
|
||||||
"""
|
"""
|
||||||
etud: Identite = Identite.query.filter_by(id=etudid).first_or_404()
|
etud: Identite = tools.get_etud(etudid, nip, ine)
|
||||||
|
|
||||||
|
if etud is None:
|
||||||
|
return json_error(
|
||||||
|
404,
|
||||||
|
message="étudiant inconnu",
|
||||||
|
)
|
||||||
|
|
||||||
create_list: list[object] = request.get_json(force=True)
|
create_list: list[object] = request.get_json(force=True)
|
||||||
|
|
||||||
|
@ -446,8 +446,6 @@ def signal_assiduites_group():
|
|||||||
date: str = request.args.get("jour", datetime.date.today().isoformat())
|
date: str = request.args.get("jour", datetime.date.today().isoformat())
|
||||||
group_ids: list[int] = request.args.get("group_ids", None)
|
group_ids: list[int] = request.args.get("group_ids", None)
|
||||||
|
|
||||||
readonly: str = "false"
|
|
||||||
|
|
||||||
if group_ids is None:
|
if group_ids is None:
|
||||||
group_ids = []
|
group_ids = []
|
||||||
else:
|
else:
|
||||||
@ -573,7 +571,7 @@ def signal_assiduites_group():
|
|||||||
dept_id=g.scodoc_dept_id,
|
dept_id=g.scodoc_dept_id,
|
||||||
),
|
),
|
||||||
defdem=_get_etuds_dem_def(formsemestre),
|
defdem=_get_etuds_dem_def(formsemestre),
|
||||||
readonly=readonly,
|
readonly="false",
|
||||||
),
|
),
|
||||||
html_sco_header.sco_footer(),
|
html_sco_header.sco_footer(),
|
||||||
).build()
|
).build()
|
||||||
@ -594,8 +592,6 @@ def visu_assiduites_group():
|
|||||||
date: str = request.args.get("jour", datetime.date.today().isoformat())
|
date: str = request.args.get("jour", datetime.date.today().isoformat())
|
||||||
group_ids: list[int] = request.args.get("group_ids", None)
|
group_ids: list[int] = request.args.get("group_ids", None)
|
||||||
|
|
||||||
readonly: str = "true"
|
|
||||||
|
|
||||||
if group_ids is None:
|
if group_ids is None:
|
||||||
group_ids = []
|
group_ids = []
|
||||||
else:
|
else:
|
||||||
@ -721,7 +717,7 @@ def visu_assiduites_group():
|
|||||||
dept_id=g.scodoc_dept_id,
|
dept_id=g.scodoc_dept_id,
|
||||||
),
|
),
|
||||||
defdem=_get_etuds_dem_def(formsemestre),
|
defdem=_get_etuds_dem_def(formsemestre),
|
||||||
readonly=readonly,
|
readonly="true",
|
||||||
),
|
),
|
||||||
html_sco_header.sco_footer(),
|
html_sco_header.sco_footer(),
|
||||||
).build()
|
).build()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user