mirror of
https://github.com/pretix/pretix.git
synced 2026-05-26 18:43:59 +00:00
* Data model draft * Refactor query and assignment usages of old permissions * Backend UI * API serializer * Big string replace * Docs, tests and fixes for teams api * Update docs for device auth * Eliminate old names * Make tests pass * Use new permissions, remove inconsistencies * Add test for translations * Show plugin permissions * Add permission for seating plans * Fix plugin activation * Fix failing test * Refactor to permission groups * Update doc/api/resources/devices.rst Co-authored-by: luelista <weller@rami.io> * Update doc/api/resources/events.rst Co-authored-by: luelista <weller@rami.io> * Update src/pretix/api/serializers/organizer.py Co-authored-by: luelista <weller@rami.io> * Fix typo * Fix python version compat * Replacement after rebase * Add proper permission handling for exports * Docs for exporters * Runtime linting of permission names * Fix typos * Show export page even without orders permission * More legacy compat * Do not strongly validate before plugins are loaded * Rebase migration * Add permission for outgoing mails * Review notes * Update doc/api/resources/teams.rst Co-authored-by: Richard Schreiber <schreiber@pretix.eu> * Clean up logic around exporters * Review and failures * Fix migration leading to forbidden combination * Handle permissions on event copying * Remove print-statements * Make test clearer * Review feedback * Add AnyPermissionOf * migration safety --------- Co-authored-by: luelista <weller@rami.io> Co-authored-by: Richard Schreiber <schreiber@pretix.eu>
119 lines
4.9 KiB
Python
119 lines
4.9 KiB
Python
#
|
|
# This file is part of pretix (Community Edition).
|
|
#
|
|
# Copyright (C) 2014-2020 Raphael Michel and contributors
|
|
# Copyright (C) 2020-today pretix GmbH and contributors
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General
|
|
# Public License as published by the Free Software Foundation in version 3 of the License.
|
|
#
|
|
# ADDITIONAL TERMS APPLY: Pursuant to Section 7 of the GNU Affero General Public License, additional terms are
|
|
# applicable granting you additional permissions and placing additional restrictions on your usage of this software.
|
|
# Please refer to the pretix LICENSE file to obtain the full terms applicable to this work. If you did not receive
|
|
# this file, see <https://pretix.eu/about/en/license>.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
|
|
# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License along with this program. If not, see
|
|
# <https://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
# This file is based on an earlier version of pretix which was released under the Apache License 2.0. The full text of
|
|
# the Apache License 2.0 can be obtained at <http://www.apache.org/licenses/LICENSE-2.0>.
|
|
#
|
|
# This file may have since been changed and any changes are released under the terms of AGPLv3 as described above. A
|
|
# full history of changes and contributors is available at <https://github.com/pretix/pretix>.
|
|
#
|
|
# This file contains Apache-licensed contributions copyrighted by: Benjamin Hättasch, Tobias Kunze
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software distributed under the Apache License 2.0 is
|
|
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations under the License.
|
|
|
|
from collections import OrderedDict
|
|
|
|
from django.dispatch import receiver
|
|
from django.utils.timezone import get_current_timezone
|
|
from django.utils.translation import gettext as _, gettext_lazy, pgettext_lazy
|
|
|
|
from pretix.base.settings import PERSON_NAME_SCHEMES
|
|
|
|
from ..exporter import ListExporter, OrganizerLevelExportMixin
|
|
from ..signals import register_multievent_data_exporters
|
|
|
|
|
|
class CustomerListExporter(OrganizerLevelExportMixin, ListExporter):
|
|
identifier = 'customerlist'
|
|
verbose_name = gettext_lazy('Customer accounts')
|
|
category = pgettext_lazy('export_category', 'Customer accounts')
|
|
description = gettext_lazy('Download a spreadsheet of all currently registered customer accounts.')
|
|
|
|
@classmethod
|
|
def get_required_organizer_permission(cls) -> str:
|
|
return 'organizer.customers:write'
|
|
|
|
@property
|
|
def additional_form_fields(self):
|
|
return OrderedDict(
|
|
[]
|
|
)
|
|
|
|
def iterate_list(self, form_data):
|
|
qs = self.organizer.customers.prefetch_related('provider')
|
|
|
|
headers = [
|
|
_('Customer ID'),
|
|
_('SSO provider'),
|
|
_('External identifier'),
|
|
_('Email'),
|
|
_('Phone number'),
|
|
_('Full name'),
|
|
]
|
|
name_scheme = PERSON_NAME_SCHEMES[self.organizer.settings.name_scheme]
|
|
if name_scheme and len(name_scheme['fields']) > 1:
|
|
for k, label, w in name_scheme['fields']:
|
|
headers.append(_('Name') + ': ' + str(label))
|
|
|
|
headers += [
|
|
_('Account active'),
|
|
_('Verified email address'),
|
|
_('Last login'),
|
|
_('Registration date'),
|
|
_('Language'),
|
|
_('Notes'),
|
|
]
|
|
yield headers
|
|
|
|
tz = get_current_timezone()
|
|
for obj in qs:
|
|
row = [
|
|
obj.identifier,
|
|
obj.provider.name if obj.provider else None,
|
|
obj.external_identifier,
|
|
obj.email or '',
|
|
obj.phone or '',
|
|
obj.name,
|
|
]
|
|
if name_scheme and len(name_scheme['fields']) > 1:
|
|
for k, label, w in name_scheme['fields']:
|
|
row.append(obj.name_parts.get(k, ''))
|
|
row += [
|
|
_('Yes') if obj.is_active else _('No'),
|
|
_('Yes') if obj.is_verified else _('No'),
|
|
obj.last_login.astimezone(tz).date().strftime('%Y-%m-%d') if obj.last_login else '',
|
|
obj.date_joined.astimezone(tz).date().strftime('%Y-%m-%d') if obj.date_joined else '',
|
|
obj.get_locale_display(),
|
|
obj.notes or '',
|
|
]
|
|
yield row
|
|
|
|
def get_filename(self):
|
|
return '{}_customers'.format(self.organizer.slug)
|
|
|
|
|
|
@receiver(register_multievent_data_exporters, dispatch_uid="multiexporter_customerlist")
|
|
def register_multievent_i_customerlist_exporter(sender, **kwargs):
|
|
return CustomerListExporter
|