From c2ed8a68e445e9bfdd75d71bdc13fb51e058776c Mon Sep 17 00:00:00 2001 From: Viktor van Wijk Date: Wed, 11 Dec 2024 15:45:15 +0100 Subject: [PATCH 1/3] :technologist: [#4895] Add custom headers to confirmation and cosign request emails --- src/openforms/submissions/tasks/emails.py | 13 ++++++++ .../submissions/tests/test_task_co_sign.py | 32 +++++++++++++++++++ .../tests/test_tasks_confirmation_emails.py | 32 +++++++++++++++++++ src/openforms/submissions/utils.py | 13 ++++++++ 4 files changed, 90 insertions(+) diff --git a/src/openforms/submissions/tasks/emails.py b/src/openforms/submissions/tasks/emails.py index 4fb4665392..55fb3437eb 100644 --- a/src/openforms/submissions/tasks/emails.py +++ b/src/openforms/submissions/tasks/emails.py @@ -10,6 +10,13 @@ from openforms.celery import app from openforms.config.models import GlobalConfiguration +from openforms.emails.constants import ( + X_OF_CONTENT_TYPE_HEADER, + X_OF_CONTENT_UUID_HEADER, + X_OF_EVENT_HEADER, + EmailContentTypeChoices, + EmailEventChoices, +) from openforms.emails.utils import send_mail_html from openforms.frontend import get_frontend_redirect_url from openforms.logging import logevent @@ -133,6 +140,12 @@ def send_email_cosigner(submission_id: int) -> None: from_email=settings.DEFAULT_FROM_EMAIL, recipient_list=[recipient], text_message=content, + extra_headers={ + "Content-Language": submission.language_code, + X_OF_CONTENT_TYPE_HEADER: EmailContentTypeChoices.submission, + X_OF_CONTENT_UUID_HEADER: str(submission.uuid), + X_OF_EVENT_HEADER: EmailEventChoices.cosign_confirmation, + }, ) except Exception: logevent.cosigner_email_queuing_failure(submission) diff --git a/src/openforms/submissions/tests/test_task_co_sign.py b/src/openforms/submissions/tests/test_task_co_sign.py index c7e81c0e13..3fa1a74ce0 100644 --- a/src/openforms/submissions/tests/test_task_co_sign.py +++ b/src/openforms/submissions/tests/test_task_co_sign.py @@ -4,6 +4,7 @@ from django.test import TestCase from openforms.config.models import GlobalConfiguration +from openforms.emails.constants import EmailContentTypeChoices, EmailEventChoices from openforms.logging.models import TimelineLogProxy from ..tasks import send_email_cosigner @@ -175,3 +176,34 @@ def test_form_link_not_allowed_in_email(self): self.assertNotIn(form_link, email.body) self.assertIn(submission.public_registration_reference, email.body) + + def test_headers_in_cosign_email(self): + submission = SubmissionFactory.from_components( + components_list=[ + { + "key": "cosign", + "type": "cosign", + "label": "Cosign component", + }, + ], + submitted_data={"cosign": "test@test.nl"}, + form_url="http://testserver/myform/", + ) + send_email_cosigner(submission.id) + + self.assertEqual(len(mail.outbox), 1) + message = mail.outbox[0] + + # UUID is not a constant, so just test if it exists + submission_uuid = message.extra_headers.pop("X-OF-Content-UUID", None) + self.assertIsNotNone(submission_uuid) + + # Test remaining headers + self.assertEqual( + message.extra_headers, + { + "Content-Language": "nl", + "X-OF-Content-Type": EmailContentTypeChoices.submission, + "X-OF-Event": EmailEventChoices.cosign_confirmation, + }, + ) diff --git a/src/openforms/submissions/tests/test_tasks_confirmation_emails.py b/src/openforms/submissions/tests/test_tasks_confirmation_emails.py index 2194501216..52256d918e 100644 --- a/src/openforms/submissions/tests/test_tasks_confirmation_emails.py +++ b/src/openforms/submissions/tests/test_tasks_confirmation_emails.py @@ -11,6 +11,7 @@ from privates.test import temp_private_root from openforms.config.models import GlobalConfiguration +from openforms.emails.constants import EmailContentTypeChoices, EmailEventChoices from openforms.emails.models import ConfirmationEmailTemplate from openforms.emails.tests.factories import ConfirmationEmailTemplateFactory from openforms.forms.tests.factories import FormStepFactory @@ -641,6 +642,37 @@ def test_template_is_rendered_in_submission_language(self): self.assertIn("Translated Radio option 1", html_message) self.assertIn("Translated Select option 2", html_message) + def test_headers_present_in_confirmation_email(self): + submission = SubmissionFactory.from_components( + completed=True, + components_list=[ + { + "key": "email", + "confirmationRecipient": True, + }, + ], + submitted_data={"email": "test@test.nl"}, + ) + with override_settings(CELERY_TASK_ALWAYS_EAGER=True): + send_confirmation_email(submission.id) + + self.assertEqual(len(mail.outbox), 1) + message = mail.outbox[0] + + # UUID is not a constant, so just test if it exists + submission_uuid = message.extra_headers.pop("X-OF-Content-UUID", None) + self.assertIsNotNone(submission_uuid) + + # Test remaining headers + self.assertEqual( + message.extra_headers, + { + "Content-Language": "nl", + "X-OF-Content-Type": EmailContentTypeChoices.submission, + "X-OF-Event": EmailEventChoices.confirmation, + }, + ) + class RaceConditionTests(TransactionTestCase): @patch("openforms.submissions.tasks.emails._send_confirmation_email") diff --git a/src/openforms/submissions/utils.py b/src/openforms/submissions/utils.py index 762b5f036a..faba1b0a67 100644 --- a/src/openforms/submissions/utils.py +++ b/src/openforms/submissions/utils.py @@ -19,6 +19,13 @@ get_confirmation_email_context_data, get_confirmation_email_templates, ) +from openforms.emails.constants import ( + X_OF_CONTENT_TYPE_HEADER, + X_OF_CONTENT_UUID_HEADER, + X_OF_EVENT_HEADER, + EmailContentTypeChoices, + EmailEventChoices, +) from openforms.emails.utils import ( render_email_template, send_mail_html, @@ -204,6 +211,12 @@ def send_confirmation_email(submission: Submission) -> None: cc=cc_emails, text_message=text_content, theme=submission.form.theme, + extra_headers={ + "Content-Language": submission.language_code, + X_OF_CONTENT_TYPE_HEADER: EmailContentTypeChoices.submission, + X_OF_CONTENT_UUID_HEADER: str(submission.uuid), + X_OF_EVENT_HEADER: EmailEventChoices.confirmation, + }, ) except Exception as e: logevent.confirmation_email_failure(submission, e) From 658c18b6c977e086e018f013377850b446c6f5c2 Mon Sep 17 00:00:00 2001 From: Viktor van Wijk Date: Wed, 11 Dec 2024 15:46:30 +0100 Subject: [PATCH 2/3] :pencil2: [#4895] Fix app label name for submission email content type --- src/openforms/emails/constants.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/openforms/emails/constants.py b/src/openforms/emails/constants.py index 6db2a3cbb2..7b2996319b 100644 --- a/src/openforms/emails/constants.py +++ b/src/openforms/emails/constants.py @@ -13,4 +13,4 @@ class EmailEventChoices(models.TextChoices): class EmailContentTypeChoices(models.TextChoices): - submission = "submission.submission", _("Submission") + submission = "submissions.Submission", _("Submission") From 94412198e0a9600f9036164a4167624168d38495 Mon Sep 17 00:00:00 2001 From: Viktor van Wijk Date: Thu, 12 Dec 2024 09:43:16 +0100 Subject: [PATCH 3/3] :pencil2: [#4895] Rename event 'cosign confirmation' to 'cosign request' It is rather a cosign request email, since the cosign confirmation itself is not much different from the "normal" confirmation email. --- src/openforms/emails/constants.py | 2 +- src/openforms/submissions/tasks/emails.py | 2 +- src/openforms/submissions/tests/test_task_co_sign.py | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/openforms/emails/constants.py b/src/openforms/emails/constants.py index 7b2996319b..b61025ed71 100644 --- a/src/openforms/emails/constants.py +++ b/src/openforms/emails/constants.py @@ -9,7 +9,7 @@ class EmailEventChoices(models.TextChoices): registration = "registration", _("Registration") confirmation = "confirmation", _("Confirmation") - cosign_confirmation = "cosign_confirmation", _("Co-sign confirmation") + cosign_request = "cosign_request", _("Co-sign request") class EmailContentTypeChoices(models.TextChoices): diff --git a/src/openforms/submissions/tasks/emails.py b/src/openforms/submissions/tasks/emails.py index 55fb3437eb..5e9bfbc812 100644 --- a/src/openforms/submissions/tasks/emails.py +++ b/src/openforms/submissions/tasks/emails.py @@ -144,7 +144,7 @@ def send_email_cosigner(submission_id: int) -> None: "Content-Language": submission.language_code, X_OF_CONTENT_TYPE_HEADER: EmailContentTypeChoices.submission, X_OF_CONTENT_UUID_HEADER: str(submission.uuid), - X_OF_EVENT_HEADER: EmailEventChoices.cosign_confirmation, + X_OF_EVENT_HEADER: EmailEventChoices.cosign_request, }, ) except Exception: diff --git a/src/openforms/submissions/tests/test_task_co_sign.py b/src/openforms/submissions/tests/test_task_co_sign.py index 3fa1a74ce0..a76ac10f8c 100644 --- a/src/openforms/submissions/tests/test_task_co_sign.py +++ b/src/openforms/submissions/tests/test_task_co_sign.py @@ -177,7 +177,7 @@ def test_form_link_not_allowed_in_email(self): self.assertNotIn(form_link, email.body) self.assertIn(submission.public_registration_reference, email.body) - def test_headers_in_cosign_email(self): + def test_headers_in_cosign_request_email(self): submission = SubmissionFactory.from_components( components_list=[ { @@ -204,6 +204,6 @@ def test_headers_in_cosign_email(self): { "Content-Language": "nl", "X-OF-Content-Type": EmailContentTypeChoices.submission, - "X-OF-Event": EmailEventChoices.cosign_confirmation, + "X-OF-Event": EmailEventChoices.cosign_request, }, )