mirror of
https://gitlab.crans.org/bde/nk20
synced 2024-11-27 19:03:00 +00:00
a6b479db19
- /apps/activity/api/serializers.py - /apps/activity/api/urls.py - /apps/activity/api/views.py - /apps/activity/tests/test_activities.py - /apps/activity/__init__.py - /apps/activity/admin.py - /apps/activity/apps.py - /apps/activity/forms.py - /apps/activity/tables.py - /apps/activity/urls.py - /apps/activity/views.py - /apps/api/__init__.py - /apps/api/apps.py - /apps/api/serializers.py - /apps/api/tests.py - /apps/api/urls.py - /apps/api/views.py - /apps/api/viewsets.py - /apps/logs/signals.py - /apps/logs/apps.py - /apps/logs/__init__.py - /apps/logs/api/serializers.py - /apps/logs/api/urls.py - /apps/logs/api/views.py - /apps/member/api/serializers.py - /apps/member/api/urls.py - /apps/member/api/views.py - /apps/member/templatetags/memberinfo.py - /apps/member/__init__.py - /apps/member/admin.py - /apps/member/apps.py - /apps/member/auth.py - /apps/member/forms.py - /apps/member/hashers.py - /apps/member/signals.py - /apps/member/tables.py - /apps/member/urls.py - /apps/member/views.py - /apps/note/api/serializers.py - /apps/note/api/urls.py - /apps/note/api/views.py - /apps/note/models/__init__.py - /apps/note/static/note/js/consos.js - /apps/note/templates/note/mails/negative_balance.txt - /apps/note/templatetags/getenv.py - /apps/note/templatetags/pretty_money.py - /apps/note/tests/test_transactions.py - /apps/note/__init__.py - /apps/note/admin.py - /apps/note/apps.py - /apps/note/forms.py - /apps/note/signals.py - /apps/note/tables.py - /apps/note/urls.py - /apps/note/views.py - /apps/permission/api/serializers.py - /apps/permission/api/urls.py - /apps/permission/api/views.py - /apps/permission/templatetags/perms.py - /apps/permission/tests/test_oauth2.py - /apps/permission/tests/test_permission_denied.py - /apps/permission/tests/test_permission_queries.py - /apps/permission/tests/test_rights_page.py - /apps/permission/__init__.py - /apps/permission/admin.py - /apps/permission/backends.py - /apps/permission/apps.py - /apps/permission/decorators.py - /apps/permission/permissions.py - /apps/permission/scopes.py - /apps/permission/signals.py - /apps/permission/tables.py - /apps/permission/urls.py - /apps/permission/views.py - /apps/registration/tests/test_registration.py - /apps/registration/__init__.py - /apps/registration/apps.py - /apps/registration/forms.py - /apps/registration/tables.py - /apps/registration/tokens.py - /apps/registration/urls.py - /apps/registration/views.py - /apps/treasury/api/serializers.py - /apps/treasury/api/urls.py - /apps/treasury/api/views.py - /apps/treasury/templatetags/escape_tex.py - /apps/treasury/tests/test_treasury.py - /apps/treasury/__init__.py - /apps/treasury/admin.py - /apps/treasury/apps.py - /apps/treasury/forms.py - /apps/treasury/signals.py - /apps/treasury/tables.py - /apps/treasury/urls.py - /apps/treasury/views.py - /apps/wei/api/serializers.py - /apps/wei/api/urls.py - /apps/wei/api/views.py - /apps/wei/forms/surveys/__init__.py - /apps/wei/forms/surveys/base.py - /apps/wei/forms/surveys/wei2021.py - /apps/wei/forms/surveys/wei2022.py - /apps/wei/forms/surveys/wei2023.py - /apps/wei/forms/__init__.py - /apps/wei/forms/registration.py - /apps/wei/management/commands/export_wei_registrations.py - /apps/wei/management/commands/import_scores.py - /apps/wei/management/commands/wei_algorithm.py - /apps/wei/templates/wei/weilist_sample.tex - /apps/wei/tests/test_wei_algorithm_2021.py - /apps/wei/tests/test_wei_algorithm_2022.py - /apps/wei/tests/test_wei_algorithm_2023.py - /apps/wei/tests/test_wei_registration.py - /apps/wei/__init__.py - /apps/wei/admin.py - /apps/wei/apps.py - /apps/wei/tables.py - /apps/wei/urls.py - /apps/wei/views.py - /note_kfet/settings/__init__.py - /note_kfet/settings/base.py - /note_kfet/settings/development.py - /note_kfet/settings/secrets_example.py - /note_kfet/static/js/base.js - /note_kfet/admin.py - /note_kfet/inputs.py - /note_kfet/middlewares.py - /note_kfet/urls.py - /note_kfet/views.py - /note_kfet/wsgi.py - /entrypoint.sh
89 lines
3.6 KiB
Python
89 lines
3.6 KiB
Python
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
from django.core.management import BaseCommand, CommandError
|
|
from django.db.models import Q
|
|
from django.db.models.functions import Lower
|
|
from wei.models import WEIClub, Bus, BusTeam, WEIMembership
|
|
|
|
|
|
class Command(BaseCommand):
|
|
help = "Export WEI registrations."
|
|
|
|
def add_arguments(self, parser):
|
|
parser.add_argument('--bus', '-b', choices=[bus.name for bus in Bus.objects.all()], type=str, default=None,
|
|
help='Filter by bus')
|
|
parser.add_argument('--team', '-t', choices=[team.name for team in BusTeam.objects.all()], type=str,
|
|
default=None, help='Filter by team. Type "none" if you want to select the members '
|
|
+ 'that are not in a team.')
|
|
parser.add_argument('--year', '-y', type=int, default=None,
|
|
help='Select the year of the concerned WEI. Default: last year')
|
|
parser.add_argument('--sep', type=str, default='|',
|
|
help='Select the CSV separator.')
|
|
|
|
def handle(self, *args, **options):
|
|
year = options["year"]
|
|
if year:
|
|
try:
|
|
wei = WEIClub.objects.get(year=year)
|
|
except WEIClub.DoesNotExist:
|
|
raise CommandError("The WEI of year {:d} does not exist.".format(year,))
|
|
else:
|
|
wei = WEIClub.objects.order_by('-year').first()
|
|
|
|
bus = options["bus"]
|
|
if bus:
|
|
try:
|
|
bus = Bus.objects.filter(wei=wei).get(name=bus)
|
|
except Bus.DoesNotExist:
|
|
raise CommandError("The bus {} does not exist or does not belong to the WEI {}.".format(bus, wei.name,))
|
|
|
|
team = options["team"]
|
|
if team:
|
|
if team.lower() == "none":
|
|
team = 0
|
|
else:
|
|
try:
|
|
team = BusTeam.objects.filter(Q(bus=bus) | Q(wei=wei)).get(name=team)
|
|
bus = team.bus
|
|
except BusTeam.DoesNotExist:
|
|
raise CommandError("The bus {} does not exist or does not belong to the bus {} neither the wei {}."
|
|
.format(team, bus.name if bus else "<None>", wei.name,))
|
|
|
|
qs = WEIMembership.objects
|
|
qs = qs.filter(club=wei).order_by(
|
|
Lower('bus__name'),
|
|
Lower('team__name'),
|
|
'user__profile__promotion',
|
|
Lower('user__last_name'),
|
|
Lower('user__first_name'),
|
|
).distinct()
|
|
|
|
if bus:
|
|
qs = qs.filter(bus=bus)
|
|
|
|
if team is not None:
|
|
qs = qs.filter(team=team if team else None)
|
|
|
|
sep = options["sep"]
|
|
|
|
self.stdout.write("Nom|Prénom|Date de naissance|Genre|Département|Année|Section|Bus|Équipe|Rôles"
|
|
.replace(sep, sep))
|
|
|
|
for membership in qs.all():
|
|
user = membership.user
|
|
registration = membership.registration
|
|
bus = membership.bus
|
|
team = membership.team
|
|
s = user.last_name
|
|
s += sep + user.first_name
|
|
s += sep + str(registration.birth_date)
|
|
s += sep + registration.get_gender_display()
|
|
s += sep + user.profile.get_department_display()
|
|
s += sep + str(user.profile.ens_year) + "A"
|
|
s += sep + user.profile.section_generated
|
|
s += sep + bus.name
|
|
s += sep + (team.name if team else "--")
|
|
s += sep + ", ".join(role.name for role in membership.roles.filter(~Q(name="Adhérent WEI")).all())
|
|
self.stdout.write(s)
|