Ajout strip nom/prenom utilisateurs + option TrivialFormulator
This commit is contained in:
parent
da472668b5
commit
2efdfa16c6
@ -296,13 +296,18 @@ class TF(object):
|
|||||||
if not allow_null:
|
if not allow_null:
|
||||||
if val is None or (isinstance(val, str) and not val.strip()):
|
if val is None or (isinstance(val, str) and not val.strip()):
|
||||||
msg.append(
|
msg.append(
|
||||||
"Le champ '%s' doit être renseigné" % descr.get("title", field)
|
f"Le champ '{descr.get('title', field)}' doit être renseigné"
|
||||||
)
|
)
|
||||||
ok = 0
|
ok = 0
|
||||||
elif val == "" or val == None:
|
elif val in ("", None):
|
||||||
continue # allowed empty field, skip
|
continue # allowed empty field, skip
|
||||||
# type
|
# type
|
||||||
typ = descr.get("type", "string")
|
typ = descr.get("type", "text")
|
||||||
|
# Option pour striper les chaînes
|
||||||
|
if isinstance(val, str) and typ == "text" and descr.get("strip", False):
|
||||||
|
val = val.strip()
|
||||||
|
self.values[field] = val
|
||||||
|
|
||||||
if val != "" and val is not None:
|
if val != "" and val is not None:
|
||||||
# check only non-null values
|
# check only non-null values
|
||||||
if typ[:3] == "int":
|
if typ[:3] == "int":
|
||||||
@ -311,24 +316,22 @@ class TF(object):
|
|||||||
self.values[field] = val
|
self.values[field] = val
|
||||||
except ValueError:
|
except ValueError:
|
||||||
msg.append(
|
msg.append(
|
||||||
"La valeur du champ '%s' doit être un nombre entier" % field
|
f"La valeur du champ '{field}' doit être un nombre entier"
|
||||||
)
|
)
|
||||||
ok = 0
|
ok = 0
|
||||||
elif typ == "float" or typ == "real":
|
elif typ in ("float", "real"):
|
||||||
self.values[field] = self.values[field].replace(",", ".")
|
self.values[field] = self.values[field].replace(",", ".")
|
||||||
try:
|
try:
|
||||||
val = float(val.replace(",", ".")) # allow ,
|
val = float(val.replace(",", ".")) # allow ,
|
||||||
self.values[field] = val
|
self.values[field] = val
|
||||||
except ValueError:
|
except ValueError:
|
||||||
msg.append(
|
msg.append(f"La valeur du champ {field}' doit être un nombre")
|
||||||
"La valeur du champ '%s' doit être un nombre" % field
|
|
||||||
)
|
|
||||||
ok = 0
|
ok = 0
|
||||||
if (
|
if (
|
||||||
ok
|
ok
|
||||||
and (typ[:3] == "int" or typ == "float" or typ == "real")
|
and (typ[:3] == "int" or typ == "float" or typ == "real")
|
||||||
and val != ""
|
and val != ""
|
||||||
and val != None
|
and val is not None
|
||||||
):
|
):
|
||||||
if "min_value" in descr and self.values[field] < descr["min_value"]:
|
if "min_value" in descr and self.values[field] < descr["min_value"]:
|
||||||
msg.append(
|
msg.append(
|
||||||
@ -343,12 +346,12 @@ class TF(object):
|
|||||||
)
|
)
|
||||||
ok = 0
|
ok = 0
|
||||||
if typ[:3] == "int":
|
if typ[:3] == "int":
|
||||||
if not (scu.DB_MIN_INT <= self.values[field] <= scu.DB_MAX_INT):
|
if not scu.DB_MIN_INT <= self.values[field] <= scu.DB_MAX_INT:
|
||||||
msg.append(
|
msg.append(
|
||||||
f"Le champ '{field}' est a une valeur hors limite"
|
f"Le champ '{field}' est a une valeur hors limite"
|
||||||
)
|
)
|
||||||
ok = 0
|
ok = 0
|
||||||
elif typ == "float" or typ == "real":
|
elif typ in ("float", "real"):
|
||||||
if not (
|
if not (
|
||||||
scu.DB_MIN_FLOAT <= self.values[field] <= scu.DB_MAX_FLOAT
|
scu.DB_MIN_FLOAT <= self.values[field] <= scu.DB_MAX_FLOAT
|
||||||
):
|
):
|
||||||
@ -356,7 +359,7 @@ class TF(object):
|
|||||||
f"Le champ '{field}' est a une valeur hors limite"
|
f"Le champ '{field}' est a une valeur hors limite"
|
||||||
)
|
)
|
||||||
ok = 0
|
ok = 0
|
||||||
if ok and (typ[:3] == "str") and "max_length" in descr:
|
if ok and "max_length" in descr and isinstance(self.values[field], str):
|
||||||
if len(self.values[field]) > descr["max_length"]:
|
if len(self.values[field]) > descr["max_length"]:
|
||||||
msg.append(
|
msg.append(
|
||||||
"Le champ '%s' est trop long (max %d caractères)"
|
"Le champ '%s' est trop long (max %d caractères)"
|
||||||
|
@ -1319,19 +1319,18 @@ def format_nomprenom(etud, reverse=False):
|
|||||||
return " ".join([x for x in fs if x])
|
return " ".join([x for x in fs if x])
|
||||||
|
|
||||||
|
|
||||||
def format_nom(s, uppercase=True):
|
def format_nom(s: str, uppercase=True) -> str:
|
||||||
"Formatte le nom"
|
"Formatte le nom"
|
||||||
if not s:
|
if not s:
|
||||||
return ""
|
return ""
|
||||||
if uppercase:
|
if uppercase:
|
||||||
return s.upper()
|
return (s.upper()).strip()
|
||||||
else:
|
return format_prenom(s)
|
||||||
return format_prenom(s)
|
|
||||||
|
|
||||||
|
|
||||||
def format_prenom(s):
|
def format_prenom(s: str) -> str:
|
||||||
"""Formatte prenom etudiant pour affichage
|
"""Formatte prenom etudiant pour affichage
|
||||||
DEPRECATED: utiliser Identite.prenom_str
|
Pour les étudiants, utiliser Identite.prenom_str
|
||||||
"""
|
"""
|
||||||
if not s:
|
if not s:
|
||||||
return ""
|
return ""
|
||||||
@ -1340,7 +1339,7 @@ def format_prenom(s):
|
|||||||
for frag in frags:
|
for frag in frags:
|
||||||
fs = frag.split("-")
|
fs = frag.split("-")
|
||||||
r.append("-".join([x.lower().capitalize() for x in fs]))
|
r.append("-".join([x.lower().capitalize() for x in fs]))
|
||||||
return " ".join(r)
|
return (" ".join(r)).strip()
|
||||||
|
|
||||||
|
|
||||||
def format_telephone(n: str | None) -> str:
|
def format_telephone(n: str | None) -> str:
|
||||||
|
@ -307,6 +307,7 @@ def create_user_form(user_name=None, edit=0, all_roles=True):
|
|||||||
"size": 20,
|
"size": 20,
|
||||||
"allow_null": False,
|
"allow_null": False,
|
||||||
"readonly": edit_only_roles,
|
"readonly": edit_only_roles,
|
||||||
|
"strip": True,
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
@ -316,6 +317,7 @@ def create_user_form(user_name=None, edit=0, all_roles=True):
|
|||||||
"size": 20,
|
"size": 20,
|
||||||
"allow_null": False,
|
"allow_null": False,
|
||||||
"readonly": edit_only_roles,
|
"readonly": edit_only_roles,
|
||||||
|
"strip": True,
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
@ -395,6 +397,7 @@ def create_user_form(user_name=None, edit=0, all_roles=True):
|
|||||||
"size": 36,
|
"size": 36,
|
||||||
"allow_null": False,
|
"allow_null": False,
|
||||||
"readonly": edit_only_roles,
|
"readonly": edit_only_roles,
|
||||||
|
"strip": True,
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
@ -455,6 +458,7 @@ def create_user_form(user_name=None, edit=0, all_roles=True):
|
|||||||
else ""
|
else ""
|
||||||
),
|
),
|
||||||
"size": 36,
|
"size": 36,
|
||||||
|
"strip": True,
|
||||||
"allow_null": not require_email_institutionnel,
|
"allow_null": not require_email_institutionnel,
|
||||||
"readonly": edit_only_roles,
|
"readonly": edit_only_roles,
|
||||||
},
|
},
|
||||||
@ -809,11 +813,13 @@ def create_user_form(user_name=None, edit=0, all_roles=True):
|
|||||||
db.session.add(the_user)
|
db.session.add(the_user)
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
# envoi éventuel d'un message
|
# envoi éventuel d'un message
|
||||||
if mode == Mode.WELCOME_AND_CHANGE_PASSWORD or mode == Mode.WELCOME_ONLY:
|
if mode in (Mode.WELCOME_AND_CHANGE_PASSWORD, Mode.WELCOME_ONLY):
|
||||||
if mode == Mode.WELCOME_AND_CHANGE_PASSWORD:
|
token = (
|
||||||
token = the_user.get_reset_password_token()
|
the_user.get_reset_password_token()
|
||||||
else:
|
if mode == Mode.WELCOME_AND_CHANGE_PASSWORD
|
||||||
token = None
|
else None
|
||||||
|
)
|
||||||
|
|
||||||
cas_force = ScoDocSiteConfig.get("cas_force")
|
cas_force = ScoDocSiteConfig.get("cas_force")
|
||||||
# Le from doit utiliser la préférence du département de l'utilisateur
|
# Le from doit utiliser la préférence du département de l'utilisateur
|
||||||
email.send_email(
|
email.send_email(
|
||||||
@ -1008,7 +1014,7 @@ def get_user_list_xml(dept=None, start="", limit=25):
|
|||||||
userlist = [
|
userlist = [
|
||||||
user
|
user
|
||||||
for user in userlist
|
for user in userlist
|
||||||
if scu.suppress_accents((user.nom or "").lower()).startswith(start)
|
if scu.suppress_accents((user.nom or "").strip().lower()).startswith(start)
|
||||||
]
|
]
|
||||||
doc = ElementTree.Element("results")
|
doc = ElementTree.Element("results")
|
||||||
for user in userlist[:limit]:
|
for user in userlist[:limit]:
|
||||||
|
Loading…
Reference in New Issue
Block a user