From 847e275b265ef33a4c1211709edbf6cc939f2566 Mon Sep 17 00:00:00 2001 From: Emmanuel Viennet Date: Thu, 21 Jul 2022 08:53:44 +0200 Subject: [PATCH] API: /formsemestres/query --- app/api/formsemestres.py | 52 ++++++++++++++++++++++++---------- app/scodoc/sco_preferences.py | 2 ++ tests/api/exemple-api-basic.py | 5 ++-- 3 files changed, 42 insertions(+), 17 deletions(-) diff --git a/app/api/formsemestres.py b/app/api/formsemestres.py index 2924949d..8ae9967e 100644 --- a/app/api/formsemestres.py +++ b/app/api/formsemestres.py @@ -7,8 +7,7 @@ """ ScoDoc 9 API : accès aux formsemestres """ - -from flask import jsonify +from flask import abort, jsonify, request import app from app import models @@ -69,25 +68,48 @@ def formsemestre_infos(formsemestre_id: int): return jsonify(formsemestre.to_dict_api()) -@bp.route("/formsemestre/apo/", methods=["GET"]) +@bp.route("/formsemestres/query", methods=["GET"]) @token_auth.login_required @token_permission_required(Permission.APIView) -def formsemestre_apo(etape_apo: str): +def formsemestres_query(): """ - Retourne les informations sur les formsemestres ayant cette étape Apogée + Retourne les formsemestres filtrés par + étape Apogée ou année scolaire ou département (acronyme ou id) etape_apo : un code étape apogée - - Exemple de résultat : - [ - { ...formsemestre... - }, ... - ] + annee_scolaire : année de début de l'année scolaire + dept_acronym : acronyme du département (eg "RT") + dept_id : id du département """ - formsemestres = FormSemestre.query.filter( - FormSemestreEtape.etape_apo == etape_apo, - FormSemestreEtape.formsemestre_id == FormSemestre.id, - ) + etape_apo = request.args.get("etape_apo") + annee_scolaire = request.args.get("annee_scolaire") + dept_acronym = request.args.get("dept_acronym") + dept_id = request.args.get("dept_id") + formsemestres = FormSemestre.query + if etape_apo is not None: + formsemestres = formsemestres.join(FormSemestreEtape).filter( + FormSemestreEtape.etape_apo == etape_apo + ) + if annee_scolaire is not None: + try: + annee_scolaire_int = int(annee_scolaire) + except ValueError: + abort(404, "invalid annee_scolaire: not int") + debut_annee = scu.date_debut_anne_scolaire(annee_scolaire_int) + fin_annee = scu.date_fin_anne_scolaire(annee_scolaire_int) + formsemestres = formsemestres.filter( + FormSemestre.date_fin >= debut_annee, FormSemestre.date_debut <= fin_annee + ) + if dept_acronym is not None: + formsemestres = formsemestres.join(models.Departement).filter_by( + acronym=dept_acronym + ) + if dept_id is not None: + try: + dept_id = int(dept_id) + except ValueError: + abort(404, "invalid dept_id: not int") + formsemestres = formsemestres.filter_by(dept_id=dept_id) return jsonify([formsemestre.to_dict_api() for formsemestre in formsemestres]) diff --git a/app/scodoc/sco_preferences.py b/app/scodoc/sco_preferences.py index 49445bc9..c4955cd5 100644 --- a/app/scodoc/sco_preferences.py +++ b/app/scodoc/sco_preferences.py @@ -1893,6 +1893,8 @@ class BasePreferences(object): # log(f"loading preferences for dept_id={self.dept_id}") cnx = ndb.GetDBConnexion() + if self.dept_id: + g.scodoc_dept_id = self.dept_id preflist = self._editor.list(cnx, {"dept_id": self.dept_id}) self.prefs = {None: {}} # { formsemestre_id (or None) : { name : value } } self.default = {} # { name : default_value } diff --git a/tests/api/exemple-api-basic.py b/tests/api/exemple-api-basic.py index 4d41a3aa..45a4b98b 100644 --- a/tests/api/exemple-api-basic.py +++ b/tests/api/exemple-api-basic.py @@ -173,8 +173,9 @@ POST_JSON( POST_JSON(f"/partition/{2379}/delete") -# # --- Recupere la liste de tous les semestres: -# sems = GET(s, "Notes/formsemestre_list?format=json", "Aucun semestre !") +# Recherche de formsemestres +sems = GET(f"/formsemestres/query?etape_apo=V1RT&annee_scolaire=2021") + # # sems est une liste de semestres (dictionnaires) # for sem in sems: