forked from CGM_Public/pretix_original
* Improve validation of email templates * simplify SafeFormatter (skip attribute access code path altogether instead of blocklisting characters) * let SafeFormatter optionally raise on missing key * simplify placeholder validation * rename parameter * Remove unused import --------- Co-authored-by: Raphael Michel <michel@rami.io>
78 lines
3.4 KiB
Python
78 lines
3.4 KiB
Python
#
|
|
# This file is part of pretix (Community Edition).
|
|
#
|
|
# Copyright (C) 2014-2020 Raphael Michel and contributors
|
|
# Copyright (C) 2020-2021 rami.io 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: Alexey Kislitsin
|
|
#
|
|
# 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 django.core.exceptions import ValidationError
|
|
from django.core.validators import BaseValidator
|
|
from django.utils.translation import gettext_lazy as _
|
|
from i18nfield.strings import LazyI18nString
|
|
|
|
from pretix.helpers.format import format_map
|
|
|
|
|
|
class PlaceholderValidator(BaseValidator):
|
|
"""
|
|
Takes list of allowed placeholders,
|
|
validates form field by checking for placeholders,
|
|
which are not presented in taken list.
|
|
"""
|
|
|
|
error_message = _(
|
|
'There is an error with your placeholder syntax. Please check that the opening "{" and closing "}" curly '
|
|
'brackets on your placeholders match up. '
|
|
'Please note: to use literal "{" or "}", you need to double them as "{{" and "}}".'
|
|
)
|
|
|
|
def __init__(self, limit_value):
|
|
super().__init__(limit_value)
|
|
self.limit_value = limit_value
|
|
|
|
def __call__(self, value):
|
|
if isinstance(value, LazyI18nString):
|
|
for l, v in value.data.items():
|
|
self.__call__(v)
|
|
return
|
|
|
|
try:
|
|
format_map(value, {key.strip('{}'): "" for key in self.limit_value}, raise_on_missing=True)
|
|
except ValueError:
|
|
raise ValidationError(self.error_message, code='invalid_placeholder_syntax')
|
|
except KeyError as e:
|
|
raise ValidationError(
|
|
_('Invalid placeholder: {%(value)s}'),
|
|
code='invalid_placeholders',
|
|
params={'value': e.args[0]})
|
|
|
|
def clean(self, x):
|
|
return x
|