diff --git a/app/scodoc/html_sidebar.py b/app/scodoc/html_sidebar.py
index 838fc9b4..43e2e6ea 100644
--- a/app/scodoc/html_sidebar.py
+++ b/app/scodoc/html_sidebar.py
@@ -48,7 +48,7 @@ def sidebar_common():
"authuser": current_user.user_name,
}
H = [
- f"""ScoDoc 8
+ f"""ScoDoc 9
{current_user.user_name}
diff --git a/app/scodoc/sco_archives.py b/app/scodoc/sco_archives.py
index 2dc2f65f..66c8c2d7 100644
--- a/app/scodoc/sco_archives.py
+++ b/app/scodoc/sco_archives.py
@@ -53,6 +53,7 @@ import shutil
import glob
import flask
+from flask import g
import app.scodoc.sco_utils as scu
from config import Config
@@ -95,7 +96,7 @@ class BaseArchiver(object):
:return: path to directory of archives for this object (eg formsemestre_id or etudid).
If directory does not yet exist, create it.
"""
- dept_dir = os.path.join(self.root, scu.get_dept_id())
+ dept_dir = os.path.join(self.root, g.scodoc_dept)
try:
scu.GSL.acquire()
if not os.path.isdir(dept_dir):
@@ -113,7 +114,7 @@ class BaseArchiver(object):
"""
:return: list of archive oids
"""
- base = os.path.join(self.root, scu.get_dept_id()) + os.path.sep
+ base = os.path.join(self.root, g.scodoc_dept) + os.path.sep
dirs = glob.glob(base + "*")
return [os.path.split(x)[1] for x in dirs]
diff --git a/app/scodoc/sco_bulletins_pdf.py b/app/scodoc/sco_bulletins_pdf.py
index 9892850e..ff05f722 100644
--- a/app/scodoc/sco_bulletins_pdf.py
+++ b/app/scodoc/sco_bulletins_pdf.py
@@ -58,6 +58,8 @@ import traceback
from reportlab.platypus.doctemplate import PageTemplate, BaseDocTemplate
+from flask import g, url_for
+
from app.scodoc import VERSION
import app.scodoc.sco_utils as scu
from app.scodoc.notes_log import log
@@ -139,7 +141,7 @@ def process_field(field, cdict, style, suppress_empty_pars=False, format="pdf"):
return text
# --- PDF format:
# handle logos:
- image_dir = scu.SCODOC_LOGOS_DIR + "/logos_" + scu.get_dept_id() + "/"
+ image_dir = scu.SCODOC_LOGOS_DIR + "/logos_" + g.scodoc_dept + "/"
if not os.path.exists(image_dir):
image_dir = scu.SCODOC_LOGOS_DIR + "/" # use global logos
if not os.path.exists(image_dir):
diff --git a/app/scodoc/sco_bulletins_signature.py b/app/scodoc/sco_bulletins_signature.py
index 120cbbf8..fead3aa8 100644
--- a/app/scodoc/sco_bulletins_signature.py
+++ b/app/scodoc/sco_bulletins_signature.py
@@ -85,7 +85,7 @@ et sur page "réglages bulletin" (avec formsemestre_id)
# def _sig_filename(side, formsemestre_id=None):
# if not side in ("left", "right"):
# raise ValueError("side must be left or right")
-# dirs = [SCODOC_LOGOS_DIR, scu.get_dept_id()]
+# dirs = [SCODOC_LOGOS_DIR, g.scodoc_dept]
# if formsemestre_id:
# dirs.append(formsemestre_id)
# dirs.append("bul_sig_{}".format(side))
diff --git a/app/scodoc/sco_etud.py b/app/scodoc/sco_etud.py
index d8e5a74f..6736ad69 100644
--- a/app/scodoc/sco_etud.py
+++ b/app/scodoc/sco_etud.py
@@ -911,7 +911,7 @@ def fill_etuds_info(etuds):
# open('/tmp/t','w').write( str(etuds) )
for etud in etuds:
etudid = etud["etudid"]
- etud["dept"] = scu.get_dept_id()
+ etud["dept"] = g.scodoc_dept
adrs = adresse_list(cnx, {"etudid": etudid})
if not adrs:
# certains "vieux" etudiants n'ont pas d'adresse
diff --git a/app/scodoc/sco_export_results.py b/app/scodoc/sco_export_results.py
index 168abc63..12e1e8aa 100644
--- a/app/scodoc/sco_export_results.py
+++ b/app/scodoc/sco_export_results.py
@@ -195,7 +195,7 @@ def _build_results_list(dpv_by_sem, etuds_infos):
int(sem["annee_debut"]), sem["mois_debut_ord"]
)
r["sid"] = "{} {} {}".format(
- sem["sem_id_txt"], scu.get_dept_id(), sem["modalite"]
+ sem["sem_id_txt"], g.scodoc_dept, sem["modalite"]
)
rows.append(r)
diff --git a/app/scodoc/sco_inscr_passage.py b/app/scodoc/sco_inscr_passage.py
index de567014..90f89db9 100644
--- a/app/scodoc/sco_inscr_passage.py
+++ b/app/scodoc/sco_inscr_passage.py
@@ -145,12 +145,13 @@ def list_inscrits_date(sem):
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
sem["date_debut_iso"] = ndb.DateDMYtoISO(sem["date_debut"])
cursor.execute(
- """select I.etudid
- from notes_formsemestre_inscription I, notes_formsemestre S
- where I.formsemestre_id = S.formsemestre_id
- and I.formsemestre_id != %(formsemestre_id)s
- and S.date_debut <= %(date_debut_iso)s
- and S.date_fin >= %(date_debut_iso)s""",
+ """SELECT I.etudid
+ FROM notes_formsemestre_inscription I, notes_formsemestre S
+ WHERE I.formsemestre_id = S.id
+ AND S.id != %(formsemestre_id)s
+ AND S.date_debut <= %(date_debut_iso)s
+ AND S.date_fin >= %(date_debut_iso)s
+ """,
sem,
)
return [x[0] for x in cursor.fetchall()]
diff --git a/app/scodoc/sco_pdf.py b/app/scodoc/sco_pdf.py
index 5eaa40e6..7b219e85 100755
--- a/app/scodoc/sco_pdf.py
+++ b/app/scodoc/sco_pdf.py
@@ -52,6 +52,8 @@ from reportlab.lib.enums import TA_LEFT, TA_RIGHT, TA_CENTER, TA_JUSTIFY
from reportlab.lib import styles
from reportlab.lib.pagesizes import letter, A4, landscape
+from flask import g
+
import app.scodoc.sco_utils as scu
from app.scodoc.sco_utils import (
CONFIG,
@@ -203,7 +205,7 @@ class ScolarsPageTemplate(PageTemplate):
# XXX COPIED from sco_pvpdf, to be refactored (no time now)
# Search background in dept specific dir, then in global config dir
for image_dir in (
- SCODOC_LOGOS_DIR + "/logos_" + scu.get_dept_id() + "/",
+ SCODOC_LOGOS_DIR + "/logos_" + g.scodoc_dept + "/",
SCODOC_LOGOS_DIR + "/", # global logos
):
for suffix in LOGOS_IMAGES_ALLOWED_TYPES:
diff --git a/app/scodoc/sco_permissions.py b/app/scodoc/sco_permissions.py
index a5419d4e..4eee09da 100644
--- a/app/scodoc/sco_permissions.py
+++ b/app/scodoc/sco_permissions.py
@@ -1,7 +1,7 @@
# -*- mode: python -*-
# -*- coding: utf-8 -*-
-"""Definition of ScoDoc 8 permissions
+"""Definition of ScoDoc permissions
used by auth
"""
diff --git a/app/scodoc/sco_photos.py b/app/scodoc/sco_photos.py
index 6e6732fe..e3f31a0b 100644
--- a/app/scodoc/sco_photos.py
+++ b/app/scodoc/sco_photos.py
@@ -43,18 +43,18 @@ Les images sont servies par ScoDoc, via la méthode getphotofile?etudid=xxx
"""
+import datetime
+import glob
import io
import os
-import time
-import datetime
import random
-import six.moves.urllib.request, six.moves.urllib.error, six.moves.urllib.parse
+import requests
+import time
import traceback
+
from PIL import Image as PILImage
-import glob
-
-from flask import request
+from flask import request, g
from config import Config
@@ -318,7 +318,7 @@ def get_new_filename(etudid):
"""Constructs a random filename to store a new image.
The path is constructed as: Fxx/etudid
"""
- dept = scu.get_dept_id()
+ dept = g.scodoc_dept
return find_new_dir() + dept + "_" + str(etudid)
@@ -351,17 +351,15 @@ def copy_portal_photo_to_fs(etud):
f = None
try:
log("copy_portal_photo_to_fs: getting %s" % url)
- f = six.moves.urllib.request.urlopen(
- url, timeout=portal_timeout
- ) # python >= 2.7
+ r = requests.get(url, timeout=portal_timeout)
except:
log("download failed: exception:\n%s" % traceback.format_exc())
log("called from:\n" + "".join(traceback.format_stack()))
return None, "%s: erreur chargement de %s" % (etud["nomprenom"], url)
- if not f:
+ if r.status_code != 200:
log("download failed")
return None, "%s: erreur chargement de %s" % (etud["nomprenom"], url)
- data = f.read()
+ data = r.content # image bytes
try:
status, diag = store_photo(etud, data)
except:
diff --git a/app/scodoc/sco_portal_apogee.py b/app/scodoc/sco_portal_apogee.py
index 2278e991..fe827683 100644
--- a/app/scodoc/sco_portal_apogee.py
+++ b/app/scodoc/sco_portal_apogee.py
@@ -27,20 +27,19 @@
"""Liaison avec le portail ENT (qui donne accès aux infos Apogée)
"""
-
-import os, time
-import six.moves.urllib.request, six.moves.urllib.parse, six.moves.urllib.error
+import datetime
+import os
+import time
+import urllib
import xml
import xml.sax.saxutils
import xml.dom.minidom
-import datetime
import app.scodoc.sco_utils as scu
from app.scodoc.notes_log import log
from app.scodoc.sco_exceptions import ScoValueError
from app.scodoc import sco_preferences
import six
-from six.moves import range
SCO_CACHE_ETAPE_FILENAME = os.path.join(scu.SCO_TMP_DIR, "last_etapes.xml")
@@ -52,17 +51,19 @@ def has_portal():
class PortalInterface(object):
def __init__(self):
- self.warning = False
+ self.first_time = True
def get_portal_url(self):
"URL of portal"
portal_url = sco_preferences.get_preference("portal_url")
- if not self.warning:
+ if portal_url and not portal_url.endswith("/"):
+ portal_url += "/"
+ if self.first_time:
if portal_url:
log("Portal URL=%s" % portal_url)
else:
log("Portal not configured")
- self.warning = True
+ self.first_time = False
return portal_url
def get_etapes_url(self):
@@ -157,14 +158,10 @@ def get_inscrits_etape(code_etape, anneeapogee=None, ntrials=2):
req = (
etud_url
+ "?"
- + six.moves.urllib.parse.urlencode(
- (("etape", code_etape), ("annee", anneeapogee))
- )
+ + urllib.parse.urlencode((("etape", code_etape), ("annee", anneeapogee)))
)
else:
- req = (
- etud_url + "?" + six.moves.urllib.parse.urlencode((("etape", code_etape),))
- )
+ req = etud_url + "?" + urllib.parse.urlencode((("etape", code_etape),))
actual_timeout = float(portal_timeout) / ntrials
if portal_timeout > 0:
actual_timeout = max(1, actual_timeout)
@@ -209,7 +206,7 @@ def query_apogee_portal(**args):
# XXX TODO : va poser problème pour la page modif données étudiants : A VOIR
return []
portal_timeout = sco_preferences.get_preference("portal_timeout")
- req = etud_url + "?" + six.moves.urllib.parse.urlencode(list(args.items()))
+ req = etud_url + "?" + urllib.parse.urlencode(list(args.items()))
doc = scu.query_portal(req, timeout=portal_timeout) # sco_utils
return xml_to_list_of_dicts(doc, req=req)
@@ -242,7 +239,7 @@ def xml_to_list_of_dicts(doc, req=None):
)
infos = []
try:
- if dom.childNodes[0].nodeName != u"etudiants":
+ if dom.childNodes[0].nodeName != "etudiants":
raise ValueError
etudiants = dom.getElementsByTagName("etudiant")
for etudiant in etudiants:
@@ -252,9 +249,7 @@ def xml_to_list_of_dicts(doc, req=None):
if e.nodeType == e.ELEMENT_NODE:
childs = e.childNodes
if len(childs):
- d[str(e.nodeName)] = childs[0].nodeValue.encode(
- scu.SCO_ENCODING
- )
+ d[str(e.nodeName)] = childs[0].nodeValue
infos.append(d)
except:
log("*** invalid XML response from Etudiant Web Service")
@@ -320,7 +315,7 @@ def get_etud_apogee(code_nip):
if not etud_url:
return {}
portal_timeout = sco_preferences.get_preference("portal_timeout")
- req = etud_url + "?" + six.moves.urllib.parse.urlencode((("nip", code_nip),))
+ req = etud_url + "?" + urllib.parse.urlencode((("nip", code_nip),))
doc = scu.query_portal(req, timeout=portal_timeout)
d = _normalize_apo_fields(xml_to_list_of_dicts(doc, req=req))
if not d:
@@ -356,13 +351,13 @@ def _parse_etapes_from_xml(doc):
# parser XML
dom = xml.dom.minidom.parseString(doc)
infos = {}
- if dom.childNodes[0].nodeName != u"etapes":
+ if dom.childNodes[0].nodeName != "etapes":
raise ValueError
if xml_etapes_by_dept:
# Ancien format XML avec des sections par departement:
for d in dom.childNodes[0].childNodes:
if d.nodeType == d.ELEMENT_NODE:
- dept = d.nodeName.encode(scu.SCO_ENCODING)
+ dept = d.nodeName
_xml_list_codes(infos, dept, d.childNodes)
else:
# Toutes les étapes:
@@ -411,8 +406,8 @@ def get_etapes_apogee():
def _xml_list_codes(target_dict, dept, nodes):
for e in nodes:
if e.nodeType == e.ELEMENT_NODE:
- intitule = e.childNodes[0].nodeValue.encode(scu.SCO_ENCODING)
- code = e.attributes["code"].value.encode(scu.SCO_ENCODING)
+ intitule = e.childNodes[0].nodeValue
+ code = e.attributes["code"].value
if dept in target_dict:
target_dict[dept][code] = intitule
else:
@@ -558,9 +553,7 @@ def get_maquette_apogee(etape="", annee_scolaire=""):
req = (
maquette_url
+ "?"
- + six.moves.urllib.parse.urlencode(
- (("etape", etape), ("annee", annee_scolaire))
- )
+ + urllib.parse.urlencode((("etape", etape), ("annee", annee_scolaire)))
)
doc = scu.query_portal(req, timeout=portal_timeout)
return doc
diff --git a/app/scodoc/sco_pvpdf.py b/app/scodoc/sco_pvpdf.py
index 2872c2ac..262d7750 100644
--- a/app/scodoc/sco_pvpdf.py
+++ b/app/scodoc/sco_pvpdf.py
@@ -200,7 +200,7 @@ class CourrierIndividuelTemplate(PageTemplate):
self.logo_header = None
# Search logos in dept specific dir, then in global scu.CONFIG dir
for image_dir in (
- scu.SCODOC_LOGOS_DIR + "/logos_" + scu.get_dept_id(),
+ scu.SCODOC_LOGOS_DIR + "/logos_" + g.scodoc_dept,
scu.SCODOC_LOGOS_DIR, # global logos
):
for suffix in scu.LOGOS_IMAGES_ALLOWED_TYPES:
diff --git a/app/scodoc/sco_saisie_notes.py b/app/scodoc/sco_saisie_notes.py
index 8f7209f2..e7890a84 100644
--- a/app/scodoc/sco_saisie_notes.py
+++ b/app/scodoc/sco_saisie_notes.py
@@ -958,7 +958,6 @@ def saisie_notes(evaluation_id, group_ids=[], REQUEST=None):
)
if form is None:
log(f"redirecting to {destination}")
- stop
return flask.redirect(destination)
H.append(form)
#
diff --git a/app/scodoc/sco_synchro_etuds.py b/app/scodoc/sco_synchro_etuds.py
index 92012a4f..c9d0bb4a 100644
--- a/app/scodoc/sco_synchro_etuds.py
+++ b/app/scodoc/sco_synchro_etuds.py
@@ -114,10 +114,11 @@ def formsemestre_synchro_etuds(
if anneeapogee:
base_url += "&anneeapogee=%s" % anneeapogee
- if anneeapogee == None: # année d'inscription par défaut
- anneeapogee = str(
- scu.annee_scolaire_debut(sem["annee_debut"], sem["mois_debut_ord"])
+ if anneeapogee is None: # année d'inscription par défaut
+ anneeapogee = scu.annee_scolaire_debut(
+ sem["annee_debut"], sem["mois_debut_ord"]
)
+ anneeapogee = str(anneeapogee)
if type(etuds) == type(""):
etuds = etuds.split(",") # vient du form de confirmation
@@ -132,7 +133,7 @@ def formsemestre_synchro_etuds(
inscrits_without_key_all,
etudsapo_ident,
) = list_synch(sem, anneeapogee=anneeapogee)
-
+ breakpoint()
if export_cat_xls:
filename = export_cat_xls
xls = build_page(
@@ -155,6 +156,7 @@ def formsemestre_synchro_etuds(
read_only=read_only,
)
else:
+ breakpoint()
etuds_set = set(etuds)
a_importer = a_importer.intersection(etuds_set)
a_desinscrire = inscrits_set - etuds_set
@@ -499,7 +501,7 @@ def list_all(etudsapo_set):
# d'interrogation par etudiant.
cnx = ndb.GetDBConnexion()
cursor = cnx.cursor(cursor_factory=ndb.ScoDocCursor)
- cursor.execute("select " + EKEY_SCO + ", etudid from identite")
+ cursor.execute("SELECT " + EKEY_SCO + ", id AS etudid FROM identite")
key2etudid = dict([(x[0], x[1]) for x in cursor.fetchall()])
all_set = set(key2etudid.keys())
@@ -654,7 +656,7 @@ def do_import_etuds_from_portal(sem, a_importer, etudsapo_ident, REQUEST):
{"etudid": etudid},
)
cursor.execute(
- "delete from identite where etudid=%(etudid)s", {"etudid": etudid}
+ "delete from identite where id=%(etudid)s", {"etudid": etudid}
)
cnx.commit()
log("do_import_etuds_from_portal: re-raising exception")
diff --git a/app/scodoc/sco_utils.py b/app/scodoc/sco_utils.py
index 853a23b1..ec6b492f 100644
--- a/app/scodoc/sco_utils.py
+++ b/app/scodoc/sco_utils.py
@@ -317,9 +317,6 @@ TYPES_ADMISSION = (TYPE_ADMISSION_DEFAULT, "APB", "APB-PC", "CEF", "Direct")
BULLETINS_VERSIONS = ("short", "selectedevals", "long")
# Support for ScoDoc7 compatibility
-def get_dept_id():
- "acronyme du dept courant"
- return g.scodoc_dept # en scodoc 8.1 #sco8
def ScoURL():
diff --git a/scotests/fakeportal/fakeportal.py b/scotests/fakeportal/fakeportal.py
index 94b2a78a..0775729c 100755
--- a/scotests/fakeportal/fakeportal.py
+++ b/scotests/fakeportal/fakeportal.py
@@ -53,6 +53,7 @@ def make_random_etape_etuds(etape, annee):
"""Liste d'etudiants d'une etape"""
random.seed(etape + annee)
nb = random.randint(0, 50)
+ print(f"generating {nb} students")
L = []
for i in range(nb):
if i % 2: