chore(members): move csv import to separate file
parent
0eedc3ecf9
commit
7647f93c83
@ -0,0 +1,227 @@
|
|||||||
|
from .models import *
|
||||||
|
import re
|
||||||
|
import csv
|
||||||
|
|
||||||
|
|
||||||
|
def import_from_csv(path, omit_groupless=True):
|
||||||
|
with open(path, encoding='ISO-8859-1') as csvfile:
|
||||||
|
reader = csv.DictReader(csvfile, delimiter=';')
|
||||||
|
rows = list(reader)
|
||||||
|
|
||||||
|
def transform_field(key, value):
|
||||||
|
new_key = CLUBDESK_TO_KOMPASS[key]
|
||||||
|
if isinstance(new_key, str):
|
||||||
|
return (new_key, value)
|
||||||
|
else:
|
||||||
|
return (new_key[0], new_key[1](value))
|
||||||
|
|
||||||
|
def transform_row(row):
|
||||||
|
kwargs = dict([ transform_field(k, v) for k, v in row.items() if k in CLUBDESK_TO_KOMPASS ])
|
||||||
|
kwargs_filtered = { k : v for k, v in kwargs.items() if k not in ['group', 'last_training', 'has_fundamental_training', 'special_training', 'phone_number_private', 'phone_number_parents'] }
|
||||||
|
if not kwargs['group'] and omit_groupless:
|
||||||
|
# if member does not have a group, skip them
|
||||||
|
return
|
||||||
|
mem = Member(**kwargs_filtered)
|
||||||
|
mem.save()
|
||||||
|
mem.group.set([group for group, is_jl in kwargs['group']])
|
||||||
|
for group, is_jl in kwargs['group']:
|
||||||
|
if is_jl:
|
||||||
|
group.leiters.add(mem)
|
||||||
|
|
||||||
|
if kwargs['has_fundamental_training']:
|
||||||
|
try:
|
||||||
|
ga_cat = TrainingCategory.objects.get(name='Grundausbildung')
|
||||||
|
except TrainingCategory.DoesNotExist:
|
||||||
|
ga_cat = TrainingCategory(name='Grundausbildung', permission_needed=True)
|
||||||
|
ga_cat.save()
|
||||||
|
ga_training = MemberTraining(member=mem, title='Grundausbildung', date=None, category=ga_cat,
|
||||||
|
participated=True, passed=True)
|
||||||
|
ga_training.save()
|
||||||
|
|
||||||
|
if kwargs['last_training'] is not None:
|
||||||
|
try:
|
||||||
|
cat = TrainingCategory.objects.get(name='Fortbildung')
|
||||||
|
except TrainingCategory.DoesNotExist:
|
||||||
|
cat = TrainingCategory(name='Fortbildung', permission_needed=False)
|
||||||
|
cat.save()
|
||||||
|
training = MemberTraining(member=mem, title='Unbekannt', date=kwargs['last_training'], category=cat,
|
||||||
|
participated=True, passed=True)
|
||||||
|
training.save()
|
||||||
|
|
||||||
|
if kwargs['special_training'] != '':
|
||||||
|
try:
|
||||||
|
cat = TrainingCategory.objects.get(name='Sonstiges')
|
||||||
|
except TrainingCategory.DoesNotExist:
|
||||||
|
cat = TrainingCategory(name='Sonstiges', permission_needed=False)
|
||||||
|
cat.save()
|
||||||
|
training = MemberTraining(member=mem, title=kwargs['special_training'], date=None, category=cat,
|
||||||
|
participated=True, passed=True)
|
||||||
|
training.save()
|
||||||
|
|
||||||
|
if kwargs['phone_number_private'] != '':
|
||||||
|
prefix = '\n' if mem.comments else ''
|
||||||
|
mem.comments += prefix + 'Telefon (Privat): ' + kwargs['phone_number_private']
|
||||||
|
mem.save()
|
||||||
|
|
||||||
|
if kwargs['phone_number_parents'] != '':
|
||||||
|
prefix = '\n' if mem.comments else ''
|
||||||
|
mem.comments += prefix + 'Telefon (Eltern): ' + kwargs['phone_number_parents']
|
||||||
|
mem.save()
|
||||||
|
|
||||||
|
for row in rows:
|
||||||
|
transform_row(row)
|
||||||
|
|
||||||
|
|
||||||
|
def parse_group(value):
|
||||||
|
groups_raw = re.split(',', value)
|
||||||
|
|
||||||
|
# need to determine if member is youth leader
|
||||||
|
roles = set()
|
||||||
|
def extract_group_name_and_role(raw):
|
||||||
|
obj = re.search('^(.*?)(?: \((.*)\))?$', raw)
|
||||||
|
is_jl = False
|
||||||
|
if obj.group(2) is not None:
|
||||||
|
roles.add(obj.group(2).strip())
|
||||||
|
if obj.group(2) == 'Jugendleiter*in':
|
||||||
|
is_jl = True
|
||||||
|
return (obj.group(1).strip(), is_jl)
|
||||||
|
|
||||||
|
group_names = [extract_group_name_and_role(raw) for raw in groups_raw if raw != '']
|
||||||
|
|
||||||
|
if "Jugendleiter*in" in roles:
|
||||||
|
group_names.append(('Jugendleiter', False))
|
||||||
|
groups = []
|
||||||
|
for group_name, is_jl in group_names:
|
||||||
|
try:
|
||||||
|
group = Group.objects.get(name=group_name)
|
||||||
|
except Group.DoesNotExist:
|
||||||
|
group = Group(name=group_name)
|
||||||
|
group.save()
|
||||||
|
groups.append((group, is_jl))
|
||||||
|
return groups
|
||||||
|
|
||||||
|
|
||||||
|
def parse_date(value):
|
||||||
|
if value == '':
|
||||||
|
return None
|
||||||
|
return datetime.strptime(value, '%d.%m.%Y').date()
|
||||||
|
|
||||||
|
|
||||||
|
def parse_datetime(value):
|
||||||
|
tz = pytz.timezone('Europe/Berlin')
|
||||||
|
if value == '':
|
||||||
|
return timezone.now()
|
||||||
|
return tz.localize(datetime.strptime(value, '%d.%m.%Y %H:%M:%S'))
|
||||||
|
|
||||||
|
|
||||||
|
def parse_status(value):
|
||||||
|
return value != "Passivmitglied"
|
||||||
|
|
||||||
|
|
||||||
|
def parse_boolean(value):
|
||||||
|
return value.lower() == "ja"
|
||||||
|
|
||||||
|
|
||||||
|
def parse_nullable_boolean(value):
|
||||||
|
if value == '':
|
||||||
|
return None
|
||||||
|
else:
|
||||||
|
return value.lower() == "ja"
|
||||||
|
|
||||||
|
|
||||||
|
def parse_gender(value):
|
||||||
|
if value == 'männlich':
|
||||||
|
return MALE
|
||||||
|
elif value == 'weiblich':
|
||||||
|
return FEMALE
|
||||||
|
else:
|
||||||
|
return DIVERSE
|
||||||
|
|
||||||
|
|
||||||
|
def parse_can_swim(value):
|
||||||
|
return True if len(value) > 0 else False
|
||||||
|
|
||||||
|
|
||||||
|
CLUBDESK_TO_KOMPASS = {
|
||||||
|
'Nachname': 'lastname',
|
||||||
|
'Vorname': 'prename',
|
||||||
|
'Adresse': 'street',
|
||||||
|
'PLZ': 'plz',
|
||||||
|
'Ort': 'town',
|
||||||
|
'Telefon Privat': 'phone_number_private',
|
||||||
|
'Telefon Mobil': 'phone_number',
|
||||||
|
'Adress-Zusatz': 'address_extra',
|
||||||
|
'Land': 'country',
|
||||||
|
'E-Mail': 'email',
|
||||||
|
'E-Mail Alternativ': 'alternative_email',
|
||||||
|
'Status': ('active', parse_status),
|
||||||
|
'Eintritt': ('join_date', parse_date),
|
||||||
|
'Austritt': ('leave_date', parse_date),
|
||||||
|
'Geburtsdatum': ('birth_date', parse_date),
|
||||||
|
'Geburtstag': ('birth_date', parse_date),
|
||||||
|
'Geschlecht': ('gender', parse_gender),
|
||||||
|
'Bemerkungen': 'comments',
|
||||||
|
'IBAN': 'iban',
|
||||||
|
'Vorlage Führungszeugnis': ('good_conduct_certificate_presented_date', parse_date),
|
||||||
|
'Letzte Fortbildung': ('last_training', parse_date),
|
||||||
|
'Grundausbildung': ('has_fundamental_training', parse_boolean),
|
||||||
|
'Besondere Ausbildung': 'special_training',
|
||||||
|
'[Gruppen]' : ('group', parse_group),
|
||||||
|
'Schlüssel': ('has_key', parse_boolean),
|
||||||
|
'Freikarte': ('has_free_ticket_gym', parse_boolean),
|
||||||
|
'DAV Ausweis Nr.': 'dav_badge_no',
|
||||||
|
'Schwimmabzeichen': ('swimming_badge', parse_can_swim),
|
||||||
|
'Kletterschein': 'climbing_badge',
|
||||||
|
'Felserfahrung': 'alpine_experience',
|
||||||
|
'Allergien': 'allergies',
|
||||||
|
'Medikamente': 'medication',
|
||||||
|
'Tetanusimpfung': 'tetanus_vaccination',
|
||||||
|
'Fotoerlaubnis': ('photos_may_be_taken', parse_boolean),
|
||||||
|
'Erziehungsberechtigte': 'legal_guardians',
|
||||||
|
'Darf sich allein von der Gruppenstunde abmelden':
|
||||||
|
('may_cancel_appointment_independently', parse_nullable_boolean),
|
||||||
|
'Mobil Eltern': 'phone_number_parents',
|
||||||
|
'Sonstiges': 'application_text',
|
||||||
|
'Erhalten am': ('application_date', parse_datetime),
|
||||||
|
'Angeschrieben von': 'contacted_by',
|
||||||
|
'Angeschrieben von ': 'contacted_by',
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def import_from_csv_waitinglist(path):
|
||||||
|
with open(path, encoding='ISO-8859-1') as csvfile:
|
||||||
|
reader = csv.DictReader(csvfile, delimiter=';')
|
||||||
|
rows = list(reader)
|
||||||
|
|
||||||
|
def transform_field(key, value):
|
||||||
|
new_key = CLUBDESK_TO_KOMPASS[key]
|
||||||
|
if isinstance(new_key, str):
|
||||||
|
return (new_key, value)
|
||||||
|
else:
|
||||||
|
return (new_key[0], new_key[1](value))
|
||||||
|
|
||||||
|
def transform_field(key, value):
|
||||||
|
new_key = CLUBDESK_TO_KOMPASS[key]
|
||||||
|
if isinstance(new_key, str):
|
||||||
|
return (new_key, value)
|
||||||
|
else:
|
||||||
|
return (new_key[0], new_key[1](value))
|
||||||
|
|
||||||
|
def transform_row(row):
|
||||||
|
kwargs = dict([ transform_field(k, v) for k, v in row.items() if k in CLUBDESK_TO_KOMPASS ])
|
||||||
|
kwargs_filtered = { k : v for k, v in kwargs.items() if k in ['prename', 'lastname', 'email', 'birth_date', 'application_text', 'application_date'] }
|
||||||
|
|
||||||
|
mem = MemberWaitingList(gender=DIVERSE, **kwargs_filtered)
|
||||||
|
mem.save()
|
||||||
|
|
||||||
|
if kwargs['contacted_by']:
|
||||||
|
group_name = kwargs['contacted_by']
|
||||||
|
try:
|
||||||
|
group = Group.objects.get(name=group_name)
|
||||||
|
invitation = InvitationToGroup(group=group, waiter=mem)
|
||||||
|
invitation.save()
|
||||||
|
except Group.DoesNotExist:
|
||||||
|
pass
|
||||||
|
|
||||||
|
for row in rows:
|
||||||
|
transform_row(row)
|
||||||
Loading…
Reference in New Issue