django-auditlog/auditlog/registry.py
2013-10-20 15:25:48 +02:00

73 lines
2.1 KiB
Python

from django.db.models.signals import pre_save, post_save, post_delete
from django.db.models import Model
from auditlog.receivers import log_create, log_update, log_delete
class AuditLogModelRegistry(object):
"""
A registry that keeps track of the models that use auditlog.
"""
def __init__(self, create=True, update=True, delete=True, custom=None):
self._registry = []
self._signals = {}
if create:
self._signals[post_save] = log_create
if update:
self._signals[pre_save] = log_update
if delete:
self._signals[post_delete] = log_delete
if custom is not None:
self._signals.update(custom)
def register(self, model):
"""
Register a model with auditlog. Auditlog will then track mutations on this model's instances.
"""
if issubclass(model, Model):
self._registry.append(model)
self._connect_signals(model)
else:
raise TypeError('Supplied model is not a valid model.')
def contains(self, model):
"""
Check if a model is registered with auditlog.
"""
return model in self._registry
def unregister(self, model):
"""
Unregister a model with auditlog. This will not affect the database.
"""
try:
self._registry.pop(model)
except KeyError:
pass
else:
self._disconnect_signals(model)
def _connect_signals(self, model):
"""
Connect signals for the model.
"""
for signal, receiver in self._signals:
signal.connect(receiver, sender=model, dispatch_uid=self._dispatch_uid(signal, model))
def _disconnect_signals(self, model):
"""
Disconnect signals for the model.
"""
for signal, receiver in self._signals:
signal.disconnect(dispatch_uid=self._dispatch_uid(signal, model))
def _dispatch_uid(self, signal, model):
"""
Generate a dispatch_uid.
"""
return (self.__class__, model, signal)
registry = AuditLogModelRegistry()