Primero, en lugar de anular guardar para agregar __before
y __after
métodos, puede usar el pre_save
incorporado , post_save,
pre_delete,
y post_delete
señales 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
y post_delete
se activará cuando llame a delete()
en un conjunto de consultas.
Sin embargo, para la actualización masiva, deberá llamar manualmente a la función que desea activar. Y también puede incluirlo todo en una transacción.
Para llamar a la función de activación adecuada si usa modelos dinámicos, puede inspeccionar el tipo de contenido del modelo. Por ejemplo:
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)