From c2798be033b7b5d004cc072756abebe22793c00e Mon Sep 17 00:00:00 2001
From: Emmanuel Viennet
Date: Wed, 16 Jun 2021 18:18:32 +0200
Subject: [PATCH] WIP refactoring, cont.
---
app/scodoc/VERSION.py | 1 +
app/scodoc/notes_table.py | 12 +-
app/scodoc/pe_jurype.py | 2 +-
app/scodoc/sco_bulletins.py | 2 +-
app/scodoc/sco_bulletins_json.py | 2 +-
app/scodoc/sco_bulletins_xml.py | 2 +-
app/scodoc/sco_compute_moy.py | 2 +-
app/scodoc/sco_edit_formation.py | 39 +-
app/scodoc/sco_edit_matiere.py | 112 ++++-
app/scodoc/sco_edit_module.py | 168 ++++++--
app/scodoc/sco_edit_ue.py | 193 +++++++--
app/scodoc/sco_etape_apogee_view.py | 2 +-
app/scodoc/sco_evaluations.py | 12 +-
app/scodoc/sco_export_results.py | 2 +-
app/scodoc/sco_formations.py | 41 +-
app/scodoc/sco_formsemestre_edit.py | 20 +-
app/scodoc/sco_formsemestre_exterieurs.py | 4 +-
app/scodoc/sco_formsemestre_status.py | 10 +-
app/scodoc/sco_formsemestre_validation.py | 6 +-
app/scodoc/sco_inscr_passage.py | 2 +-
app/scodoc/sco_liste_notes.py | 2 +-
app/scodoc/sco_moduleimpl.py | 6 +-
app/scodoc/sco_moduleimpl_inscriptions.py | 4 +-
app/scodoc/sco_moduleimpl_status.py | 4 +-
app/scodoc/sco_parcours_dut.py | 4 +-
app/scodoc/sco_placement.py | 2 +-
app/scodoc/sco_pvjury.py | 6 +-
app/scodoc/sco_recapcomplet.py | 2 +-
app/scodoc/sco_saisie_notes.py | 12 +-
app/scodoc/sco_tag_module.py | 2 +-
app/scodoc/sco_ue_external.py | 10 +-
app/views/notes.py | 482 +++-------------------
app/views/scolar.py | 8 +-
config/get_scodoc_version.sh | 2 +-
34 files changed, 606 insertions(+), 574 deletions(-)
diff --git a/app/scodoc/VERSION.py b/app/scodoc/VERSION.py
index 67d94d7b..de4344f4 100644
--- a/app/scodoc/VERSION.py
+++ b/app/scodoc/VERSION.py
@@ -8,6 +8,7 @@ SCONAME = "ScoDoc"
SCONEWS = """
Année 2021
+- Réécriture du système de publication, basé sur Flask.
- Version mobile (en test)
- Évaluations de type "deuxième session"
- Gestion du genre neutre (pas d'affichage de la civilité)
diff --git a/app/scodoc/notes_table.py b/app/scodoc/notes_table.py
index 1abdb72e..f8b7d438 100644
--- a/app/scodoc/notes_table.py
+++ b/app/scodoc/notes_table.py
@@ -100,10 +100,10 @@ def get_sem_ues_modimpls(context, formsemestre_id, modimpls=None):
)
uedict = {}
for modimpl in modimpls:
- mod = context.do_module_list(args={"module_id": modimpl["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": modimpl["module_id"]})[0]
modimpl["module"] = mod
if not mod["ue_id"] in uedict:
- ue = context.do_ue_list(args={"ue_id": mod["ue_id"]})[0]
+ ue = sco_edit_ue.do_ue_list(context, args={"ue_id": mod["ue_id"]})[0]
uedict[ue["ue_id"]] = ue
ues = uedict.values()
ues.sort(key=lambda u: u["numero"])
@@ -218,18 +218,18 @@ class NotesTable:
for modimpl in self._modimpls:
mod = modimpl["module"] # has been added here by do_formsemestre_moyennes
if not mod["ue_id"] in uedict:
- ue = context.do_ue_list(args={"ue_id": mod["ue_id"]})[0]
+ ue = sco_edit_ue.do_ue_list(context, args={"ue_id": mod["ue_id"]})[0]
uedict[ue["ue_id"]] = ue
else:
ue = uedict[mod["ue_id"]]
modimpl["ue"] = ue # add ue dict to moduleimpl
self._matmoys[mod["matiere_id"]] = {}
- mat = context.do_matiere_list(args={"matiere_id": mod["matiere_id"]})[0]
+ mat = sco_edit_matiere.do_matiere_list(context, args={"matiere_id": mod["matiere_id"]})[0]
modimpl["mat"] = mat # add matiere dict to moduleimpl
# calcul moyennes du module et stocke dans le module
# nb_inscrits, nb_notes, nb_abs, nb_neutre, moy, median, last_modif=
- self.formation = context.formation_list(
+ self.formation = sco_formations.formation_list(context,
args={"formation_id": self.sem["formation_id"]}
)[0]
self.parcours = sco_codes_parcours.get_parcours_from_code(
@@ -1074,7 +1074,7 @@ class NotesTable:
"Warning: %s capitalized an UE %s which is not part of current sem %s"
% (etudid, ue_id, self.formsemestre_id)
)
- ue = self.context.do_ue_list(args={"ue_id": ue_id})[0]
+ ue = self.sco_edit_ue.do_ue_list(context, args={"ue_id": ue_id})[0]
self.uedict[ue_id] = ue # record this UE
if ue_id not in self._uecoef:
cl = formsemestre_uecoef_list(
diff --git a/app/scodoc/pe_jurype.py b/app/scodoc/pe_jurype.py
index c9f86ad3..08a2b28f 100644
--- a/app/scodoc/pe_jurype.py
+++ b/app/scodoc/pe_jurype.py
@@ -66,7 +66,7 @@ def comp_nom_semestre_dans_parcours(context, sem):
"""Le nom a afficher pour titrer un semestre
par exemple: "semestre 2 FI 2015"
"""
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
return "%s %s %s %s" % (
parcours.SESSION_NAME, # eg "semestre"
diff --git a/app/scodoc/sco_bulletins.py b/app/scodoc/sco_bulletins.py
index c594d891..6b2a116a 100644
--- a/app/scodoc/sco_bulletins.py
+++ b/app/scodoc/sco_bulletins.py
@@ -131,7 +131,7 @@ def formsemestre_bulletinetud_dict(
I["server_name"] = ""
# Formation et parcours
- I["formation"] = context.formation_list(
+ I["formation"] = sco_formations.formation_list(context,
args={"formation_id": I["sem"]["formation_id"]}
)[0]
I["parcours"] = sco_codes_parcours.get_parcours_from_code(
diff --git a/app/scodoc/sco_bulletins_json.py b/app/scodoc/sco_bulletins_json.py
index 2aac216d..3098303a 100644
--- a/app/scodoc/sco_bulletins_json.py
+++ b/app/scodoc/sco_bulletins_json.py
@@ -380,7 +380,7 @@ def formsemestre_bulletinetud_published_dict(
"decisions_ue"
]: # and sco_preferences.get_preference(context, 'bul_show_uevalid', formsemestre_id): always publish (car utile pour export Apogee)
for ue_id in decision["decisions_ue"].keys():
- ue = context.do_ue_list({"ue_id": ue_id})[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": ue_id})[0]
d["decision_ue"].append(
dict(
ue_id=ue["ue_id"],
diff --git a/app/scodoc/sco_bulletins_xml.py b/app/scodoc/sco_bulletins_xml.py
index 842377c2..849e9cfe 100644
--- a/app/scodoc/sco_bulletins_xml.py
+++ b/app/scodoc/sco_bulletins_xml.py
@@ -392,7 +392,7 @@ def make_xml_formsemestre_bulletinetud(
"decisions_ue"
]: # and sco_preferences.get_preference(context, 'bul_show_uevalid', formsemestre_id): always publish (car utile pour export Apogee)
for ue_id in decision["decisions_ue"].keys():
- ue = context.do_ue_list({"ue_id": ue_id})[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": ue_id})[0]
doc._push()
doc.decision_ue(
ue_id=ue["ue_id"],
diff --git a/app/scodoc/sco_compute_moy.py b/app/scodoc/sco_compute_moy.py
index 9c671479..2b6f72c1 100644
--- a/app/scodoc/sco_compute_moy.py
+++ b/app/scodoc/sco_compute_moy.py
@@ -390,7 +390,7 @@ def do_formsemestre_moyennes(context, nt, formsemestre_id):
mods_att = []
expr_diags = []
for modimpl in modimpls:
- mod = context.do_module_list(args={"module_id": modimpl["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": modimpl["module_id"]})[0]
modimpl["module"] = mod # add module dict to moduleimpl (used by nt)
moduleimpl_id = modimpl["moduleimpl_id"]
assert not D.has_key(moduleimpl_id)
diff --git a/app/scodoc/sco_edit_formation.py b/app/scodoc/sco_edit_formation.py
index b21fa9bb..28e6f849 100644
--- a/app/scodoc/sco_edit_formation.py
+++ b/app/scodoc/sco_edit_formation.py
@@ -40,7 +40,7 @@ import sco_formations
def formation_delete(context, formation_id=None, dialog_confirmed=False, REQUEST=None):
"""Delete a formation"""
- F = context.formation_list(args={"formation_id": formation_id})
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not F:
raise ScoValueError("formation inexistante !")
F = F[0]
@@ -81,7 +81,7 @@ def formation_delete(context, formation_id=None, dialog_confirmed=False, REQUEST
parameters={"formation_id": formation_id},
)
else:
- context.do_formation_delete(F["formation_id"], REQUEST)
+ do_formation_delete(context, F["formation_id"], REQUEST)
H.append(
"""OK, formation supprimée.
continuer
"""
@@ -92,6 +92,31 @@ def formation_delete(context, formation_id=None, dialog_confirmed=False, REQUEST
return "\n".join(H)
+def do_formation_delete(context, oid, REQUEST):
+ """delete a formation (and all its UE, matieres, modules)
+ XXX delete all ues, will break if there are validations ! USE WITH CARE !
+ """
+ F = sco_formations.formation_list(context, args={"formation_id": oid})[0]
+ if sco_formations.formation_has_locked_sems(context, oid):
+ raise ScoLockedFormError()
+ cnx = ndb.GetDBConnexion()
+ # delete all UE in this formation
+ ues = sco_edit_ue.do_ue_list(context, {"formation_id": oid})
+ for ue in ues:
+ do_ue_delete(ue["ue_id"], REQUEST=REQUEST, force=True)
+
+ sco_formations._formationEditor.delete(cnx, oid)
+
+ # news
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=oid,
+ text="Suppression de la formation %(acronyme)s" % F,
+ )
+
+
def formation_create(context, REQUEST=None):
"""Creation d'une formation"""
return formation_edit(context, create=True, REQUEST=REQUEST)
@@ -118,11 +143,11 @@ def formation_edit(context, formation_id=None, create=False, REQUEST=None):
is_locked = False
else:
# edit an existing formation
- F = context.formation_list(args={"formation_id": formation_id})
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not F:
raise ScoValueError("formation inexistante !")
initvalues = F[0]
- is_locked = context.formation_has_locked_sems(formation_id)
+ is_locked = sco_formations.formation_has_locked_sems(context, formation_id)
submitlabel = "Modifier les valeurs"
H = [
html_sco_header.sco_header(
@@ -212,7 +237,7 @@ def formation_edit(context, formation_id=None, create=False, REQUEST=None):
"version": version,
}
ndb.quote_dict(args)
- others = context.formation_list(args=args)
+ others = sco_formations.formation_list(context, args=args)
if others and ((len(others) > 1) or others[0]["formation_id"] != formation_id):
return (
"\n".join(H)
@@ -237,7 +262,7 @@ def do_formation_create(context, args, REQUEST):
a = args.copy()
if a.has_key("formation_id"):
del a["formation_id"]
- F = context.formation_list(args=a)
+ F = sco_formations.formation_list(context, args=a)
if len(F) > 0:
log("do_formation_create: error: %d formations matching args=%s" % (len(F), a))
raise ScoValueError("Formation non unique (%s) !" % str(a))
@@ -263,7 +288,7 @@ def do_formation_edit(context, args):
# On autorise la modif de la formation meme si elle est verrouillee
# car cela ne change que du cosmetique, (sauf eventuellement le code formation ?)
# mais si verrouillée on ne peut changer le type de parcours
- if context.formation_has_locked_sems(args["formation_id"]):
+ if sco_formations.formation_has_locked_sems(context, args["formation_id"]):
if args.has_key("type_parcours"):
del args["type_parcours"]
# On ne peut jamais supprimer le code formation:
diff --git a/app/scodoc/sco_edit_matiere.py b/app/scodoc/sco_edit_matiere.py
index d6567bc4..39e53e9a 100644
--- a/app/scodoc/sco_edit_matiere.py
+++ b/app/scodoc/sco_edit_matiere.py
@@ -32,13 +32,65 @@ import notesdb as ndb
import sco_utils as scu
from notes_log import log
from TrivialFormulator import TrivialFormulator, TF, tf_error_message
+import sco_edit_ue
import sco_formsemestre
+import sco_news
from sco_exceptions import ScoValueError
+_matiereEditor = ndb.EditableTable(
+ "notes_matieres",
+ "matiere_id",
+ ("matiere_id", "ue_id", "numero", "titre"),
+ sortkey="numero",
+ output_formators={"numero": ndb.int_null_is_zero},
+)
+
+
+def do_matiere_list(context, *args, **kw):
+ "list matieres"
+ cnx = ndb.GetDBConnexion()
+ return _matiereEditor.list(cnx, *args, **kw)
+
+
+def do_matiere_edit(context, *args, **kw):
+ "edit a matiere"
+ cnx = ndb.GetDBConnexion()
+ # check
+ mat = sco_edit_matiere.do_matiere_list(
+ context, {"matiere_id": args[0]["matiere_id"]}
+ )[0]
+ if sco_edit_matiere.matiere_is_locked(context, mat["matiere_id"]):
+ raise ScoLockedFormError()
+ # edit
+ _matiereEditor.edit(cnx, *args, **kw)
+ sco_core.inval_cache(context) # > modif matiere
+
+
+def do_matiere_create(context, args, REQUEST):
+ "create a matiere"
+ cnx = ndb.GetDBConnexion()
+ # check
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": args["ue_id"]})[0]
+ # create matiere
+ r = _matiereEditor.create(cnx, args)
+
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=ue["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+ return r
+
def matiere_create(context, ue_id=None, REQUEST=None):
"""Creation d'une matiere"""
- UE = context.do_ue_list(args={"ue_id": ue_id})[0]
+ UE = sco_edit_ue.do_ue_list(context, args={"ue_id": ue_id})[0]
H = [
html_sco_header.sco_header(
context, REQUEST, page_title="Création d'une matière"
@@ -85,7 +137,7 @@ associé.
return REQUEST.RESPONSE.redirect(dest_url)
else:
# check unicity
- mats = context.do_matiere_list(args={"ue_id": ue_id, "titre": tf[2]["titre"]})
+ mats = do_matiere_list(context, args={"ue_id": ue_id, "titre": tf[2]["titre"]})
if mats:
return (
"\n".join(H)
@@ -93,14 +145,46 @@ associé.
+ tf[1]
+ html_sco_header.sco_footer(context, REQUEST)
)
- _ = context.do_matiere_create(tf[2], REQUEST)
+ _ = do_matiere_create(context, tf[2], REQUEST)
return REQUEST.RESPONSE.redirect(dest_url)
+def do_matiere_delete(context, oid, REQUEST):
+ "delete matiere and attached modules"
+ cnx = ndb.GetDBConnexion()
+ # check
+ mat = do_matiere_list(context, {"matiere_id": oid})[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": mat["ue_id"]})[0]
+ locked = sco_edit_matiere.matiere_is_locked(context, mat["matiere_id"])
+ if locked:
+ log("do_matiere_delete: mat=%s" % mat)
+ log("do_matiere_delete: ue=%s" % ue)
+ log("do_matiere_delete: locked sems: %s" % locked)
+ raise ScoLockedFormError()
+ log("do_matiere_delete: matiere_id=%s" % oid)
+ # delete all modules in this matiere
+ mods = sco_edit_module.do_module_list(context, {"matiere_id": oid})
+ for mod in mods:
+ sco_edit_module.do_module_delete(context, mod["module_id"], REQUEST)
+ _matiereEditor.delete(cnx, oid)
+
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=ue["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+
+
def matiere_delete(context, matiere_id=None, REQUEST=None):
"""Delete an UE"""
- M = context.do_matiere_list(args={"matiere_id": matiere_id})[0]
- UE = context.do_ue_list(args={"ue_id": M["ue_id"]})[0]
+ M = do_matiere_list(context, args={"matiere_id": matiere_id})[0]
+ UE = sco_edit_ue.do_ue_list(context, args={"ue_id": M["ue_id"]})[0]
H = [
html_sco_header.sco_header(
context, REQUEST, page_title="Suppression d'une matière"
@@ -122,23 +206,25 @@ def matiere_delete(context, matiere_id=None, REQUEST=None):
elif tf[0] == -1:
return REQUEST.RESPONSE.redirect(dest_url)
else:
- context.do_matiere_delete(matiere_id, REQUEST)
+ do_matiere_delete(context, matiere_id, REQUEST)
return REQUEST.RESPONSE.redirect(dest_url)
def matiere_edit(context, matiere_id=None, REQUEST=None):
"""Edit matiere"""
- F = context.do_matiere_list(args={"matiere_id": matiere_id})
+ F = do_matiere_list(context, args={"matiere_id": matiere_id})
if not F:
raise ScoValueError("Matière inexistante !")
F = F[0]
- U = context.do_ue_list(args={"ue_id": F["ue_id"]})
+ U = sco_edit_ue.do_ue_list(context, args={"ue_id": F["ue_id"]})
if not F:
raise ScoValueError("UE inexistante !")
U = U[0]
- Fo = context.formation_list(args={"formation_id": U["formation_id"]})[0]
+ Fo = sco_formations.formation_list(
+ context, args={"formation_id": U["formation_id"]}
+ )[0]
- ues = context.do_ue_list(args={"formation_id": U["formation_id"]})
+ ues = sco_edit_ue.do_ue_list(context, args={"formation_id": U["formation_id"]})
ue_names = ["%(acronyme)s (%(titre)s)" % u for u in ues]
ue_ids = [u["ue_id"] for u in ues]
H = [
@@ -195,8 +281,8 @@ associé.
return REQUEST.RESPONSE.redirect(dest_url)
else:
# check unicity
- mats = context.do_matiere_list(
- args={"ue_id": tf[2]["ue_id"], "titre": tf[2]["titre"]}
+ mats = do_matiere_list(
+ context, args={"ue_id": tf[2]["ue_id"], "titre": tf[2]["titre"]}
)
if len(mats) > 1 or (len(mats) == 1 and mats[0]["matiere_id"] != matiere_id):
return (
@@ -215,7 +301,7 @@ associé.
{"ue_id": tf[2]["ue_id"], "matiere_id": matiere_id},
)
- context.do_matiere_edit(tf[2])
+ do_matiere_edit(context, tf[2])
return REQUEST.RESPONSE.redirect(dest_url)
diff --git a/app/scodoc/sco_edit_module.py b/app/scodoc/sco_edit_module.py
index 56f49fe8..b3f74afa 100644
--- a/app/scodoc/sco_edit_module.py
+++ b/app/scodoc/sco_edit_module.py
@@ -25,7 +25,7 @@
#
##############################################################################
-"""Ajout/Modification/Supression UE
+"""Ajout/Modification/Supression modules
(portage from DTML)
"""
import notesdb as ndb
@@ -55,14 +55,75 @@ Tous ces enseignants, plus le responsable du semestre, pourront
saisir et modifier les notes de ce module.
"""
+_moduleEditor = ndb.EditableTable(
+ "notes_modules",
+ "module_id",
+ (
+ "module_id",
+ "titre",
+ "code",
+ "abbrev",
+ "heures_cours",
+ "heures_td",
+ "heures_tp",
+ "coefficient",
+ "ue_id",
+ "matiere_id",
+ "formation_id",
+ "semestre_id",
+ "numero",
+ "code_apogee",
+ "module_type"
+ #'ects'
+ ),
+ sortkey="numero, code, titre",
+ output_formators={
+ "heures_cours": ndb.float_null_is_zero,
+ "heures_td": ndb.float_null_is_zero,
+ "heures_tp": ndb.float_null_is_zero,
+ "numero": ndb.int_null_is_zero,
+ "coefficient": ndb.float_null_is_zero,
+ "module_type": ndb.int_null_is_zero
+ #'ects' : ndb.float_null_is_null
+ },
+)
+
+
+def do_module_list(context, *args, **kw):
+ "list modules"
+ cnx = ndb.GetDBConnexion()
+ return _moduleEditor.list(cnx, *args, **kw)
+
+
+def do_module_create(context, args, REQUEST):
+ "create a module"
+ # create
+ cnx = ndb.GetDBConnexion()
+ r = _moduleEditor.create(cnx, args)
+
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": args["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=args["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+ return r
+
def module_create(context, matiere_id=None, REQUEST=None):
"""Creation d'un module"""
if not matiere_id:
raise ScoValueError("invalid matiere !")
- M = context.do_matiere_list(args={"matiere_id": matiere_id})[0]
- UE = context.do_ue_list(args={"ue_id": M["ue_id"]})[0]
- Fo = context.formation_list(args={"formation_id": UE["formation_id"]})[0]
+ M = sco_edit_matiere.do_matiere_list(context, args={"matiere_id": matiere_id})[0]
+ UE = sco_edit_ue.do_ue_list(context, args={"ue_id": M["ue_id"]})[0]
+ Fo = sco_formations.formation_list(
+ context, args={"formation_id": UE["formation_id"]}
+ )[0]
parcours = sco_codes_parcours.get_parcours_from_code(Fo["type_parcours"])
semestres_indices = range(1, parcours.NB_SEM + 1)
H = [
@@ -72,7 +133,7 @@ def module_create(context, matiere_id=None, REQUEST=None):
_MODULE_HELP,
]
# cherche le numero adequat (pour placer le module en fin de liste)
- Mods = context.do_module_list(args={"matiere_id": matiere_id})
+ Mods = do_module_list(context, args={"matiere_id": matiere_id})
if Mods:
default_num = max([m["numero"] for m in Mods]) + 10
else:
@@ -172,17 +233,52 @@ def module_create(context, matiere_id=None, REQUEST=None):
if tf[0] == 0:
return "\n".join(H) + tf[1] + html_sco_header.sco_footer(context, REQUEST)
else:
- context.do_module_create(tf[2], REQUEST)
+ do_module_create(context, tf[2], REQUEST)
return REQUEST.RESPONSE.redirect(
scu.NotesURL() + "/ue_list?formation_id=" + UE["formation_id"]
)
+def do_module_delete(context, oid, REQUEST):
+ "delete module"
+ mod = do_module_list(context, {"module_id": oid})[0]
+ if sco_edit_module.module_is_locked(context, mod["module_id"]):
+ raise ScoLockedFormError()
+
+ # S'il y a des moduleimpls, on ne peut pas detruire le module !
+ mods = sco_moduleimpl.do_moduleimpl_list(context, module_id=oid)
+ if mods:
+ err_page = scu.confirm_dialog(
+ context,
+ message="""Destruction du module impossible car il est utilisé dans des semestres existants !
""",
+ helpmsg="""Il faut d'abord supprimer le semestre. Mais il est peut être préférable de laisser ce programme intact et d'en créer une nouvelle version pour la modifier.""",
+ dest_url="ue_list",
+ parameters={"formation_id": mod["formation_id"]},
+ REQUEST=REQUEST,
+ )
+ raise ScoGenError(err_page)
+ # delete
+ cnx = ndb.GetDBConnexion()
+ _moduleEditor.delete(cnx, oid)
+
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": mod["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=mod["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+
+
def module_delete(context, module_id=None, REQUEST=None):
"""Delete a module"""
if not module_id:
raise ScoValueError("invalid module !")
- Mods = context.do_module_list(args={"module_id": module_id})
+ Mods = do_module_list(context, args={"module_id": module_id})
if not Mods:
raise ScoValueError("Module inexistant !")
Mod = Mods[0]
@@ -207,13 +303,36 @@ def module_delete(context, module_id=None, REQUEST=None):
elif tf[0] == -1:
return REQUEST.RESPONSE.redirect(dest_url)
else:
- context.do_module_delete(module_id, REQUEST)
+ do_module_delete(context, module_id, REQUEST)
return REQUEST.RESPONSE.redirect(dest_url)
+def do_module_edit(context, val):
+ "edit a module"
+ # check
+ mod = do_module_list(context, {"module_id": val["module_id"]})[0]
+ if module_is_locked(context, mod["module_id"]):
+ # formation verrouillée: empeche de modifier certains champs:
+ protected_fields = ("coefficient", "ue_id", "matiere_id", "semestre_id")
+ for f in protected_fields:
+ if f in val:
+ del val[f]
+ # edit
+ cnx = ndb.GetDBConnexion()
+ _moduleEditor.edit(cnx, val)
+
+ sems = sco_formsemestre.do_formsemestre_list(
+ context, args={"formation_id": mod["formation_id"]}
+ )
+ if sems:
+ sco_core.inval_cache(
+ context, formsemestre_id_list=[s["formsemestre_id"] for s in sems]
+ ) # > modif module
+
+
def check_module_code_unicity(code, field, formation_id, context, module_id=None):
"true si code module unique dans la formation"
- Mods = context.do_module_list(args={"code": code, "formation_id": formation_id})
+ Mods = do_module_list(context, args={"code": code, "formation_id": formation_id})
if module_id: # edition: supprime le module en cours
Mods = [m for m in Mods if m["module_id"] != module_id]
@@ -224,12 +343,14 @@ def module_edit(context, module_id=None, REQUEST=None):
"""Edit a module"""
if not module_id:
raise ScoValueError("invalid module !")
- Mod = context.do_module_list(args={"module_id": module_id})
+ Mod = do_module_list(context, args={"module_id": module_id})
if not Mod:
raise ScoValueError("invalid module !")
Mod = Mod[0]
unlocked = not module_is_locked(context, module_id)
- Fo = context.formation_list(args={"formation_id": Mod["formation_id"]})[0]
+ Fo = sco_formations.formation_list(
+ context, args={"formation_id": Mod["formation_id"]}
+ )[0]
parcours = sco_codes_parcours.get_parcours_from_code(Fo["type_parcours"])
M = ndb.SimpleDictFetch(
context,
@@ -386,7 +507,7 @@ def module_edit(context, module_id=None, REQUEST=None):
tf[2]["ue_id"], tf[2]["matiere_id"] = tf[2]["ue_matiere_id"].split("!")
# Check unicité code module dans la formation
- context.do_module_edit(tf[2])
+ do_module_edit(context, tf[2])
return REQUEST.RESPONSE.redirect(dest_url)
@@ -397,11 +518,11 @@ def edit_module_set_code_apogee(context, id=None, value=None, REQUEST=None):
value = value.strip("-_ \t")
log("edit_module_set_code_apogee: module_id=%s code_apogee=%s" % (module_id, value))
- modules = context.do_module_list(args={"module_id": module_id})
+ modules = do_module_list(context, args={"module_id": module_id})
if not modules:
return "module invalide" # shoud not occur
- context.do_module_edit({"module_id": module_id, "code_apogee": value})
+ do_module_edit(context, {"module_id": module_id, "code_apogee": value})
if not value:
value = scu.APO_MISSING_CODE_STR
return value
@@ -413,7 +534,7 @@ def module_list(context, formation_id, REQUEST=None):
"""
if not formation_id:
raise ScoValueError("invalid formation !")
- F = context.formation_list(args={"formation_id": formation_id})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})[0]
H = [
html_sco_header.sco_header(
context, REQUEST, page_title="Liste des modules de %(titre)s" % F
@@ -424,7 +545,7 @@ def module_list(context, formation_id, REQUEST=None):
]
editable = REQUEST.AUTHENTICATED_USER.has_permission(Permission.ScoChangeFormation)
- for Mod in context.do_module_list(args={"formation_id": formation_id}):
+ for Mod in do_module_list(context, args={"formation_id": formation_id}):
H.append('%s' % Mod)
if editable:
H.append('modifier' % Mod)
@@ -460,14 +581,14 @@ def module_count_moduleimpls(context, module_id):
def formation_add_malus_modules(context, formation_id, titre=None, REQUEST=None):
"""Création d'un module de "malus" dans chaque UE d'une formation"""
- ue_list = context.do_ue_list(args={"formation_id": formation_id})
+ ue_list = sco_edit_ue.do_ue_list(context, args={"formation_id": formation_id})
for ue in ue_list:
# Un seul module de malus par UE:
nb_mod_malus = len(
[
mod
- for mod in context.do_module_list(args={"ue_id": ue["ue_id"]})
+ for mod in do_module_list(context, args={"ue_id": ue["ue_id"]})
if mod["module_type"] == scu.MODULE_MALUS
]
)
@@ -480,7 +601,7 @@ def formation_add_malus_modules(context, formation_id, titre=None, REQUEST=None)
def ue_add_malus_module(context, ue_id, titre=None, code=None, REQUEST=None):
"""Add a malus module in this ue"""
- ue = context.do_ue_list(args={"ue_id": ue_id})[0]
+ ue = sco_edit_ue.do_ue_list(context, args={"ue_id": ue_id})[0]
if titre is None:
titre = ""
@@ -499,13 +620,14 @@ def ue_add_malus_module(context, ue_id, titre=None, code=None, REQUEST=None):
)
# Matiere pour placer le module malus
- Matlist = context.do_matiere_list(args={"ue_id": ue_id})
+ Matlist = sco_edit_matiere.do_matiere_list(context, args={"ue_id": ue_id})
numero = max([mat["numero"] for mat in Matlist]) + 10
- matiere_id = context.do_matiere_create(
- {"ue_id": ue_id, "titre": "Malus", "numero": numero}, REQUEST
+ matiere_id = sco_edit_matiere.do_matiere_create(
+ context, {"ue_id": ue_id, "titre": "Malus", "numero": numero}, REQUEST
)
- module_id = context.do_module_create(
+ module_id = do_module_create(
+ context,
{
"titre": titre,
"code": code,
diff --git a/app/scodoc/sco_edit_ue.py b/app/scodoc/sco_edit_ue.py
index a6adf4f7..c39763a2 100644
--- a/app/scodoc/sco_edit_ue.py
+++ b/app/scodoc/sco_edit_ue.py
@@ -25,7 +25,7 @@
#
##############################################################################
-"""Ajout/Modification/Supression UE
+"""Ajout/Modification/Suppression UE
"""
import notesdb as ndb
@@ -41,6 +41,135 @@ import sco_tag_module
from sco_permissions import ScoChangeFormation, ScoEditFormationTags, ScoImplement
from sco_exceptions import ScoValueError, ScoLockedFormError
+_ueEditor = ndb.EditableTable(
+ "notes_ue",
+ "ue_id",
+ (
+ "ue_id",
+ "formation_id",
+ "acronyme",
+ "numero",
+ "titre",
+ "type",
+ "ue_code",
+ "ects",
+ "is_external",
+ "code_apogee",
+ "coefficient",
+ ),
+ sortkey="numero",
+ input_formators={"type": ndb.int_null_is_zero},
+ output_formators={
+ "numero": ndb.int_null_is_zero,
+ "ects": ndb.float_null_is_null,
+ "coefficient": ndb.float_null_is_zero,
+ },
+)
+
+
+def do_ue_list(context, *args, **kw):
+ "list UEs"
+ cnx = ndb.GetDBConnexion()
+ return _ueEditor.list(cnx, *args, **kw)
+
+
+def do_ue_create(context, args, REQUEST):
+ "create an ue"
+ cnx = ndb.GetDBConnexion()
+ # check duplicates
+ ues = do_ue_list(context,
+ {"formation_id": args["formation_id"], "acronyme": args["acronyme"]}
+ )
+ if ues:
+ raise ScoValueError('Acronyme d\'UE "%s" déjà utilisé !' % args["acronyme"])
+ # create
+ r = context._ueEditor.create(cnx, args)
+
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": args["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=args["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+ return r
+
+
+def do_ue_delete(context, ue_id, delete_validations=False, REQUEST=None, force=False):
+ "delete UE and attached matieres (but not modules (it should ?))"
+ cnx = ndb.GetDBConnexion()
+ log("do_ue_delete: ue_id=%s, delete_validations=%s" % (ue_id, delete_validations))
+ # check
+ ue = do_ue_list(context, {"ue_id": ue_id})
+ if not ue:
+ raise ScoValueError("UE inexistante !")
+ ue = ue[0]
+ if sco_edit_ue.ue_is_locked(context, ue["ue_id"]):
+ raise ScoLockedFormError()
+ # Il y a-t-il des etudiants ayant validé cette UE ?
+ # si oui, propose de supprimer les validations
+ validations = sco_parcours_dut.scolar_formsemestre_validation_list(
+ cnx, args={"ue_id": ue_id}
+ )
+ if validations and not delete_validations and not force:
+ return scu.confirm_dialog(
+ context,
+ "%d étudiants ont validé l'UE %s (%s)
Si vous supprimez cette UE, ces validations vont être supprimées !
"
+ % (len(validations), ue["acronyme"], ue["titre"]),
+ dest_url="",
+ REQUEST=REQUEST,
+ target_variable="delete_validations",
+ cancel_url="ue_list?formation_id=%s" % ue["formation_id"],
+ parameters={"ue_id": ue_id, "dialog_confirmed": 1},
+ )
+ if delete_validations:
+ log("deleting all validations of UE %s" % ue_id)
+ ndb.SimpleQuery(
+ context,
+ "DELETE FROM scolar_formsemestre_validation WHERE ue_id=%(ue_id)s",
+ {"ue_id": ue_id},
+ )
+
+ # delete all matiere in this UE
+ mats = sco_edit_matiere.do_matiere_list(context, {"ue_id": ue_id})
+ for mat in mats:
+ sco_edit_matiere.do_matiere_delete(context, mat["matiere_id"], REQUEST)
+ # delete uecoef and events
+ ndb.SimpleQuery(
+ context,
+ "DELETE FROM notes_formsemestre_uecoef WHERE ue_id=%(ue_id)s",
+ {"ue_id": ue_id},
+ )
+ ndb.SimpleQuery(
+ context, "DELETE FROM scolar_events WHERE ue_id=%(ue_id)s", {"ue_id": ue_id}
+ )
+ cnx = ndb.GetDBConnexion()
+ context._ueEditor.delete(cnx, ue_id)
+ # > UE delete + supr. validations associées etudiants (cas compliqué, mais rarement utilisé: acceptable de tout invalider ?):
+ sco_core.inval_cache(context)
+ # news
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
+ sco_news.add(
+ context,
+ REQUEST,
+ typ=NEWS_FORM,
+ object=ue["formation_id"],
+ text="Modification de la formation %(acronyme)s" % F,
+ )
+ #
+ if not force:
+ return REQUEST.RESPONSE.redirect(
+ scu.NotesURL() + "/ue_list?formation_id=" + str(ue["formation_id"])
+ )
+ else:
+ return None
+
def ue_create(context, formation_id=None, REQUEST=None):
"""Creation d'une UE"""
@@ -51,7 +180,7 @@ def ue_edit(context, ue_id=None, create=False, formation_id=None, REQUEST=None):
"""Modification ou creation d'une UE"""
create = int(create)
if not create:
- U = context.do_ue_list(args={"ue_id": ue_id})
+ U = do_ue_list(context, args={"ue_id": ue_id})
if not U:
raise ScoValueError("UE inexistante !")
U = U[0]
@@ -63,7 +192,7 @@ def ue_edit(context, ue_id=None, create=False, formation_id=None, REQUEST=None):
title = "Création d'une UE"
initvalues = {}
submitlabel = "Créer cette UE"
- Fol = context.formation_list(args={"formation_id": formation_id})
+ Fol = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not Fol:
raise ScoValueError(
"Formation %s inexistante ! (si vous avez suivi un lien valide, merci de signaler le problème)"
@@ -201,14 +330,14 @@ def ue_edit(context, ue_id=None, create=False, formation_id=None, REQUEST=None):
context, formation_id, int(tf[2]["semestre_id"] or 0)
)
- ue_id = context.do_ue_create(tf[2], REQUEST)
+ ue_id = do_ue_create(context, tf[2], REQUEST)
if parcours.UE_IS_MODULE or tf[2]["create_matiere"]:
- matiere_id = context.do_matiere_create(
+ matiere_id = sco_edit_matiere.do_matiere_create(context,
{"ue_id": ue_id, "titre": tf[2]["titre"], "numero": 1}, REQUEST
)
if parcours.UE_IS_MODULE:
# dans ce mode, crée un (unique) module dans l'UE:
- _ = context.do_module_create(
+ _ = sco_edit_module.do_module_create(context,
{
"titre": tf[2]["titre"],
"code": tf[2]["acronyme"],
@@ -233,7 +362,7 @@ def _add_ue_semestre_id(context, ue_list):
qui les place à la fin de la liste.
"""
for ue in ue_list:
- Modlist = context.do_module_list(args={"ue_id": ue["ue_id"]})
+ Modlist = sco_edit_module.do_module_list(context, args={"ue_id": ue["ue_id"]})
if Modlist:
ue["semestre_id"] = Modlist[0]["semestre_id"]
else:
@@ -244,7 +373,7 @@ def next_ue_numero(context, formation_id, semestre_id=None):
"""Numero d'une nouvelle UE dans cette formation.
Si le semestre est specifie, cherche les UE ayant des modules de ce semestre
"""
- ue_list = context.do_ue_list(args={"formation_id": formation_id})
+ ue_list = do_ue_list(context, args={"formation_id": formation_id})
if not ue_list:
return 0
if semestre_id is None:
@@ -263,7 +392,7 @@ def ue_delete(
context, ue_id=None, delete_validations=False, dialog_confirmed=False, REQUEST=None
):
"""Delete an UE"""
- ue = context.do_ue_list(args={"ue_id": ue_id})
+ ue = do_ue_list(context, args={"ue_id": ue_id})
if not ue:
raise ScoValueError("UE inexistante !")
ue = ue[0]
@@ -278,8 +407,8 @@ def ue_delete(
cancel_url="ue_list?formation_id=%s" % ue["formation_id"],
)
- return context._do_ue_delete(
- ue_id, delete_validations=delete_validations, REQUEST=REQUEST
+ return do_ue_delete(
+ context, ue_id, delete_validations=delete_validations, REQUEST=REQUEST
)
@@ -289,14 +418,14 @@ def ue_list(context, formation_id=None, msg="", REQUEST=None):
"""
authuser = REQUEST.AUTHENTICATED_USER
- F = context.formation_list(args={"formation_id": formation_id})
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not F:
raise ScoValueError("invalid formation_id")
F = F[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
- locked = context.formation_has_locked_sems(formation_id)
+ locked = sco_formations.formation_has_locked_sems(context, formation_id)
- ue_list = context.do_ue_list(args={"formation_id": formation_id})
+ ue_list = do_ue_list(context, args={"formation_id": formation_id})
# tri par semestre et numero:
_add_ue_semestre_id(context, ue_list)
ue_list.sort(key=lambda u: (u["semestre_id"], u["numero"]))
@@ -478,7 +607,7 @@ Si vous souhaitez modifier cette formation (par exemple pour y ajouter un module
H.append('[verrouillé]')
if not parcours.UE_IS_MODULE:
H.append('')
- Matlist = context.do_matiere_list(args={"ue_id": UE["ue_id"]})
+ Matlist = sco_edit_matiere.do_matiere_list(context, args={"ue_id": UE["ue_id"]})
for Mat in Matlist:
if not parcours.UE_IS_MODULE:
H.append('- ')
@@ -496,7 +625,7 @@ Si vous souhaitez modifier cette formation (par exemple pour y ajouter un module
H.append("")
H.append('
')
- Modlist = context.do_module_list(args={"matiere_id": Mat["matiere_id"]})
+ Modlist = sco_edit_module.do_module_list(context, args={"matiere_id": Mat["matiere_id"]})
im = 0
for Mod in Modlist:
Mod["nb_moduleimpls"] = sco_edit_module.module_count_moduleimpls(
@@ -683,19 +812,23 @@ def ue_sharing_code(context, ue_code=None, ue_id=None, hide_ue_id=None):
Either ue_code or ue_id may be specified.
"""
if ue_id:
- ue = context.do_ue_list(args={"ue_id": ue_id})[0]
+ ue = do_ue_list(context, args={"ue_id": ue_id})[0]
if not ue_code:
ue_code = ue["ue_code"]
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
formation_code = F["formation_code"]
- ue_list_all = context.do_ue_list(args={"ue_code": ue_code})
+ ue_list_all = do_ue_list(context, args={"ue_code": ue_code})
if ue_id:
# retire les UE d'autres formations:
# log('checking ucode %s formation %s' % (ue_code, formation_code))
ue_list = []
for ue in ue_list_all:
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
if formation_code == F["formation_code"]:
ue_list.append(ue)
else:
@@ -716,7 +849,9 @@ def ue_sharing_code(context, ue_code=None, ue_id=None, hide_ue_id=None):
H.append('UE avec le code %s:' % ue_code)
H.append("")
for ue in ue_list:
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
+ F = sco_formations.formation_list(
+ context, args={"formation_id": ue["formation_id"]}
+ )[0]
H.append(
'- %s (%s) dans %s (%s), version %s
'
% (
@@ -736,13 +871,13 @@ def do_ue_edit(context, args, bypass_lock=False, dont_invalidate_cache=False):
"edit an UE"
# check
ue_id = args["ue_id"]
- ue = context.do_ue_list({"ue_id": ue_id})[0]
+ ue = do_ue_list(context, {"ue_id": ue_id})[0]
if (not bypass_lock) and ue_is_locked(context, ue["ue_id"]):
raise ScoLockedFormError()
# check: acronyme unique dans cette formation
if args.has_key("acronyme"):
new_acro = args["acronyme"]
- ues = context.do_ue_list(
+ ues = do_ue_list(context,
{"formation_id": ue["formation_id"], "acronyme": new_acro}
)
if ues and ues[0]["ue_id"] != ue_id:
@@ -772,7 +907,7 @@ def edit_ue_set_code_apogee(context, id=None, value=None, REQUEST=None):
value = value.strip("-_ \t")
log("edit_ue_set_code_apogee: ue_id=%s code_apogee=%s" % (ue_id, value))
- ues = context.do_ue_list(args={"ue_id": ue_id})
+ ues = do_ue_list(context, args={"ue_id": ue_id})
if not ues:
return "ue invalide"
@@ -806,16 +941,16 @@ def ue_is_locked(context, ue_id):
# ---- Table recap formation
def formation_table_recap(context, formation_id, format="html", REQUEST=None):
"""Table recapitulant formation."""
- F = context.formation_list(args={"formation_id": formation_id})
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not F:
raise ScoValueError("invalid formation_id")
F = F[0]
T = []
- ue_list = context.do_ue_list(args={"formation_id": formation_id})
+ ue_list = do_ue_list(context, args={"formation_id": formation_id})
for UE in ue_list:
- Matlist = context.do_matiere_list(args={"ue_id": UE["ue_id"]})
+ Matlist = sco_edit_matiere.do_matiere_list(context, args={"ue_id": UE["ue_id"]})
for Mat in Matlist:
- Modlist = context.do_module_list(args={"matiere_id": Mat["matiere_id"]})
+ Modlist = sco_edit_module.do_module_list(context, args={"matiere_id": Mat["matiere_id"]})
for Mod in Modlist:
Mod["nb_moduleimpls"] = sco_edit_module.module_count_moduleimpls(
context, Mod["module_id"]
@@ -894,5 +1029,5 @@ def ue_list_semestre_ids(context, ue):
Mais cela n'a pas toujours été le cas dans les programmes pédagogiques officiels,
aussi ScoDoc laisse le choix.
"""
- Modlist = context.do_module_list(args={"ue_id": ue["ue_id"]})
+ Modlist = sco_edit_module.do_module_list(context, args={"ue_id": ue["ue_id"]})
return sorted(list(set([mod["semestre_id"] for mod in Modlist])))
diff --git a/app/scodoc/sco_etape_apogee_view.py b/app/scodoc/sco_etape_apogee_view.py
index 128e1bcd..25823ab9 100644
--- a/app/scodoc/sco_etape_apogee_view.py
+++ b/app/scodoc/sco_etape_apogee_view.py
@@ -342,7 +342,7 @@ def apo_semset_maq_status(
if missing:
formation_ids = {sem["formation_id"] for sem in semset.sems}
- formations = [context.formation_list(formation_id=i)[0] for i in formation_ids]
+ formations = [sco_formations.formation_list(context, formation_id=i)[0] for i in formation_ids]
# log('formations=%s' % formations)
H.append(
'Elements Apogée absents dans ScoDoc: %s'
diff --git a/app/scodoc/sco_evaluations.py b/app/scodoc/sco_evaluations.py
index eb06adda..1a05dd08 100644
--- a/app/scodoc/sco_evaluations.py
+++ b/app/scodoc/sco_evaluations.py
@@ -107,7 +107,7 @@ def do_evaluation_delete(context, REQUEST, evaluation_id):
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
sco_core.inval_cache(context, formsemestre_id=M["formsemestre_id"]) # > eval delete
# news
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
mod["moduleimpl_id"] = M["moduleimpl_id"]
mod["url"] = (
scu.NotesURL() + "/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % mod
@@ -166,7 +166,7 @@ def do_evaluation_etat(
# ---- Liste des groupes complets et incomplets
E = context.do_evaluation_list(args={"evaluation_id": evaluation_id})[0]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
is_malus = Mod["module_type"] == scu.MODULE_MALUS # True si module de malus
formsemestre_id = M["formsemestre_id"]
# Si partition_id is None, prend 'all' ou bien la premiere:
@@ -576,7 +576,7 @@ def formsemestre_evaluations_delai_correction(
M = sco_moduleimpl.do_moduleimpl_list(
context, moduleimpl_id=e["moduleimpl_id"]
)[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
if (e["evaluation_type"] != scu.EVALUATION_NORMALE) or (
Mod["module_type"] == scu.MODULE_MALUS
):
@@ -742,7 +742,7 @@ def evaluation_describe(context, evaluation_id="", edit_in_place=True, REQUEST=N
E = context.do_evaluation_list({"evaluation_id": evaluation_id})[0]
moduleimpl_id = E["moduleimpl_id"]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
formsemestre_id = M["formsemestre_id"]
u = context.Users.user_info(M["responsable_id"])
resp = u["prenomnom"]
@@ -771,7 +771,7 @@ def evaluation_describe(context, evaluation_id="", edit_in_place=True, REQUEST=N
]
if Mod["module_type"] == scu.MODULE_MALUS:
# Indique l'UE
- ue = context.do_ue_list(args={"ue_id": Mod["ue_id"]})[0]
+ ue = sco_edit_ue.do_ue_list(context, args={"ue_id": Mod["ue_id"]})[0]
H.append("
UE : %(acronyme)s
" % ue)
# store min/max values used by JS client-side checks:
H.append(
@@ -880,7 +880,7 @@ def evaluation_create_form(
else:
min_note_max_str = "0"
#
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
#
help = """
Le coefficient d'une évaluation n'est utilisé que pour pondérer les évaluations au sein d'un module.
diff --git a/app/scodoc/sco_export_results.py b/app/scodoc/sco_export_results.py
index ad8eb160..25f02ef4 100644
--- a/app/scodoc/sco_export_results.py
+++ b/app/scodoc/sco_export_results.py
@@ -62,7 +62,7 @@ def _build_results_table(context, start_date=None, end_date=None, types_parcours
semlist = [dpv["formsemestre"] for dpv in dpv_by_sem.values() if dpv]
semlist_parcours = []
for sem in semlist:
- sem["formation"] = context.formation_list(
+ sem["formation"] = sco_formations.formation_list(context,
args={"formation_id": sem["formation_id"]}
)[0]
sem["parcours"] = sco_codes_parcours.get_parcours_from_code(
diff --git a/app/scodoc/sco_formations.py b/app/scodoc/sco_formations.py
index c936ee0f..385e787e 100644
--- a/app/scodoc/sco_formations.py
+++ b/app/scodoc/sco_formations.py
@@ -61,14 +61,37 @@ _formationEditor = ndb.EditableTable(
)
+def formation_list(context, formation_id=None, args={}):
+ """List formation(s) with given id, or matching args
+ (when args is given, formation_id is ignored).
+ """
+ if not args:
+ if formation_id is None:
+ args = {}
+ else:
+ args = {"formation_id": formation_id}
+ cnx = ndb.GetDBConnexion()
+ r = _formationEditor.list(cnx, args=args)
+ # log('%d formations found' % len(r))
+ return r
+
+
+def formation_has_locked_sems(context, formation_id):
+ "True if there is a locked formsemestre in this formation"
+ sems = sco_formsemestre.do_formsemestre_list(
+ context, args={"formation_id": formation_id, "etat": "0"}
+ )
+ return sems
+
+
def formation_export(
context, formation_id, export_ids=False, export_tags=True, format=None, REQUEST=None
):
"""Get a formation, with UE, matieres, modules
in desired format
"""
- F = context.formation_list(args={"formation_id": formation_id})[0]
- ues = context.do_ue_list({"formation_id": formation_id})
+ F = formation_list(context, args={"formation_id": formation_id})[0]
+ ues = sco_edit_ue.do_ue_list(context, {"formation_id": formation_id})
F["ue"] = ues
for ue in ues:
ue_id = ue["ue_id"]
@@ -77,14 +100,14 @@ def formation_export(
del ue["formation_id"]
if ue["ects"] is None:
del ue["ects"]
- mats = context.do_matiere_list({"ue_id": ue_id})
+ mats = sco_edit_matiere.do_matiere_list(context, {"ue_id": ue_id})
ue["matiere"] = mats
for mat in mats:
matiere_id = mat["matiere_id"]
if not export_ids:
del mat["matiere_id"]
del mat["ue_id"]
- mods = context.do_module_list({"matiere_id": matiere_id})
+ mods = sco_edit_module.do_module_list(context, {"matiere_id": matiere_id})
mat["module"] = mods
for mod in mods:
if export_tags:
@@ -188,14 +211,14 @@ def formation_import_xml(
del ue_info[1]["ue_id"]
else:
xml_ue_id = None
- ue_id = context.do_ue_create(ue_info[1], REQUEST)
+ ue_id = sco_edit_ue.do_ue_create(context, ue_info[1], REQUEST)
if xml_ue_id:
ues_old2new[xml_ue_id] = ue_id
# -- create matieres
for mat_info in ue_info[2]:
assert mat_info[0] == "matiere"
mat_info[1]["ue_id"] = ue_id
- mat_id = context.do_matiere_create(mat_info[1], REQUEST)
+ mat_id = sco_edit_matiere.do_matiere_create(context, mat_info[1], REQUEST)
# -- create modules
for mod_info in mat_info[2]:
assert mod_info[0] == "module"
@@ -207,7 +230,7 @@ def formation_import_xml(
mod_info[1]["formation_id"] = formation_id
mod_info[1]["matiere_id"] = mat_id
mod_info[1]["ue_id"] = ue_id
- mod_id = context.do_module_create(mod_info[1], REQUEST)
+ mod_id = sco_edit_module.do_module_create(context, mod_info[1], REQUEST)
if xml_module_id:
modules_old2new[xml_module_id] = mod_id
if import_tags:
@@ -223,7 +246,7 @@ def formation_list_table(context, formation_id=None, args={}, REQUEST=None):
and listing associated semestres
returns a table
"""
- formations = context.formation_list(formation_id=formation_id, args=args)
+ formations = formation_list(context, formation_id=formation_id, args=args)
title = "Programmes pédagogiques"
lockicon = scu.icontag(
"lock32_img", title="Comporte des semestres verrouillés", border="0"
@@ -269,7 +292,7 @@ def formation_list_table(context, formation_id=None, args={}, REQUEST=None):
else:
f["date_fin_dernier_sem"] = ""
f["annee_dernier_sem"] = ""
- locked = context.formation_has_locked_sems(f["formation_id"])
+ locked = formation_has_locked_sems(context, f["formation_id"])
#
if locked:
but_locked = lockicon
diff --git a/app/scodoc/sco_formsemestre_edit.py b/app/scodoc/sco_formsemestre_edit.py
index 5ac35707..4ea1be46 100644
--- a/app/scodoc/sco_formsemestre_edit.py
+++ b/app/scodoc/sco_formsemestre_edit.py
@@ -140,7 +140,7 @@ def do_formsemestre_createwithmodules(context, REQUEST=None, edit=False):
allowed_user_names = login2display.values() + [""]
#
formation_id = REQUEST.form["formation_id"]
- F = context.formation_list(args={"formation_id": formation_id})
+ F = sco_formations.formation_list(context, args={"formation_id": formation_id})
if not F:
raise ScoValueError("Formation inexistante !")
F = F[0]
@@ -193,11 +193,11 @@ def do_formsemestre_createwithmodules(context, REQUEST=None, edit=False):
# on pourrait faire un simple module_list( )
# mais si on veut l'ordre du PPN (groupe par UE et matieres) il faut:
mods = [] # liste de dicts
- uelist = context.do_ue_list({"formation_id": formation_id})
+ uelist = sco_edit_ue.do_ue_list(context, {"formation_id": formation_id})
for ue in uelist:
- matlist = context.do_matiere_list({"ue_id": ue["ue_id"]})
+ matlist = sco_edit_matiere.do_matiere_list(context, {"ue_id": ue["ue_id"]})
for mat in matlist:
- modsmat = context.do_module_list({"matiere_id": mat["matiere_id"]})
+ modsmat = sco_edit_module.do_module_list(context, {"matiere_id": mat["matiere_id"]})
# XXX debug checks
for m in modsmat:
if m["ue_id"] != ue["ue_id"]:
@@ -747,7 +747,7 @@ def do_formsemestre_createwithmodules(context, REQUEST=None, edit=False):
"responsable_id": tf[2][module_id],
}
moduleimpl_id = sco_moduleimpl.do_moduleimpl_create(context, modargs)
- mod = context.do_module_list({"module_id": module_id})[0]
+ mod = sco_edit_module.do_module_list(context, {"module_id": module_id})[0]
msg += ["création de %s (%s)" % (mod["code"], mod["titre"])]
# INSCRIPTIONS DES ETUDIANTS
log(
@@ -798,7 +798,7 @@ def do_formsemestre_createwithmodules(context, REQUEST=None, edit=False):
sco_moduleimpl.do_moduleimpl_edit(
context, modargs, formsemestre_id=formsemestre_id
)
- mod = context.do_module_list({"module_id": module_id})[0]
+ mod = sco_edit_module.do_module_list(context, {"module_id": module_id})[0]
if msg:
msg_html = (
@@ -834,7 +834,7 @@ def formsemestre_delete_moduleimpls(context, formsemestre_id, module_ids_to_del)
moduleimpl_id = sco_moduleimpl.do_moduleimpl_list(
context, formsemestre_id=formsemestre_id, module_id=module_id
)[0]["moduleimpl_id"]
- mod = context.do_module_list({"module_id": module_id})[0]
+ mod = sco_edit_module.do_module_list(context, {"module_id": module_id})[0]
# Evaluations dans ce module ?
evals = context.do_evaluation_list({"moduleimpl_id": moduleimpl_id})
if evals:
@@ -1109,7 +1109,7 @@ def formsemestre_associate_new_version(
if not dialog_confirmed:
# dresse le liste des semestres de la meme formation et version
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
othersems = sco_formsemestre.do_formsemestre_list(
context,
args={
@@ -1227,7 +1227,7 @@ def _reassociate_moduleimpls(
def formsemestre_delete(context, formsemestre_id, REQUEST=None):
"""Delete a formsemestre (affiche avertissements)"""
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
H = [
html_sco_header.html_sem_header(
context, REQUEST, "Suppression du semestre", sem
@@ -1672,7 +1672,7 @@ def get_formsemestre_session_id(context, sem, F, parcours):
"""
# sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- # F = context.formation_list( args={ 'formation_id' : sem['formation_id'] } )[0]
+ # F = sco_formations.formation_list(context, args={ 'formation_id' : sem['formation_id'] } )[0]
# parcours = sco_codes_parcours.get_parcours_from_code(F['type_parcours'])
ImputationDept = sco_preferences.get_preference(
diff --git a/app/scodoc/sco_formsemestre_exterieurs.py b/app/scodoc/sco_formsemestre_exterieurs.py
index 6794ac11..aecbc04a 100644
--- a/app/scodoc/sco_formsemestre_exterieurs.py
+++ b/app/scodoc/sco_formsemestre_exterieurs.py
@@ -49,7 +49,7 @@ def formsemestre_ext_create(context, etudid, sem_params, REQUEST=None):
sem_params: dict nécessaire à la création du formsemestre
"""
# Check args
- _formation = context.formation_list(
+ _formation = sco_formations.formation_list(context,
args={"formation_id": sem_params["formation_id"]}
)[0]
if etudid:
@@ -436,7 +436,7 @@ def _list_ue_with_coef_and_validations(context, sem, etudid):
"""
cnx = ndb.GetDBConnexion()
formsemestre_id = sem["formsemestre_id"]
- ue_list = context.do_ue_list({"formation_id": sem["formation_id"]})
+ ue_list = sco_edit_ue.do_ue_list(context, {"formation_id": sem["formation_id"]})
for ue in ue_list:
# add coefficient
uecoef = sco_formsemestre.formsemestre_uecoef_list(
diff --git a/app/scodoc/sco_formsemestre_status.py b/app/scodoc/sco_formsemestre_status.py
index 1e3d8e02..8073a3f4 100644
--- a/app/scodoc/sco_formsemestre_status.py
+++ b/app/scodoc/sco_formsemestre_status.py
@@ -140,7 +140,7 @@ def formsemestre_status_menubar(context, sem, REQUEST):
else:
change_lock_msg = "Déverrouiller"
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
menuSemestre = [
{
@@ -563,7 +563,7 @@ def fill_formsemestre(context, sem, REQUEST=None):
)
else:
sem["eyelink"] = ""
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
sem["formation"] = F
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
if sem["semestre_id"] != -1:
@@ -605,7 +605,7 @@ def formsemestre_description_table(
use_ue_coefs = sco_preferences.get_preference(
context, "use_ue_coefs", formsemestre_id
)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
Mlist = sco_moduleimpl.do_moduleimpl_withmodule_list(
context, formsemestre_id=formsemestre_id
@@ -891,7 +891,7 @@ def html_expr_diagnostic(context, diagnostics):
)
else:
if diag["ue_id"] != last_id or diag["msg"] != last_msg:
- ue = context.do_ue_list({"ue_id": diag["ue_id"]})[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": diag["ue_id"]})[0]
H.append(
'
- UE "%s": %s
'
% (ue["acronyme"] or ue["titre"] or "?", diag["msg"])
@@ -912,7 +912,7 @@ def formsemestre_status_head(
if not semlist:
raise ScoValueError("Session inexistante (elle a peut être été supprimée ?)")
sem = semlist[0]
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
page_title = page_title or "Modules de "
diff --git a/app/scodoc/sco_formsemestre_validation.py b/app/scodoc/sco_formsemestre_validation.py
index 360838a4..baaf3b8d 100644
--- a/app/scodoc/sco_formsemestre_validation.py
+++ b/app/scodoc/sco_formsemestre_validation.py
@@ -1073,7 +1073,7 @@ def formsemestre_validate_previous_ue(context, formsemestre_id, etudid, REQUEST=
"""
etud = scolars.get_etud_info(etudid=etudid, filled=True)[0]
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- Fo = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ Fo = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
H = [
html_sco_header.sco_header(
@@ -1109,7 +1109,7 @@ def formsemestre_validate_previous_ue(context, formsemestre_id, etudid, REQUEST=
]
# Toutes les UE de cette formation sont présentées (même celles des autres semestres)
- ues = context.do_ue_list({"formation_id": Fo["formation_id"]})
+ ues = sco_edit_ue.do_ue_list(context, {"formation_id": Fo["formation_id"]})
ue_names = ["Choisir..."] + ["%(acronyme)s %(titre)s" % ue for ue in ues]
ue_ids = [""] + [ue["ue_id"] for ue in ues]
tf = TrivialFormulator(
@@ -1334,7 +1334,7 @@ def check_formation_ues(context, formation_id):
définition du programme: cette fonction retourne un bout de HTML
à afficher pour prévenir l'utilisateur, ou '' si tout est ok.
"""
- ues = context.do_ue_list({"formation_id": formation_id})
+ ues = sco_edit_ue.do_ue_list(context, {"formation_id": formation_id})
ue_multiples = {} # { ue_id : [ liste des formsemestre ] }
for ue in ues:
# formsemestres utilisant cette ue ?
diff --git a/app/scodoc/sco_inscr_passage.py b/app/scodoc/sco_inscr_passage.py
index 068450d9..147d30e3 100644
--- a/app/scodoc/sco_inscr_passage.py
+++ b/app/scodoc/sco_inscr_passage.py
@@ -242,7 +242,7 @@ def list_source_sems(context, sem, delai=None):
if s["semestre_id"] == sco_codes_parcours.NO_SEMESTRE_ID:
continue
#
- F = context.formation_list(args={"formation_id": s["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": s["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
if not parcours.ALLOW_SEM_SKIP:
if s["semestre_id"] < (sem["semestre_id"] - 1):
diff --git a/app/scodoc/sco_liste_notes.py b/app/scodoc/sco_liste_notes.py
index abf6bca9..62a7e9fd 100644
--- a/app/scodoc/sco_liste_notes.py
+++ b/app/scodoc/sco_liste_notes.py
@@ -224,7 +224,7 @@ def _make_table_notes(
E = evals[0]
moduleimpl_id = E["moduleimpl_id"]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
sem = sco_formsemestre.get_formsemestre(context, M["formsemestre_id"])
# (debug) check that all evals are in same module:
for e in evals:
diff --git a/app/scodoc/sco_moduleimpl.py b/app/scodoc/sco_moduleimpl.py
index fb84f0a9..8521275a 100644
--- a/app/scodoc/sco_moduleimpl.py
+++ b/app/scodoc/sco_moduleimpl.py
@@ -132,9 +132,9 @@ def do_moduleimpl_withmodule_list(
del args["REQUEST"]
modimpls = do_moduleimpl_list(context, **args)
for mo in modimpls:
- mo["module"] = context.do_module_list(args={"module_id": mo["module_id"]})[0]
- mo["ue"] = context.do_ue_list(args={"ue_id": mo["module"]["ue_id"]})[0]
- mo["matiere"] = context.do_matiere_list(
+ mo["module"] = sco_edit_module.do_module_list(context, args={"module_id": mo["module_id"]})[0]
+ mo["ue"] = sco_edit_ue.do_ue_list(context, args={"ue_id": mo["module"]["ue_id"]})[0]
+ mo["matiere"] = sco_edit_matiere.do_matiere_list(context,
args={"matiere_id": mo["module"]["matiere_id"]}
)[0]
diff --git a/app/scodoc/sco_moduleimpl_inscriptions.py b/app/scodoc/sco_moduleimpl_inscriptions.py
index 65ea7dc0..5b2abc4d 100644
--- a/app/scodoc/sco_moduleimpl_inscriptions.py
+++ b/app/scodoc/sco_moduleimpl_inscriptions.py
@@ -57,7 +57,7 @@ def moduleimpl_inscriptions_edit(
"""
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
formsemestre_id = M["formsemestre_id"]
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
# -- check lock
if sem["etat"] != "1":
@@ -334,7 +334,7 @@ def moduleimpl_inscriptions_stats(context, formsemestre_id, REQUEST=None):
UECaps = get_etuds_with_capitalized_ue(context, formsemestre_id)
if UECaps:
H.append('
Etudiants avec UEs capitalisées:
')
- ues = [context.do_ue_list({"ue_id": ue_id})[0] for ue_id in UECaps.keys()]
+ ues = [sco_edit_ue.do_ue_list(context, {"ue_id": ue_id})[0] for ue_id in UECaps.keys()]
ues.sort(key=lambda u: u["numero"])
for ue in ues:
H.append(
diff --git a/app/scodoc/sco_moduleimpl_status.py b/app/scodoc/sco_moduleimpl_status.py
index 43ed95a9..44ffb4b5 100644
--- a/app/scodoc/sco_moduleimpl_status.py
+++ b/app/scodoc/sco_moduleimpl_status.py
@@ -161,9 +161,9 @@ def moduleimpl_status(context, moduleimpl_id=None, partition_id=None, REQUEST=No
authuser = REQUEST.AUTHENTICATED_USER
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
formsemestre_id = M["formsemestre_id"]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
ModInscrits = sco_moduleimpl.do_moduleimpl_inscription_list(
context, moduleimpl_id=M["moduleimpl_id"]
)
diff --git a/app/scodoc/sco_parcours_dut.py b/app/scodoc/sco_parcours_dut.py
index 430fb456..1eb8c7cc 100644
--- a/app/scodoc/sco_parcours_dut.py
+++ b/app/scodoc/sco_parcours_dut.py
@@ -339,7 +339,7 @@ class SituationEtudParcoursGeneric:
if nb_ue > nb_max_ue:
nb_max_ue = nb_ue
# add formation_code to each sem:
- sem["formation_code"] = self.context.formation_list(
+ sem["formation_code"] = self.sco_formations.formation_list(context,
args={"formation_id": sem["formation_id"]}
)[0]["formation_code"]
# si sem peut servir à compenser le semestre courant, positionne
@@ -1098,7 +1098,7 @@ def list_formsemestre_utilisateurs_uecap(context, formsemestre_id):
semestre): meme code formation, meme semestre_id, date posterieure"""
cnx = ndb.GetDBConnexion()
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
cursor.execute(
"""select sem.formsemestre_id
diff --git a/app/scodoc/sco_placement.py b/app/scodoc/sco_placement.py
index ac906fd9..e26ee824 100644
--- a/app/scodoc/sco_placement.py
+++ b/app/scodoc/sco_placement.py
@@ -276,7 +276,7 @@ def do_placement(context, REQUEST):
return "Aucun groupe sélectionné !
"
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
sem = sco_formsemestre.get_formsemestre(context, M["formsemestre_id"])
evalname = "%s-%s" % (Mod["code"], ndb.DateDMYtoISO(E["jour"]))
if E["description"]:
diff --git a/app/scodoc/sco_pvjury.py b/app/scodoc/sco_pvjury.py
index 3bf6127f..47f98e35 100644
--- a/app/scodoc/sco_pvjury.py
+++ b/app/scodoc/sco_pvjury.py
@@ -83,7 +83,7 @@ def _descr_decisions_ues(context, nt, etudid, decisions_ue, decision_sem):
and sco_codes_parcours.code_semestre_validant(decision_sem["code"])
)
):
- ue = context.do_ue_list(args={"ue_id": ue_id})[0]
+ ue = sco_edit_ue.do_ue_list(context, args={"ue_id": ue_id})[0]
uelist.append(ue)
except:
log("descr_decisions_ues: ue_id=%s decisions_ue=%s" % (ue_id, decisions_ue))
@@ -353,7 +353,7 @@ def dict_pvjury(
"formsemestre": sem,
"has_prev": has_prev,
"semestre_non_terminal": semestre_non_terminal,
- "formation": context.formation_list(args={"formation_id": sem["formation_id"]})[
+ "formation": sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[
0
],
"decisions": L,
@@ -720,7 +720,7 @@ def formsemestre_pvjury_pdf(
def descrform_pvjury(context, sem):
"""Définition de formulaire pour PV jury PDF"""
- F = context.formation_list(formation_id=sem["formation_id"])[0]
+ F = sco_formations.formation_list(context, formation_id=sem["formation_id"])[0]
return [
(
"date_commission",
diff --git a/app/scodoc/sco_recapcomplet.py b/app/scodoc/sco_recapcomplet.py
index 73c516c3..4bddb19e 100644
--- a/app/scodoc/sco_recapcomplet.py
+++ b/app/scodoc/sco_recapcomplet.py
@@ -66,7 +66,7 @@ def formsemestre_recapcomplet(
trié par moyenne générale décroissante.
"""
sem = sco_formsemestre.get_formsemestre(context, formsemestre_id)
- F = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(F["type_parcours"])
# traduit du DTML
modejury = int(modejury)
diff --git a/app/scodoc/sco_saisie_notes.py b/app/scodoc/sco_saisie_notes.py
index 44cca390..278e6e33 100644
--- a/app/scodoc/sco_saisie_notes.py
+++ b/app/scodoc/sco_saisie_notes.py
@@ -280,7 +280,7 @@ def do_evaluation_upload_xls(context, REQUEST):
M = sco_moduleimpl.do_moduleimpl_list(
context, moduleimpl_id=E["moduleimpl_id"]
)[0]
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
mod["moduleimpl_id"] = M["moduleimpl_id"]
mod["url"] = "Notes/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % mod
sco_news.add(
@@ -371,7 +371,7 @@ def do_evaluation_set_missing(
nb_changed, _, _ = _notes_add(context, authuser, evaluation_id, L, comment)
# news
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
mod["moduleimpl_id"] = M["moduleimpl_id"]
mod["url"] = "Notes/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % mod
sco_news.add(
@@ -447,7 +447,7 @@ def evaluation_suppress_alln(context, evaluation_id, REQUEST, dialog_confirmed=F
]
# news
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
mod["moduleimpl_id"] = M["moduleimpl_id"]
mod["url"] = "Notes/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % mod
sco_news.add(
@@ -785,7 +785,7 @@ def feuille_saisie_notes(context, evaluation_id, group_ids=[], REQUEST=None):
E = evals[0]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
formsemestre_id = M["formsemestre_id"]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
sem = sco_formsemestre.get_formsemestre(context, M["formsemestre_id"])
if E["jour"]:
indication_date = DateDMYtoISO(E["jour"])
@@ -863,7 +863,7 @@ def has_existing_decision(context, M, E, etudid):
return True
dec_ues = nt.get_etud_decision_ues(etudid)
if dec_ues:
- mod = context.do_module_list({"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, {"module_id": M["module_id"]})[0]
ue_id = mod["ue_id"]
if ue_id in dec_ues:
return True # decision pour l'UE a laquelle appartient cette evaluation
@@ -1249,7 +1249,7 @@ def save_note(
)
E = context.do_evaluation_list({"evaluation_id": evaluation_id})[0]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
Mod["url"] = "Notes/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % M
result = {"nbchanged": 0} # JSON
# Check access: admin, respformation, or responsable_id
diff --git a/app/scodoc/sco_tag_module.py b/app/scodoc/sco_tag_module.py
index 074a85ad..58c52dc1 100644
--- a/app/scodoc/sco_tag_module.py
+++ b/app/scodoc/sco_tag_module.py
@@ -248,7 +248,7 @@ def module_tag_set(context, module_id="", taglist=[], REQUEST=None):
taglist = [t.strip() for t in taglist]
log("module_tag_set: module_id=%s taglist=%s" % (module_id, taglist))
# Sanity check:
- Mod = context.do_module_list(args={"module_id": module_id})
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": module_id})
if not Mod:
raise ScoValueError("invalid module !")
diff --git a/app/scodoc/sco_ue_external.py b/app/scodoc/sco_ue_external.py
index faf8d066..9377e137 100644
--- a/app/scodoc/sco_ue_external.py
+++ b/app/scodoc/sco_ue_external.py
@@ -91,7 +91,7 @@ def external_ue_create(
numero = sco_edit_ue.next_ue_numero(
context, formation_id, semestre_id=sem["semestre_id"]
)
- ue_id = context.do_ue_create(
+ ue_id = sco_edit_ue.do_ue_create(context,
{
"formation_id": formation_id,
"titre": titre,
@@ -104,11 +104,11 @@ def external_ue_create(
REQUEST,
)
- matiere_id = context.do_matiere_create(
+ matiere_id = sco_edit_matiere.do_matiere_create(context,
{"ue_id": ue_id, "titre": titre or acronyme, "numero": 1}, REQUEST
)
- module_id = context.do_module_create(
+ module_id = sco_edit_module.do_module_create(context,
{
"titre": "UE extérieure",
"code": acronyme,
@@ -176,7 +176,7 @@ def external_ue_inscrit_et_note(
def get_existing_external_ue(context, formation_id):
"la liste de toutes les UE externes définies dans cette formation"
- return context.do_ue_list(args={"formation_id": formation_id, "is_external": 1})
+ return sco_edit_ue.do_ue_list(context, args={"formation_id": formation_id, "is_external": 1})
def get_external_moduleimpl_id(context, formsemestre_id, ue_id):
@@ -235,7 +235,7 @@ def external_ue_create_form(context, formsemestre_id, etudid, REQUEST=None):
""",
]
html_footer = html_sco_header.sco_footer(context, REQUEST)
- Fo = context.formation_list(args={"formation_id": sem["formation_id"]})[0]
+ Fo = sco_formations.formation_list(context, args={"formation_id": sem["formation_id"]})[0]
parcours = sco_codes_parcours.get_parcours_from_code(Fo["type_parcours"])
ue_types = parcours.ALLOWED_UE_TYPES
ue_types.sort()
diff --git a/app/views/notes.py b/app/views/notes.py
index fdc48636..802b2fec 100644
--- a/app/views/notes.py
+++ b/app/views/notes.py
@@ -407,33 +407,11 @@ sco_publish(
Permission.ScoChangeFormation,
)
-
-@bp.route("/do_formation_delete")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_formation_delete(context, oid, REQUEST):
- """delete a formation (and all its UE, matieres, modules)
- XXX delete all ues, will break if there are validations ! USE WITH CARE !
- """
- F = context.formation_list(args={"formation_id": oid})[0]
- if context.formation_has_locked_sems(oid):
- raise ScoLockedFormError()
- cnx = ndb.GetDBConnexion()
- # delete all UE in this formation
- ues = context.do_ue_list({"formation_id": oid})
- for ue in ues:
- context._do_ue_delete(ue["ue_id"], REQUEST=REQUEST, force=True)
-
- _formationEditor.delete(cnx, oid)
-
- # news
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=oid,
- text="Suppression de la formation %(acronyme)s" % F,
- )
+sco_publish(
+ "/do_formation_delete",
+ sco_edit_formation.do_formation_delete,
+ Permission.ScoChangeFormation,
+)
@bp.route("/formation_list")
@@ -443,15 +421,7 @@ def formation_list(context, format=None, REQUEST=None, formation_id=None, args={
"""List formation(s) with given id, or matching args
(when args is given, formation_id is ignored).
"""
- # logCallStack()
- if not args:
- if formation_id is None:
- args = {}
- else:
- args = {"formation_id": formation_id}
- cnx = ndb.GetDBConnexion()
- r = sco_formations._formationEditor.list(cnx, args=args)
- # log('%d formations found' % len(r))
+ r = sco_formation.formation_list(context, formation_id=formation_id, args=args)
return scu.sendResult(REQUEST, r, name="formation", format=format)
@@ -504,7 +474,9 @@ def formation_import_xml_form(context, REQUEST):
elif tf[0] == -1:
return REQUEST.RESPONSE.redirect(scu.NotesURL())
else:
- formation_id, _, _ = context.formation_import_xml(tf[2]["xmlfile"], REQUEST)
+ formation_id, _, _ = sco_formations.formation_import_xml(
+ context, tf[2]["xmlfile"], REQUEST
+ )
return (
"\n".join(H)
@@ -527,7 +499,7 @@ def formation_create_new_version(context, formation_id, redirect=True, REQUEST=N
context, REQUEST, xml
)
# news
- F = context.formation_list(args={"formation_id": new_id})[0]
+ F = sco_formations.formation_list(context, args={"formation_id": new_id})[0]
sco_news.add(
context,
REQUEST,
@@ -544,382 +516,40 @@ def formation_create_new_version(context, formation_id, redirect=True, REQUEST=N
# --- UE
-_ueEditor = ndb.EditableTable(
- "notes_ue",
- "ue_id",
- (
- "ue_id",
- "formation_id",
- "acronyme",
- "numero",
- "titre",
- "type",
- "ue_code",
- "ects",
- "is_external",
- "code_apogee",
- "coefficient",
- ),
- sortkey="numero",
- input_formators={"type": ndb.int_null_is_zero},
- output_formators={
- "numero": ndb.int_null_is_zero,
- "ects": ndb.float_null_is_null,
- "coefficient": ndb.float_null_is_zero,
- },
+sco_publish(
+ "/do_ue_create",
+ sco_edit_ue.do_ue_create,
+ Permission.ScoChangeFormation,
)
-
-@bp.route("/do_ue_create")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_ue_create(context, args, REQUEST):
- "create an ue"
- cnx = ndb.GetDBConnexion()
- # check duplicates
- ues = context.do_ue_list(
- {"formation_id": args["formation_id"], "acronyme": args["acronyme"]}
- )
- if ues:
- raise ScoValueError('Acronyme d\'UE "%s" déjà utilisé !' % args["acronyme"])
- # create
- r = context._ueEditor.create(cnx, args)
-
- # news
- F = context.formation_list(args={"formation_id": args["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=args["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
- return r
-
-
-def _do_ue_delete(context, ue_id, delete_validations=False, REQUEST=None, force=False):
- "delete UE and attached matieres (but not modules (it should ?))"
- cnx = ndb.GetDBConnexion()
- log("do_ue_delete: ue_id=%s, delete_validations=%s" % (ue_id, delete_validations))
- # check
- ue = context.do_ue_list({"ue_id": ue_id})
- if not ue:
- raise ScoValueError("UE inexistante !")
- ue = ue[0]
- if sco_edit_ue.ue_is_locked(context, ue["ue_id"]):
- raise ScoLockedFormError()
- # Il y a-t-il des etudiants ayant validé cette UE ?
- # si oui, propose de supprimer les validations
- validations = sco_parcours_dut.scolar_formsemestre_validation_list(
- cnx, args={"ue_id": ue_id}
- )
- if validations and not delete_validations and not force:
- return scu.confirm_dialog(
- context,
- "%d étudiants ont validé l'UE %s (%s)
Si vous supprimez cette UE, ces validations vont être supprimées !
"
- % (len(validations), ue["acronyme"], ue["titre"]),
- dest_url="",
- REQUEST=REQUEST,
- target_variable="delete_validations",
- cancel_url="ue_list?formation_id=%s" % ue["formation_id"],
- parameters={"ue_id": ue_id, "dialog_confirmed": 1},
- )
- if delete_validations:
- log("deleting all validations of UE %s" % ue_id)
- ndb.SimpleQuery(
- context,
- "DELETE FROM scolar_formsemestre_validation WHERE ue_id=%(ue_id)s",
- {"ue_id": ue_id},
- )
-
- # delete all matiere in this UE
- mats = context.do_matiere_list({"ue_id": ue_id})
- for mat in mats:
- context.do_matiere_delete(mat["matiere_id"], REQUEST)
- # delete uecoef and events
- ndb.SimpleQuery(
- context,
- "DELETE FROM notes_formsemestre_uecoef WHERE ue_id=%(ue_id)s",
- {"ue_id": ue_id},
- )
- ndb.SimpleQuery(
- context, "DELETE FROM scolar_events WHERE ue_id=%(ue_id)s", {"ue_id": ue_id}
- )
- cnx = ndb.GetDBConnexion()
- context._ueEditor.delete(cnx, ue_id)
- # > UE delete + supr. validations associées etudiants (cas compliqué, mais rarement utilisé: acceptable de tout invalider ?):
- sco_core.inval_cache(context)
- # news
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=ue["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
- #
- if not force:
- return REQUEST.RESPONSE.redirect(
- scu.NotesURL() + "/ue_list?formation_id=" + str(ue["formation_id"])
- )
- else:
- return None
-
-
-@bp.route("/do_ue_list")
-@permission_required(Permission.ScoView)
-@scodoc7func(context)
-def do_ue_list(context, *args, **kw):
- "list UEs"
- cnx = ndb.GetDBConnexion()
- return context._ueEditor.list(cnx, *args, **kw)
+sco_publish(
+ "/do_ue_list",
+ sco_edit_ue.do_ue_list,
+ Permission.ScoView,
+)
# --- Matieres
-_matiereEditor = ndb.EditableTable(
- "notes_matieres",
- "matiere_id",
- ("matiere_id", "ue_id", "numero", "titre"),
- sortkey="numero",
- output_formators={"numero": ndb.int_null_is_zero},
+sco_publish(
+ "/do_matiere_create",
+ sco_edit_matiere.do_matiere_create,
+ Permission.ScoChangeFormation,
+)
+sco_publish(
+ "/do_matiere_delete",
+ sco_edit_matiere.do_matiere_delete,
+ Permission.ScoChangeFormation,
)
-
-
-@bp.route("/do_matiere_create")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_matiere_create(context, args, REQUEST):
- "create a matiere"
- cnx = ndb.GetDBConnexion()
- # check
- ue = context.do_ue_list({"ue_id": args["ue_id"]})[0]
- # create matiere
- r = context._matiereEditor.create(cnx, args)
-
- # news
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=ue["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
- return r
-
-
-@bp.route("/do_matiere_delete")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_matiere_delete(context, oid, REQUEST):
- "delete matiere and attached modules"
- cnx = ndb.GetDBConnexion()
- # check
- mat = context.do_matiere_list({"matiere_id": oid})[0]
- ue = context.do_ue_list({"ue_id": mat["ue_id"]})[0]
- locked = sco_edit_matiere.matiere_is_locked(context, mat["matiere_id"])
- if locked:
- log("do_matiere_delete: mat=%s" % mat)
- log("do_matiere_delete: ue=%s" % ue)
- log("do_matiere_delete: locked sems: %s" % locked)
- raise ScoLockedFormError()
- log("do_matiere_delete: matiere_id=%s" % oid)
- # delete all modules in this matiere
- mods = context.do_module_list({"matiere_id": oid})
- for mod in mods:
- context.do_module_delete(mod["module_id"], REQUEST)
- context._matiereEditor.delete(cnx, oid)
-
- # news
- F = context.formation_list(args={"formation_id": ue["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=ue["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
-
-
-@bp.route("/do_matiere_list")
-@permission_required(Permission.ScoView)
-@scodoc7func(context)
-def do_matiere_list(context, *args, **kw):
- "list matieres"
- cnx = ndb.GetDBConnexion()
- return context._matiereEditor.list(cnx, *args, **kw)
-
-
-@bp.route("/do_matiere_edit")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_matiere_edit(context, *args, **kw):
- "edit a matiere"
- cnx = ndb.GetDBConnexion()
- # check
- mat = context.do_matiere_list({"matiere_id": args[0]["matiere_id"]})[0]
- if sco_edit_matiere.matiere_is_locked(context, mat["matiere_id"]):
- raise ScoLockedFormError()
- # edit
- context._matiereEditor.edit(cnx, *args, **kw)
- sco_core.inval_cache(context) # > modif matiere
-
-
-@bp.route("/do_matiere_formation_id")
-@permission_required(Permission.ScoView)
-@scodoc7func(context)
-def do_matiere_formation_id(context, matiere_id):
- "get formation_id from matiere"
- cnx = ndb.GetDBConnexion()
- cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
- cursor.execute(
- "select UE.formation_id from notes_matieres M, notes_ue UE where M.matiere_id = %(matiere_id)s and M.ue_id = UE.ue_id",
- {"matiere_id": matiere_id},
- )
- res = cursor.fetchall()
- return res[0][0]
# --- Modules
-_moduleEditor = ndb.EditableTable(
- "notes_modules",
- "module_id",
- (
- "module_id",
- "titre",
- "code",
- "abbrev",
- "heures_cours",
- "heures_td",
- "heures_tp",
- "coefficient",
- "ue_id",
- "matiere_id",
- "formation_id",
- "semestre_id",
- "numero",
- "code_apogee",
- "module_type"
- #'ects'
- ),
- sortkey="numero, code, titre",
- output_formators={
- "heures_cours": ndb.float_null_is_zero,
- "heures_td": ndb.float_null_is_zero,
- "heures_tp": ndb.float_null_is_zero,
- "numero": ndb.int_null_is_zero,
- "coefficient": ndb.float_null_is_zero,
- "module_type": ndb.int_null_is_zero
- #'ects' : ndb.float_null_is_null
- },
+sco_publish(
+ "/do_module_delete",
+ sco_edit_module.do_module_delete,
+ Permission.ScoChangeFormation,
)
-@bp.route("/do_module_create")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_module_create(context, args, REQUEST):
- "create a module"
- # create
- cnx = ndb.GetDBConnexion()
- r = context._moduleEditor.create(cnx, args)
-
- # news
- F = context.formation_list(args={"formation_id": args["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=args["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
- return r
-
-
-@bp.route("/do_module_delete")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_module_delete(context, oid, REQUEST):
- "delete module"
- mod = context.do_module_list({"module_id": oid})[0]
- if sco_edit_module.module_is_locked(context, mod["module_id"]):
- raise ScoLockedFormError()
-
- # S'il y a des moduleimpls, on ne peut pas detruire le module !
- mods = sco_moduleimpl.do_moduleimpl_list(context, module_id=oid)
- if mods:
- err_page = scu.confirm_dialog(
- context,
- message="""Destruction du module impossible car il est utilisé dans des semestres existants !
""",
- helpmsg="""Il faut d'abord supprimer le semestre. Mais il est peut être préférable de laisser ce programme intact et d'en créer une nouvelle version pour la modifier.""",
- dest_url="ue_list",
- parameters={"formation_id": mod["formation_id"]},
- REQUEST=REQUEST,
- )
- raise ScoGenError(err_page)
- # delete
- cnx = ndb.GetDBConnexion()
- context._moduleEditor.delete(cnx, oid)
-
- # news
- F = context.formation_list(args={"formation_id": mod["formation_id"]})[0]
- sco_news.add(
- context,
- REQUEST,
- typ=NEWS_FORM,
- object=mod["formation_id"],
- text="Modification de la formation %(acronyme)s" % F,
- )
-
-
-@bp.route("/do_module_list")
-@permission_required(Permission.ScoView)
-@scodoc7func(context)
-def do_module_list(context, *args, **kw):
- "list modules"
- cnx = ndb.GetDBConnexion()
- return context._moduleEditor.list(cnx, *args, **kw)
-
-
-@bp.route("/do_module_edit")
-@permission_required(Permission.ScoChangeFormation)
-@scodoc7func(context)
-def do_module_edit(context, val):
- "edit a module"
- # check
- mod = context.do_module_list({"module_id": val["module_id"]})[0]
- if sco_edit_module.module_is_locked(context, mod["module_id"]):
- # formation verrouillée: empeche de modifier certains champs:
- protected_fields = ("coefficient", "ue_id", "matiere_id", "semestre_id")
- for f in protected_fields:
- if f in val:
- del val[f]
- # edit
- cnx = ndb.GetDBConnexion()
- context._moduleEditor.edit(cnx, val)
-
- sems = sco_formsemestre.do_formsemestre_list(
- context, args={"formation_id": mod["formation_id"]}
- )
- if sems:
- sco_core.inval_cache(
- context, formsemestre_id_list=[s["formsemestre_id"] for s in sems]
- ) # > modif module
-
-
-#
-@bp.route("/formation_has_locked_sems")
-@permission_required(Permission.ScoView)
-@scodoc7func(context)
-def formation_has_locked_sems(context, formation_id):
- "True if there is a locked formsemestre in this formation"
- sems = sco_formsemestre.do_formsemestre_list(
- context, args={"formation_id": formation_id, "etat": "0"}
- )
- return sems
-
-
@bp.route("/formation_count_sems")
@permission_required(Permission.ScoView)
@scodoc7func(context)
@@ -949,13 +579,15 @@ sco_publish(
@scodoc7func(context)
def module_move(context, module_id, after=0, REQUEST=None, redirect=1):
"""Move before/after previous one (decrement/increment numero)"""
- module = context.do_module_list({"module_id": module_id})[0]
+ module = sco_edit_module.do_module_list(context, {"module_id": module_id})[0]
redirect = int(redirect)
after = int(after) # 0: deplace avant, 1 deplace apres
if after not in (0, 1):
raise ValueError('invalid value for "after"')
formation_id = module["formation_id"]
- others = context.do_module_list({"matiere_id": module["matiere_id"]})
+ others = sco_edit_module.do_module_list(
+ context, {"matiere_id": module["matiere_id"]}
+ )
# log('others=%s' % others)
if len(others) > 1:
idx = [p["module_id"] for p in others].index(module_id)
@@ -972,8 +604,8 @@ def module_move(context, module_id, after=0, REQUEST=None, redirect=1):
module["numero"], neigh["numero"] = neigh["numero"], module["numero"]
if module["numero"] == neigh["numero"]:
neigh["numero"] -= 2 * after - 1
- context._moduleEditor.edit(cnx, module)
- context._moduleEditor.edit(cnx, neigh)
+ _moduleEditor.edit(cnx, module)
+ _moduleEditor.edit(cnx, neigh)
# redirect to ue_list page:
if redirect:
@@ -985,14 +617,14 @@ def module_move(context, module_id, after=0, REQUEST=None, redirect=1):
@scodoc7func(context)
def ue_move(context, ue_id, after=0, REQUEST=None, redirect=1):
"""Move UE before/after previous one (decrement/increment numero)"""
- o = context.do_ue_list({"ue_id": ue_id})[0]
+ o = sco_edit_ue.do_ue_list(context, {"ue_id": ue_id})[0]
# log('ue_move %s (#%s) after=%s' % (ue_id, o['numero'], after))
redirect = int(redirect)
after = int(after) # 0: deplace avant, 1 deplace apres
if after not in (0, 1):
raise ValueError('invalid value for "after"')
formation_id = o["formation_id"]
- others = context.do_ue_list({"formation_id": formation_id})
+ others = sco_edit_ue.do_ue_list(context, {"formation_id": formation_id})
if len(others) > 1:
idx = [p["ue_id"] for p in others].index(ue_id)
neigh = None # object to swap with
@@ -1554,7 +1186,7 @@ def edit_ue_expr(context, REQUEST, formsemestre_id, ue_id):
raise AccessDenied("vous n'avez pas le droit d'effectuer cette opération")
cnx = ndb.GetDBConnexion()
#
- ue = context.do_ue_list({"ue_id": ue_id})[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": ue_id})[0]
H = [
html_sco_header.html_sem_header(
context,
@@ -1753,8 +1385,8 @@ def do_formsemestre_inscription_listinscrits(
r = cache.get(formsemestre_id)
if r is None:
# retreive list
- r = sco_formsemestre_inscriptions.do_formsemestre_inscription_list(context,
- args={"formsemestre_id": formsemestre_id, "etat": "I"}
+ r = sco_formsemestre_inscriptions.do_formsemestre_inscription_list(
+ context, args={"formsemestre_id": formsemestre_id, "etat": "I"}
)
cache.set(formsemestre_id, r)
return scu.sendResult(REQUEST, r, format=format, name="inscrits")
@@ -1811,8 +1443,8 @@ def formsemestre_desinscription(
sem["date_debut"],
sem["date_fin"],
)
- inscrits = sco_formsemestre_inscriptions.do_formsemestre_inscription_list(context,
- args={"formsemestre_id": formsemestre_id}
+ inscrits = sco_formsemestre_inscriptions.do_formsemestre_inscription_list(
+ context, args={"formsemestre_id": formsemestre_id}
)
nbinscrits = len(inscrits)
if nbinscrits <= 1:
@@ -2050,7 +1682,7 @@ def do_evaluation_create(
# news
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=moduleimpl_id)[0]
- mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
mod["moduleimpl_id"] = M["moduleimpl_id"]
mod["url"] = "Notes/moduleimpl_status?moduleimpl_id=%(moduleimpl_id)s" % mod
sco_news.add(
@@ -2127,7 +1759,7 @@ def evaluation_delete(context, REQUEST, evaluation_id):
raise ValueError("Evalution inexistante ! (%s)" % evaluation_id)
E = El[0]
M = sco_moduleimpl.do_moduleimpl_list(context, moduleimpl_id=E["moduleimpl_id"])[0]
- Mod = context.do_module_list(args={"module_id": M["module_id"]})[0]
+ Mod = sco_edit_module.do_module_list(context, args={"module_id": M["module_id"]})[0]
tit = "Suppression de l'évaluation %(description)s (%(jour)s)" % E
etat = sco_evaluations.do_evaluation_etat(context, evaluation_id)
H = [
@@ -3156,8 +2788,10 @@ def check_sem_integrity(context, formsemestre_id, REQUEST):
bad_ue = []
bad_sem = []
for modimpl in modimpls:
- mod = context.do_module_list({"module_id": modimpl["module_id"]})[0]
- ue = context.do_ue_list({"ue_id": mod["ue_id"]})[0]
+ mod = sco_edit_module.do_module_list(
+ context, {"module_id": modimpl["module_id"]}
+ )[0]
+ ue = sco_edit_ue.do_ue_list(context, {"ue_id": mod["ue_id"]})[0]
if ue["formation_id"] != mod["formation_id"]:
modimpl["mod"] = mod
modimpl["ue"] = ue
@@ -3183,12 +2817,14 @@ def check_sem_integrity(context, formsemestre_id, REQUEST):
def check_form_integrity(context, formation_id, fix=False, REQUEST=None):
"debug"
log("check_form_integrity: formation_id=%s fix=%s" % (formation_id, fix))
- ues = context.do_ue_list(args={"formation_id": formation_id})
+ ues = sco_edit_ue.do_ue_list(context, args={"formation_id": formation_id})
bad = []
for ue in ues:
- mats = context.do_matiere_list(args={"ue_id": ue["ue_id"]})
+ mats = sco_edit_matiere.do_matiere_list(context, args={"ue_id": ue["ue_id"]})
for mat in mats:
- mods = context.do_module_list({"matiere_id": mat["matiere_id"]})
+ mods = sco_edit_module.do_module_list(
+ context, {"matiere_id": mat["matiere_id"]}
+ )
for mod in mods:
if mod["ue_id"] != ue["ue_id"]:
if fix:
@@ -3197,7 +2833,7 @@ def check_form_integrity(context, formation_id, fix=False, REQUEST=None):
"fix: mod.ue_id = %s (was %s)" % (ue["ue_id"], mod["ue_id"])
)
mod["ue_id"] = ue["ue_id"]
- context.do_module_edit(mod)
+ sco_edit_module.do_module_edit(context, mod)
bad.append(mod)
if mod["formation_id"] != formation_id:
bad.append(mod)
@@ -3276,7 +2912,9 @@ def check_formsemestre_integrity(context, formsemestre_id, REQUEST=None):
def check_integrity_all(context, REQUEST=None):
"debug: verifie tous les semestres et tt les formations"
# formations
- for F in context.formation_list():
+ for F in sco_formations.formation_list(
+ context,
+ ):
context.check_form_integrity(F["formation_id"], REQUEST=REQUEST)
# semestres
for sem in sco_formsemestre.do_formsemestre_list(context):
diff --git a/app/views/scolar.py b/app/views/scolar.py
index 788cf4ae..ead578c7 100644
--- a/app/views/scolar.py
+++ b/app/views/scolar.py
@@ -153,7 +153,9 @@ def sco_publish(route, function, permission):
"""Declare a route for a python function,
protected by permission and called following ScoDoc 7 Zope standards.
"""
- bp.route(route)(permission_required(permission)(scodoc7func(context)(function)))
+ return bp.route(route)(
+ permission_required(permission)(scodoc7func(context)(function))
+ )
log.set_log_directory(Config.INSTANCE_HOME + "/log")
@@ -213,7 +215,7 @@ def about(context, REQUEST):
@permission_required(Permission.ScoChangePreferences)
@scodoc7func(context)
def edit_preferences(context, REQUEST):
- """Edit global preferences (lien eParamétrage" département)"""
+ """Edit global preferences (lien "Paramétrage" département)"""
return sco_preferences.get_base_preferences(context).edit(REQUEST=REQUEST)
@@ -288,7 +290,7 @@ def showEtudLog(context, etudid, format="html", REQUEST=None):
# ---------- PAGE ACCUEIL (listes) --------------
-sco_publish("/", sco_dept.index_html, Permission.ScoView)
+bp.route("/")(sco_publish("/index_html", sco_dept.index_html, Permission.ScoView))
@bp.route("/rssnews")
diff --git a/config/get_scodoc_version.sh b/config/get_scodoc_version.sh
index ed577d48..6d5fcc51 100755
--- a/config/get_scodoc_version.sh
+++ b/config/get_scodoc_version.sh
@@ -8,7 +8,7 @@ source config.sh
source utils.sh
# Source code version:
-x=$(grep SCOVERSION ../VERSION.py) || terminate "can't access VERSION.py" 1
+x=$(grep SCOVERSION ../app/scodoc/VERSION.py) || terminate "can't access VERSION.py" 1
x=${x#*\"}
src_version=${x%\"*}