Am I thinking about this all wrong, or am I missing something that's really obvious?
Python's style guide say's less code is better (and I don't think that's subjective... It's a fact), so consider this.
To use forms for all validation means that to write a model field subclass with custom validation, you'd have to:
- Subclass models.Field
- Subclass forms.Field
- Add custom validation to your forms.Fi开发者_JAVA技巧eld subclass
- Set your custom form field as the default form field for the custom model field
- Always use a django model form if you want to perform validation
With all validation in the model you'd just have to:
- Subclass models.Field
- Add custom validation to your models.Field subclass
Now you could use your model field in an API that bypasses all use of web forms, and you'd still have validation at lowest level. If you used web forms, the validation would propagate upwards.
Is there a way to do this without having to write the Django team and wait for them to fix this error?
This sort of thing is already possible in Django's development version:
There are three steps in validating a model, and all three are called by a model’s
full_clean()
method. Most of the time, this method will be called automatically by aModelForm
. You should only need to callfull_clean()
if you plan to handle validation errors yourself.
See the docs.
e.g. (as part of your model class):
def clean(self):
from django.core.exceptions import ValidationError
# Don't allow draft entries to have a pub_date.
if self.status == 'draft' and self.pub_date is not None:
raise ValidationError('Draft entries may not have a publication date.')
# Set the pub_date for published items if it hasn't been set already.
if self.status == 'published' and self.pub_date is None:
self.pub_date = datetime.datetime.now()
The ModelForm
's validation process will call into your model's clean
method, per this:
As part of its validation process,
ModelForm
will call theclean()
method of each field on your model that has a corresponding field on your form. If you have excluded any model fields, validation will not be run on those fields. Also, your model'sclean()
method will be called before any uniqueness checks are made. See Validating objects for more information on the model'sclean()
hook.
It is already being fixed, and will be in Django 1.2.
精彩评论