Skip to content
Snippets Groups Projects
Commit a24c8602 authored by Jiří Kalvoda's avatar Jiří Kalvoda
Browse files

Přesunutí obecných validací z mo.imports do mo.users

parent 3eb04644
No related branches found
No related tags found
1 merge request!89Přidán formulář na editaci registrace do ročníku
...@@ -149,21 +149,16 @@ class Import: ...@@ -149,21 +149,16 @@ class Import:
return place return place
def parse_school(self, kod: str) -> Optional[db.Place]: def parse_school(self, kod: str) -> Optional[db.Place]:
if kod == "":
return self.error('Škola je povinná')
if kod in self.school_place_cache: if kod in self.school_place_cache:
return self.school_place_cache[kod] return self.school_place_cache[kod]
place = db.get_place_by_code(kod, fetch_school=True) try:
if not place: place = mo.users.validate_and_find_school(kod)
return self.error(f'Škola s kódem "{kod}" nenalezena'+ except mo.CheckError as e:
('. Nechybí vám # na začátku?' if re.fullmatch(r'\d+', kod) else '')) return self.error(str(e))
if place.type != db.PlaceType.school:
return self.error(f'Kód školy "{kod}" neodpovídá škole')
self.school_place_cache[kod] = place self.school_place_cache[kod] = place
return place return place
def parse_grade(self, rocnik: str, school: Optional[db.School]) -> Optional[str]: def parse_grade(self, rocnik: str, school: Optional[db.School]) -> Optional[str]:
...@@ -174,16 +169,10 @@ class Import: ...@@ -174,16 +169,10 @@ class Import:
# lidé připisují všechny možné i nemožné znaky, které vypadají jako apostrof :) # lidé připisují všechny možné i nemožné znaky, které vypadají jako apostrof :)
rocnik = re.sub('[\'"\u00b4\u2019]', "", rocnik) rocnik = re.sub('[\'"\u00b4\u2019]', "", rocnik)
if (not re.fullmatch(r'\d(/\d)?', rocnik)): try:
return self.error(f'Ročník má neplatný formát, musí to být buď číslice, nebo číslice/číslice') return mo.users.normalize_grade(rocnik, school)
except mo.CheckError as e:
if (not school.is_zs and re.fullmatch(r'\d', rocnik)): return self.error(str(e))
return self.error(f'Ročník pro střední školu ({school.place.name}) zapisujte ve formátu číslice/číslice')
if (not school.is_ss and re.fullmatch(r'\d/\d', rocnik)):
return self.error(f'Ročník pro základní školu ({school.place.name}) zapisujte jako číslici 1–9')
return rocnik
def parse_born(self, rok: str) -> Optional[int]: def parse_born(self, rok: str) -> Optional[int]:
if not re.fullmatch(r'\d{4}', rok): if not re.fullmatch(r'\d{4}', rok):
......
...@@ -12,6 +12,33 @@ import mo.db as db ...@@ -12,6 +12,33 @@ import mo.db as db
import mo.util import mo.util
import mo.tokens import mo.tokens
def normalize_grade(rocnik:str, school:db.School) -> str:
""" Aktuálně provádí jen kontrolu formátu. """
if not re.fullmatch(r'\d(/\d)?', rocnik):
raise mo.CheckError(f'Ročník má neplatný formát, musí to být buď číslice, nebo číslice/číslice')
if not school.is_zs and re.fullmatch(r'\d', rocnik):
raise mo.CheckError(f'Ročník pro střední školu ({school.place.name}) zapisujte ve formátu číslice/číslice')
if not school.is_ss and re.fullmatch(r'\d/\d', rocnik):
raise mo.CheckError(f'Ročník pro základní školu ({school.place.name}) zapisujte jako číslici 1–9')
return rocnik
def validate_and_find_school(kod:str) -> db.Place:
if kod == "":
raise mo.CheckError('Škola je povinná')
place = db.get_place_by_code(kod, fetch_school=True)
if not place:
raise mo.CheckError(f'Škola s kódem "{kod}" nenalezena'+
('. Nechybí vám # na začátku?' if re.fullmatch(r'\d+', kod) else ''))
if place.type != db.PlaceType.school:
raise mo.CheckError(f'Kód školy "{kod}" neodpovídá škole')
return place
def normalize_email(addr: str) -> str: def normalize_email(addr: str) -> str:
if not re.fullmatch(r'.+@.+', addr): if not re.fullmatch(r'.+@.+', addr):
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment