Я должен отслеживать/регистрировать действие по администратору Django.
Я знаю, что существуют сообщения, хранившие администратором где-нибудь, но я не знаю, как получить доступ к ним для использования их в качестве простого журнала.
Я пытаюсь отследить следующее:
Пользователь, выполняющий действие
Действие фиксируется
Дата и время действия
Спасибо, ребята.
Мне пришлось сделать нечто подобное, и я использовал что-то вроде этого:
from django.contrib.admin.models import LogEntry
logs = LogEntry.objects.all() #or you can filter, etc.
for l in logs:
#perform action
Вы можете увидеть все атрибуты для LogEntry , но я думаю, что те, которые вы ищете for - это l.user, l.action_time и l.obj_repr (имя объекта) и l.action_flag ({1: 'Добавить', 2: 'Изменить', 3: 'Удалить'}). Надеюсь, это поможет!
Журнал находится в таблице django_admin_log в базе данных, используемой django.
Взгляните на класс LogEntry , который хранит журнал действий внутри администратора.
Вы можете использовать его так, чтобы вставлять собственные записи в журналы:
from settings import LOG_SIZE, LOG_THRESHOLD
from django.contrib.admin.models import LogEntry
if not LogEntry._meta.installed:
raise ImproperlyConfigured("You'll need to put 'django.contrib.admin' in your INSTALLED_APPS setting before you can use the admin application.")
def log_action(user_id, content_type_id, object_id, object_repr, action_flag, change_message=''):
# limit log size
log_count = LogEntry.objects.count()
if log_count > LOG_THRESHOLD:
to_delete = LogEntry.objects.all()[LOG_SIZE:log_count]
#FIXME (!?): to_delete.delete()
for d in to_delete:
d.delete()
LogEntry.objects.log_action(user_id, content_type_id, object_id, object_repr, action_flag, change_message)