X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fplcorebase.py;h=590e24009a585fa3210aa74870a680e107cb1d55;hb=6ecd42600aa29e2ccaf0a59db03210d032d8d30d;hp=b64df5fc74bd163f672aeeeb7808b57cb6076960;hpb=9c2c8fa92c81666bde7a97ecd4df1a4262704b11;p=plstackapi.git diff --git a/planetstack/core/models/plcorebase.py b/planetstack/core/models/plcorebase.py index b64df5f..590e240 100644 --- a/planetstack/core/models/plcorebase.py +++ b/planetstack/core/models/plcorebase.py @@ -1,6 +1,8 @@ import os from django.db import models from django.forms.models import model_to_dict +from django.core.urlresolvers import reverse +from django.forms.models import model_to_dict # This is a no-op if observer_disabled is set to 1 in the config file from observer import * @@ -37,10 +39,17 @@ class PlCoreBase(models.Model): return self.diff.get(field_name, None) def delete(self, *args, **kwds): + # so we have something to give the observer + pk = self.pk + model_dict = model_to_dict(self) + for (k,v) in model_dict.items(): + # things like datetime are not JSON serializable + model_dict[k] = str(v) + super(PlCoreBase, self).delete(*args, **kwds) # This is a no-op if observer_disabled is set - notify_observer(model=self, delete=True) + notify_observer(model=self, delete=True, pk=pk, model_dict=model_dict) def save(self, *args, **kwargs): super(PlCoreBase, self).save(*args, **kwargs)