summaryrefslogtreecommitdiff
path: root/django/forms/models.py
diff options
context:
space:
mode:
authorAlexander Lötvall <alexander.lotvall@kognity.com>2024-06-08 12:14:46 +0200
committerSarah Boyce <42296566+sarahboyce@users.noreply.github.com>2024-06-17 12:19:26 +0200
commit38ad710aba885ad26944ff5708ce1a02a446d2d3 (patch)
tree839e0f5f2a8a5bf68dca3f335965f82292e3fd6d /django/forms/models.py
parentfa7848146738a9fe1d415ee4808664e54739eeb7 (diff)
Fixed #35483 -- Added NUL (0x00) character validation to ModelChoiceFields.
Applied the ProhibitNullCharactersValidator to ModelChoiceField and ModelMultipleChoiceField. Co-authored-by: Viktor Paripás <viktor.paripas@gmail.com> Co-authored-by: Vasyl Dizhak <vasyl@dizhak.com> Co-authored-by: Arthur Vasconcelos <vasconcelos.arthur@gmail.com>
Diffstat (limited to 'django/forms/models.py')
-rw-r--r--django/forms/models.py7
1 files changed, 7 insertions, 0 deletions
diff --git a/django/forms/models.py b/django/forms/models.py
index 09be448984..8084e16c8d 100644
--- a/django/forms/models.py
+++ b/django/forms/models.py
@@ -11,6 +11,7 @@ from django.core.exceptions import (
ImproperlyConfigured,
ValidationError,
)
+from django.core.validators import ProhibitNullCharactersValidator
from django.db.models.utils import AltersData
from django.forms.fields import ChoiceField, Field
from django.forms.forms import BaseForm, DeclarativeFieldsMetaclass
@@ -1487,6 +1488,10 @@ class ModelChoiceField(ChoiceField):
self.limit_choices_to = limit_choices_to # limit the queryset later.
self.to_field_name = to_field_name
+ def validate_no_null_characters(self, value):
+ non_null_character_validator = ProhibitNullCharactersValidator()
+ return non_null_character_validator(value)
+
def get_limit_choices_to(self):
"""
Return ``limit_choices_to`` for this form field.
@@ -1551,6 +1556,7 @@ class ModelChoiceField(ChoiceField):
def to_python(self, value):
if value in self.empty_values:
return None
+ self.validate_no_null_characters(value)
try:
key = self.to_field_name or "pk"
if isinstance(value, self.queryset.model):
@@ -1631,6 +1637,7 @@ class ModelMultipleChoiceField(ModelChoiceField):
code="invalid_list",
)
for pk in value:
+ self.validate_no_null_characters(pk)
try:
self.queryset.filter(**{key: pk})
except (ValueError, TypeError):