mirror of
https://github.com/pretix/pretix.git
synced 2026-05-19 17:34:03 +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>
84 lines
3.5 KiB
Python
84 lines
3.5 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/>.
|
|
#
|
|
|
|
from django.dispatch import receiver
|
|
from django.utils.formats import date_format
|
|
from django.utils.translation import gettext_lazy as _, pgettext, pgettext_lazy
|
|
|
|
from ..exporter import ListExporter, OrganizerLevelExportMixin
|
|
from ..models import ReusableMedium
|
|
from ..signals import register_multievent_data_exporters
|
|
|
|
|
|
class ReusableMediaExporter(OrganizerLevelExportMixin, ListExporter):
|
|
identifier = 'reusablemedia'
|
|
verbose_name = _('Reusable media')
|
|
category = pgettext_lazy('export_category', 'Reusable media')
|
|
description = _('Download a spread sheet with the data of all reusable medias on your account.')
|
|
repeatable_read = False
|
|
|
|
@classmethod
|
|
def get_required_organizer_permission(cls) -> str:
|
|
return "organizer.reusablemedia:read"
|
|
|
|
def iterate_list(self, form_data):
|
|
media = ReusableMedium.objects.filter(
|
|
organizer=self.organizer,
|
|
).select_related(
|
|
'customer', 'linked_orderposition', 'linked_giftcard',
|
|
).order_by('created')
|
|
|
|
headers = [
|
|
pgettext('reusable_medium', 'Media type'),
|
|
pgettext('reusable_medium', 'Identifier'),
|
|
_('Active'),
|
|
_('Expiration date'),
|
|
_('Customer account'),
|
|
_('Linked ticket'),
|
|
_('Linked gift card'),
|
|
_('Notes'),
|
|
]
|
|
|
|
yield headers
|
|
yield self.ProgressSetTotal(total=media.count())
|
|
|
|
for medium in media.iterator(chunk_size=1000):
|
|
row = [
|
|
medium.type,
|
|
medium.identifier,
|
|
_('Yes') if medium.active else _('No'),
|
|
date_format(medium.expires, 'SHORT_DATETIME_FORMAT') if medium.expires else '',
|
|
medium.customer.identifier if medium.customer_id else '',
|
|
f"{medium.linked_orderposition.order.code}-{medium.linked_orderposition.positionid}" if medium.linked_orderposition_id else '',
|
|
medium.linked_giftcard.secret if medium.linked_giftcard_id else '',
|
|
medium.notes,
|
|
]
|
|
yield row
|
|
|
|
def get_filename(self):
|
|
return f'{self.organizer.slug}_media'
|
|
|
|
|
|
@receiver(register_multievent_data_exporters, dispatch_uid="multiexporter_reusablemedia")
|
|
def register_multievent_i_reusable_media_exporter(sender, **kwargs):
|
|
return ReusableMediaExporter
|