Innanzitutto, invece di sovrascrivere salva per aggiungere __before
e __after
metodi, puoi usare il built-in pre_save
, post_save,
pre_delete,
e post_delete
segnali. https://docs.djangoproject.com/en/1.4/topics/signals/
from django.db.models.signals import post_save
class YourModel(models.Model):
pass
def after_save_your_model(sender, instance, **kwargs):
pass
# register the signal
post_save.connect(after_save_your_model, sender=YourModel, dispatch_uid=__file__)
pre_delete
e post_delete
verrà attivato quando chiami delete()
su un set di query.
Per l'aggiornamento in blocco, tuttavia, dovrai chiamare manualmente la funzione che desideri attivare. E puoi anche inserire tutto in una transazione.
Per chiamare la corretta funzione di trigger se stai usando modelli dinamici, puoi controllare il ContentType del modello. Ad esempio:
from django.contrib.contenttypes.models import ContentType
def view(request, app, model_name, method):
...
model = get_model(app, model_name)
content_type = ContentType.objects.get_for_model(model)
if content_type == ContenType.objects.get_for_model(YourModel):
after_save_your_model(model)
elif content_type == Contentype.objects.get_for_model(AnotherModel):
another_trigger_function(model)