Skip to content
Snippets Groups Projects
Commit 2801e5a3 authored by Martin Mareš's avatar Martin Mareš
Browse files

Merge branch 'jk/issue-190' into 'devel'

Připsání mailu do chybové hlášky při importu.

See merge request !83
parents 61e22e2e e8013730
No related branches found
No related tags found
1 merge request!83Připsání mailu do chybové hlášky při importu.
......@@ -69,6 +69,7 @@ class Import:
gatekeeper: mo.rights.Gatekeeper
new_user_ids: List[int]
line_number: int = 0
row_name: Optional[str] = None
def __init__(self):
self.errors = []
......@@ -84,6 +85,9 @@ class Import:
def error(self, msg: str) -> Any:
if self.line_number > 0:
if self.row_name:
msg = f"Řádek {self.line_number} ({self.row_name}): {msg}"
else:
msg = f"Řádek {self.line_number}: {msg}"
self.errors.append(msg)
logger.info('Import: >> %s', msg)
......@@ -376,6 +380,12 @@ class Import:
except UnicodeDecodeError:
return False
def get_row_name(self, row: mo.csv.Row) -> Optional[str]:
if hasattr(row, 'email'):
return row.email # type: ignore
# čtení prvku potomka
return None
def generic_import(self, path: str) -> bool:
charset = self.fmt.get_charset()
if charset != 'utf-8' and self.check_utf8(path):
......@@ -396,12 +406,14 @@ class Import:
self.line_number = 2
for row in rows:
self.row_name = self.get_row_name(row)
self.cnt_rows += 1
self.import_row(row)
if len(self.errors) >= 100:
self.errors.append('Import přerušen pro příliš mnoho chyb')
break
self.line_number += 1
self.row_name = None
return len(self.errors) == 0
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment