2020-08-18 13:05:41 -04:00
|
|
|
from contextlib import contextmanager
|
|
|
|
|
|
|
|
from django.db.models.signals import m2m_changed, pre_delete, post_save
|
|
|
|
|
|
|
|
from extras.signals import _handle_changed_object, _handle_deleted_object
|
|
|
|
from utilities.utils import curry
|
2021-05-28 16:07:27 -04:00
|
|
|
from .webhooks import flush_webhooks
|
2020-08-18 13:05:41 -04:00
|
|
|
|
|
|
|
|
|
|
|
@contextmanager
|
|
|
|
def change_logging(request):
|
|
|
|
"""
|
|
|
|
Enable change logging by connecting the appropriate signals to their receivers before code is run, and
|
|
|
|
disconnecting them afterward.
|
|
|
|
|
|
|
|
:param request: WSGIRequest object with a unique `id` set
|
|
|
|
"""
|
2021-05-28 16:07:27 -04:00
|
|
|
webhook_queue = []
|
|
|
|
|
2020-08-18 13:05:41 -04:00
|
|
|
# Curry signals receivers to pass the current request
|
2021-05-28 16:07:27 -04:00
|
|
|
handle_changed_object = curry(_handle_changed_object, request, webhook_queue)
|
|
|
|
handle_deleted_object = curry(_handle_deleted_object, request, webhook_queue)
|
2020-08-18 13:05:41 -04:00
|
|
|
|
|
|
|
# Connect our receivers to the post_save and post_delete signals.
|
|
|
|
post_save.connect(handle_changed_object, dispatch_uid='handle_changed_object')
|
|
|
|
m2m_changed.connect(handle_changed_object, dispatch_uid='handle_changed_object')
|
|
|
|
pre_delete.connect(handle_deleted_object, dispatch_uid='handle_deleted_object')
|
|
|
|
|
|
|
|
yield
|
|
|
|
|
|
|
|
# Disconnect change logging signals. This is necessary to avoid recording any errant
|
|
|
|
# changes during test cleanup.
|
|
|
|
post_save.disconnect(handle_changed_object, dispatch_uid='handle_changed_object')
|
|
|
|
m2m_changed.disconnect(handle_changed_object, dispatch_uid='handle_changed_object')
|
|
|
|
pre_delete.disconnect(handle_deleted_object, dispatch_uid='handle_deleted_object')
|
2021-05-28 16:07:27 -04:00
|
|
|
|
|
|
|
# Flush queued webhooks to RQ
|
|
|
|
flush_webhooks(webhook_queue)
|
|
|
|
del webhook_queue
|