Primeiro, em vez de substituir salvar para adicionar
__before
e __after
métodos, você pode usar o built-in pre_save
, post_save,
pre_delete,
e post_delete
sinais. 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
será acionado quando você chamar delete()
em um conjunto de consultas. No entanto, para atualização em massa, você terá que chamar manualmente a função que deseja acionar. E você pode jogar tudo em uma transação também.
Para chamar a função de gatilho adequada se estiver usando modelos dinâmicos, você pode inspecionar o ContentType do modelo. Por exemplo:
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)