Вход действия по администратору Django - Django

Я должен отслеживать/регистрировать действие по администратору Django.

Я знаю, что существуют сообщения, хранившие администратором где-нибудь, но я не знаю, как получить доступ к ним для использования их в качестве простого журнала.


Я пытаюсь отследить следующее:

  • Пользователь, выполняющий действие

  • Действие фиксируется

  • Дата и время действия

Спасибо, ребята.

26
задан RadiantHex 1 July 2010 в 12:45
поделиться

3 ответа

Мне пришлось сделать нечто подобное, и я использовал что-то вроде этого:

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: 'Удалить'}). Надеюсь, это поможет!

21
ответ дан 28 November 2019 в 07:27
поделиться

Журнал находится в таблице django_admin_log в базе данных, используемой django.

13
ответ дан 28 November 2019 в 07:27
поделиться

Взгляните на класс 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)
5
ответ дан 28 November 2019 в 07:27
поделиться
Другие вопросы по тегам:

Похожие вопросы: