xlogging.py: from django.contrib.contenttypes.models import ContentType from django.utils.encoding import force_unicode VIEW = 4 def log_view(request, object): """ Log that an object is being viewed by the user. """ from django.contrib.admin.models import LogEntry LogEntry.objects.log_action( user_id = request.user.pk, content_type_id = ContentType.objects.get_for_model(object).pk, object_id = object.pk, object_repr = force_unicode(object), action_flag = VIEW, change_message = "Accessed object %s in %s." % (force_unicode(object), ContentType.objects.get_for_model(object)) ) admin.py from some.application.module.xlogging import log_view class SomeAdmin(admin.ModelAdmin): def change_view(self, request, object_id, extra_context=None): object = self.queryset(request).get(pk=unquote(object_id)) log_view(request, object) return super(SomeAdmin, self).change_view(request, object_id, extra_context)