Бастиан, я объясняю вам мой шаблон кода, надеюсь, это вам поможет:
Начиная с django 1.2, он может написать код проверки на модели. Когда мы работаем с модельными формами, instance.full_clean () вызывается при проверке формы.
В каждой модели я перезаписываю метод clean()
пользовательской функцией (этот метод автоматически вызывается из full_clean () при проверке формы модели):
from django.db import models
class Issue(models.Model):
....
def clean(self):
rules.Issue_clean(self) #<-- custom function invocation
from issues import rules
rules.connect()
Затем в rules.py
файле я пишу правила ведения бизнеса. Также я подключаю pre_save()
к своей пользовательской функции, чтобы предотвратить сохранение модели с неправильным состоянием:
из issues.models import Issue
def connect():
from django.db.models.signals import post_save, pre_save, pre_delete
#issues
pre_save.connect(Issue_pre_save, sender = Incidencia )
post_save.connect(Issue_post_save, sender = Incidencia )
pre_delete.connect(Issue_pre_delete, sender= Incidencia)
def Incidencia_clean( instance ): #<-- custom function
import datetime as dt
errors = {}
#dia i hora sempre informats
if not instance.dia_incidencia: #<-- business rules
errors.setdefault('dia_incidencia',[]).append(u'Data missing: ...')
#dia i hora sempre informats
if not instance.franja_incidencia:
errors.setdefault('franja_incidencia',[]).append(u'Falten Dades: ...')
#Només es poden posar incidències més ennlà de 7 dies
if instance.dia_incidencia < ( dt.date.today() + dt.timedelta( days = -7) ):
errors.setdefault('dia_incidencia 1',[]).append(u'''blah blah error desc)''')
#No incidències al futur.
if instance.getDate() > datetime.now():
errors.setdefault('dia_incidencia 2',[]).append(u'''Encara no pots ....''')
...
if len( errors ) > 0:
raise ValidationError(errors) #<-- raising errors
def Issue_pre_save(sender, instance, **kwargs):
instance.clean() #<-- custom function invocation
Затем modelform вызывает метод модели clean, а моя функция custon проверяет правильное состояние или вызывает ошибку, которая обрабатывается формой модели.
Чтобы отображать ошибки в форме, вы должны включить это в шаблон формы:
{% if form.non_field_errors %}
{% for error in form.non_field_errors %}
{{error}}
{% endfor %}
{% endif %}
Причина в том, что ошибки проверки модели связаны с записью словаря ошибок non_field_errors.
Когда вы сохраняете или удаляете модель вне формы, вы должны помнить, что может возникнуть ошибка:
try:
issue.delete()
except ValidationError, e:
import itertools
errors = list( itertools.chain( *e.message_dict.values() ) )
Кроме того, вы можете добавлять ошибки в словарь форм без форм:
try:
#provoco els errors per mostrar-los igualment al formulari.
issue.clean()
except ValidationError, e:
form._errors = {}
for _, v in e.message_dict.items():
form._errors.setdefault(NON_FIELD_ERRORS, []).extend( v )
Помните, что этот код не выполняется в методе save (): обратите внимание, что full_clean () не будет вызываться автоматически ни при вызове метода save () вашей модели, ни в результате проверки ModelForm. Затем вы можете добавить ошибки в словарь форм на без модельных форм:
try:
#provoco els errors per mostrar-los igualment al formulari.
issue.clean()
except ValidationError, e:
form._errors = {}
for _, v in e.message_dict.items():
form._errors.setdefault(NON_FIELD_ERRORS, []).extend( v )
person
dani herrera
schedule
07.01.2012