2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2018-07-23 16:22:46 +00:00
|
|
|
This module contains a validator for each :class:`~eav.models.Attribute` datatype.
|
2010-09-27 13:28:52 +00:00
|
|
|
|
|
|
|
|
A validator is a callable that takes a value and raises a ``ValidationError``
|
2018-07-27 13:13:42 +00:00
|
|
|
if it doesn't meet some criteria (see `Django validators
|
2018-07-23 16:22:46 +00:00
|
|
|
<http://docs.djangoproject.com/en/dev/ref/validators/>`_).
|
2010-09-27 13:28:52 +00:00
|
|
|
|
|
|
|
|
These validators are called by the
|
|
|
|
|
:meth:`~eav.models.Attribute.validate_value` method in the
|
|
|
|
|
:class:`~eav.models.Attribute` model.
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
|
2021-04-05 02:53:45 +00:00
|
|
|
import json
|
2017-09-05 10:01:20 +00:00
|
|
|
import datetime
|
2018-05-31 01:21:20 +00:00
|
|
|
|
|
|
|
|
from django.core.exceptions import ValidationError
|
2010-09-27 13:28:52 +00:00
|
|
|
from django.db import models
|
2021-04-23 15:19:06 +00:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2010-09-27 13:28:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_text(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* type is ``str`` or ``unicode``
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2018-06-04 21:51:30 +00:00
|
|
|
if not isinstance(value, str):
|
2010-09-27 13:28:52 +00:00
|
|
|
raise ValidationError(_(u"Must be str or unicode"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_float(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* can be cast as a ``float``
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
try:
|
|
|
|
|
float(value)
|
|
|
|
|
except ValueError:
|
|
|
|
|
raise ValidationError(_(u"Must be a float"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_int(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* can be cast as an ``int``
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
try:
|
|
|
|
|
int(value)
|
|
|
|
|
except ValueError:
|
|
|
|
|
raise ValidationError(_(u"Must be an integer"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_date(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* is an instance of ``datetime``
|
|
|
|
|
or ``date``
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2017-09-05 10:01:20 +00:00
|
|
|
if not isinstance(value, datetime.datetime) and not isinstance(value, datetime.date):
|
2010-09-27 13:28:52 +00:00
|
|
|
raise ValidationError(_(u"Must be a date or datetime"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_bool(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* type is ``bool``
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2018-06-04 21:51:30 +00:00
|
|
|
if not isinstance(value, bool):
|
2010-09-27 13:28:52 +00:00
|
|
|
raise ValidationError(_(u"Must be a boolean"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_object(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* is a saved
|
|
|
|
|
django model instance.
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
if not isinstance(value, models.Model):
|
|
|
|
|
raise ValidationError(_(u"Must be a django model object instance"))
|
2018-07-27 13:13:42 +00:00
|
|
|
|
2010-09-27 13:28:52 +00:00
|
|
|
if not value.pk:
|
|
|
|
|
raise ValidationError(_(u"Model has not been saved yet"))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_enum(value):
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
Raises ``ValidationError`` unless *value* is a saved
|
|
|
|
|
:class:`~eav.models.EnumValue` model instance.
|
2018-07-27 13:13:42 +00:00
|
|
|
"""
|
2010-09-27 13:28:52 +00:00
|
|
|
from .models import EnumValue
|
2018-07-27 13:13:42 +00:00
|
|
|
|
2019-06-20 16:14:19 +00:00
|
|
|
if isinstance(value, EnumValue) and not value.pk:
|
2010-09-27 13:28:52 +00:00
|
|
|
raise ValidationError(_(u"EnumValue has not been saved yet"))
|
2021-04-05 02:53:45 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
def validate_json(value):
|
|
|
|
|
"""
|
|
|
|
|
Raises ``ValidationError`` unless *value* can be cast as an ``json object`` (a dict)
|
|
|
|
|
"""
|
|
|
|
|
try:
|
|
|
|
|
if isinstance(value, str):
|
|
|
|
|
value = json.loads(value)
|
|
|
|
|
if not isinstance(value, dict):
|
|
|
|
|
raise ValidationError(_(u"Must be a JSON Serializable object"))
|
|
|
|
|
except ValueError:
|
|
|
|
|
raise ValidationError(_(u"Must be a JSON Serializable object"))
|