Add workflow email action template support

Signed-off-by: Roberto Rosario <roberto.rosario@mayan-edms.com>
This commit is contained in:
Roberto Rosario
2019-06-27 12:10:31 -04:00
parent 850fb16c8c
commit 744bfefa5c
2 changed files with 110 additions and 4 deletions

View File

@@ -9,6 +9,7 @@ from mayan.apps.documents.tests.mixins import DocumentTestMixin
from mayan.apps.document_states.literals import WORKFLOW_ACTION_ON_ENTRY from mayan.apps.document_states.literals import WORKFLOW_ACTION_ON_ENTRY
from mayan.apps.document_states.tests.mixins import WorkflowTestMixin from mayan.apps.document_states.tests.mixins import WorkflowTestMixin
from mayan.apps.document_states.tests.test_actions import ActionTestCase from mayan.apps.document_states.tests.test_actions import ActionTestCase
from mayan.apps.metadata.tests.mixins import MetadataTypeTestMixin
from ..permissions import permission_user_mailer_use from ..permissions import permission_user_mailer_use
from ..workflow_actions import EmailAction from ..workflow_actions import EmailAction
@@ -66,6 +67,69 @@ class EmailActionTestCase(MailerTestMixin, WorkflowTestMixin, ActionTestCase):
self.assertEqual(mail.outbox[0].to, [TEST_EMAIL_ADDRESS]) self.assertEqual(mail.outbox[0].to, [TEST_EMAIL_ADDRESS])
class EmailActionTemplateTestCase(MetadataTypeTestMixin, MailerTestMixin, WorkflowTestMixin, ActionTestCase):
def test_email_action_recipient_template(self):
self._create_test_metadata_type()
self.test_document_type.metadata.create(metadata_type=self.test_metadata_type)
self.test_document.metadata.create(metadata_type=self.test_metadata_type, value=TEST_EMAIL_ADDRESS)
self._create_test_user_mailer()
action = EmailAction(
form_data={
'mailing_profile': self.test_user_mailer.pk,
'recipient': '{{{{ document.metadata_value_of.{} }}}}'.format(self.test_metadata_type.name),
'subject': TEST_EMAIL_SUBJECT,
'body': '',
}
)
action.execute(context={'document': self.test_document})
self.assertEqual(len(mail.outbox), 1)
self.assertEqual(mail.outbox[0].from_email, TEST_EMAIL_FROM_ADDRESS)
self.assertEqual(mail.outbox[0].to, [TEST_EMAIL_ADDRESS])
def test_email_action_subject_template(self):
self._create_test_metadata_type()
self.test_document_type.metadata.create(metadata_type=self.test_metadata_type)
self.test_document.metadata.create(metadata_type=self.test_metadata_type, value=TEST_EMAIL_SUBJECT)
self._create_test_user_mailer()
action = EmailAction(
form_data={
'mailing_profile': self.test_user_mailer.pk,
'recipient': TEST_EMAIL_ADDRESS,
'subject': '{{{{ document.metadata_value_of.{} }}}}'.format(self.test_metadata_type.name),
'body': '',
}
)
action.execute(context={'document': self.test_document})
self.assertEqual(len(mail.outbox), 1)
self.assertEqual(mail.outbox[0].from_email, TEST_EMAIL_FROM_ADDRESS)
self.assertEqual(mail.outbox[0].to, [TEST_EMAIL_ADDRESS])
def test_email_action_body_template(self):
self._create_test_metadata_type()
self.test_document_type.metadata.create(metadata_type=self.test_metadata_type)
self.test_document.metadata.create(metadata_type=self.test_metadata_type, value=TEST_EMAIL_BODY)
self._create_test_user_mailer()
action = EmailAction(
form_data={
'mailing_profile': self.test_user_mailer.pk,
'recipient': TEST_EMAIL_ADDRESS,
'subject': TEST_EMAIL_SUBJECT,
'body': '{{{{ document.metadata_value_of.{} }}}}'.format(self.test_metadata_type.name),
}
)
action.execute(context={'document': self.test_document})
self.assertEqual(len(mail.outbox), 1)
self.assertEqual(mail.outbox[0].from_email, TEST_EMAIL_FROM_ADDRESS)
self.assertEqual(mail.outbox[0].to, [TEST_EMAIL_ADDRESS])
self.assertEqual(mail.outbox[0].body, TEST_EMAIL_BODY)
class EmailActionViewTestCase(DocumentTestMixin, MailerTestMixin, WorkflowTestMixin, GenericViewTestCase): class EmailActionViewTestCase(DocumentTestMixin, MailerTestMixin, WorkflowTestMixin, GenericViewTestCase):
auto_upload_document = False auto_upload_document = False

View File

@@ -2,10 +2,12 @@ from __future__ import absolute_import, unicode_literals
import logging import logging
from django.template import Template, Context
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from mayan.apps.acls.models import AccessControlList from mayan.apps.acls.models import AccessControlList
from mayan.apps.document_states.classes import WorkflowAction from mayan.apps.document_states.classes import WorkflowAction
from mayan.apps.document_states.exceptions import WorkflowStateActionError
from .models import UserMailer from .models import UserMailer
from .permissions import permission_user_mailer_use from .permissions import permission_user_mailer_use
@@ -28,7 +30,8 @@ class EmailAction(WorkflowAction):
'class': 'django.forms.CharField', 'kwargs': { 'class': 'django.forms.CharField', 'kwargs': {
'help_text': _( 'help_text': _(
'Email address of the recipient. Can be multiple addresses ' 'Email address of the recipient. Can be multiple addresses '
'separated by comma or semicolon.' 'separated by comma or semicolon. A template can be used '
'to reference properties of the document.'
), ),
'required': True 'required': True
} }
@@ -36,17 +39,23 @@ class EmailAction(WorkflowAction):
'subject': { 'subject': {
'label': _('Subject'), 'label': _('Subject'),
'class': 'django.forms.CharField', 'kwargs': { 'class': 'django.forms.CharField', 'kwargs': {
'help_text': _(
'Subject of the email. Can be a string or a template.'
),
'required': True 'required': True
} }
}, },
'body': { 'body': {
'label': _('Body'), 'label': _('Body'),
'class': 'django.forms.CharField', 'kwargs': { 'class': 'django.forms.CharField', 'kwargs': {
'help_text': _('Body of the email to send.'), 'help_text': _(
'Body of the email to send. Can be a string or a template.'
),
'required': True 'required': True
} }
}, },
} }
field_order = ('mailing_profile', 'recipient', 'subject', 'body')
label = _('Send email') label = _('Send email')
widgets = { widgets = {
'body': { 'body': {
@@ -56,10 +65,42 @@ class EmailAction(WorkflowAction):
permission = permission_user_mailer_use permission = permission_user_mailer_use
def execute(self, context): def execute(self, context):
try:
recipient = Template(self.form_data['recipient']).render(
context=Context(context)
)
except Exception as exception:
raise WorkflowStateActionError(
_('Recipient template error: %s') % exception
)
else:
logger.debug('Recipient result: %s', recipient)
try:
subject = Template(self.form_data['subject']).render(
context=Context(context)
)
except Exception as exception:
raise WorkflowStateActionError(
_('Subject template error: %s') % exception
)
else:
logger.debug('Subject result: %s', subject)
try:
body = Template(self.form_data['body']).render(
context=Context(context)
)
except Exception as exception:
raise WorkflowStateActionError(
_('Body template error: %s') % exception
)
else:
logger.debug('Body result: %s', body)
user_mailer = self.get_user_mailer() user_mailer = self.get_user_mailer()
user_mailer.send( user_mailer.send(
to=self.form_data['recipient'], subject=self.form_data['subject'], to=recipient, subject=subject, body=body,
body=self.form_data['body'],
) )
def get_form_schema(self, request): def get_form_schema(self, request):
@@ -74,6 +115,7 @@ class EmailAction(WorkflowAction):
self.fields['mailing_profile']['kwargs']['queryset'] = queryset self.fields['mailing_profile']['kwargs']['queryset'] = queryset
return { return {
'field_order': self.field_order,
'fields': self.fields, 'fields': self.fields,
'widgets': self.widgets 'widgets': self.widgets
} }