From b4f669bad567171c93447077f60073dac8c513a8 Mon Sep 17 00:00:00 2001 From: Steven Bal Date: Tue, 29 Oct 2024 14:16:29 +0100 Subject: [PATCH] :sparkles: [#4398] Ensure logs from ownership check in pre-registration work --- src/openforms/logging/logevent.py | 8 +++++ .../events/object_ownership_check_failure.txt | 4 +++ src/openforms/registrations/tasks.py | 31 ++++++++++--------- 3 files changed, 29 insertions(+), 14 deletions(-) create mode 100644 src/openforms/logging/templates/logging/events/object_ownership_check_failure.txt diff --git a/src/openforms/logging/logevent.py b/src/openforms/logging/logevent.py index 2dbe321049..3a05cbad2b 100644 --- a/src/openforms/logging/logevent.py +++ b/src/openforms/logging/logevent.py @@ -247,6 +247,14 @@ def registration_attempts_limited(submission: Submission): ) +def object_ownership_check_failure(submission: Submission, plugin=None): + _create_log( + submission, + "object_ownership_check_failure", + plugin=plugin, + ) + + # - - - diff --git a/src/openforms/logging/templates/logging/events/object_ownership_check_failure.txt b/src/openforms/logging/templates/logging/events/object_ownership_check_failure.txt new file mode 100644 index 0000000000..b6f8a4be43 --- /dev/null +++ b/src/openforms/logging/templates/logging/events/object_ownership_check_failure.txt @@ -0,0 +1,4 @@ +{% load i18n %} +{% blocktrans trimmed with plugin=log.fmt_plugin lead=log.fmt_lead %} + {{ lead }}: Registration plugin {{ plugin }} reported: authenticated user is not the owner of referenced object. +{% endblocktrans %} diff --git a/src/openforms/registrations/tasks.py b/src/openforms/registrations/tasks.py index 1ac00809d1..373b381848 100644 --- a/src/openforms/registrations/tasks.py +++ b/src/openforms/registrations/tasks.py @@ -74,27 +74,30 @@ def pre_registration(submission_id: int, event: PostSubmissionEvents) -> None: ) return + registration_plugin = get_registration_plugin(submission) + + # If an `initial_data_reference` was passed, we must verify that the + # authenticated user is the owner of the referenced object + if registration_plugin and submission.initial_data_reference: + try: + registration_plugin.verify_initial_data_ownership(submission) + except PermissionDenied as e: + logger.exception( + "Submission with initial_data_reference did not pass ownership check for plugin %s", + registration_plugin.verbose_name, + ) + logevent.object_ownership_check_failure( + submission, plugin=registration_plugin + ) + raise e + with transaction.atomic(): - registration_plugin = get_registration_plugin(submission) if not registration_plugin: set_submission_reference(submission) submission.pre_registration_completed = True submission.save() return - # If an `initial_data_reference` was passed, we must verify that the - # authenticated user is the owner of the referenced object - if submission.initial_data_reference: - try: - registration_plugin.verify_initial_data_ownership(submission) - except PermissionDenied as e: - logger.exception( - "Submission with initial_data_reference did not pass ownership check for plugin %s", - registration_plugin.verbose_name, - ) - logevent.registration_failure(submission, e, plugin=registration_plugin) - raise e - options_serializer = registration_plugin.configuration_options( data=submission.registration_backend.options, context={"validate_business_logic": False},