From ecca23e67b63ef6c9577652a7ea820645a3d9b55 Mon Sep 17 00:00:00 2001 From: Aurélien Bompard Date: Fri, 5 Jul 2013 13:25:47 +0200 Subject: Add an attachment field to replies and new emails --- hyperkitty/lib/__init__.py | 19 +++++++++++++++---- hyperkitty/templates/message_new.html | 2 +- hyperkitty/templates/messages/reply_form.html | 2 +- hyperkitty/views/forms.py | 2 ++ hyperkitty/views/message.py | 6 ++++-- 5 files changed, 23 insertions(+), 8 deletions(-) diff --git a/hyperkitty/lib/__init__.py b/hyperkitty/lib/__init__.py index 0317b92..fbfc38d 100644 --- a/hyperkitty/lib/__init__.py +++ b/hyperkitty/lib/__init__.py @@ -105,7 +105,8 @@ def daterange(start_date, end_date): class PostingFailed(Exception): pass -def post_to_list(request, mlist, subject, message, headers={}): +def post_to_list(request, mlist, subject, message, headers={}, + attachments=None): if not mlist: # Make sure the list exists to avoid posting to any email addess raise SuspiciousOperation("I don't know this mailing-list") @@ -117,15 +118,25 @@ def post_to_list(request, mlist, subject, message, headers={}): "your message has not been sent.") # send the message headers["User-Agent"] = "HyperKitty on %s" % request.build_absolute_uri("/") + if not request.user.first_name and not request.user.last_name: + from_email = request.user.email + else: + from_email = '"%s %s" <%s>' % (request.user.first_name, + request.user.last_name, + request.user.email) msg = EmailMessage( subject=subject, body=message, - from_email='"%s %s" <%s>' % - (request.user.first_name, request.user.last_name, - request.user.email), + from_email=from_email, to=[mlist.name], headers=headers, ) + # Attachments + if attachments: + if not isinstance(attachments, list): + attachments = [attachments] + for attach in attachments: + msg.attach(attach.name, attach.read()) msg.send() diff --git a/hyperkitty/templates/message_new.html b/hyperkitty/templates/message_new.html index 25e7c03..56d25f5 100644 --- a/hyperkitty/templates/message_new.html +++ b/hyperkitty/templates/message_new.html @@ -30,7 +30,7 @@ Create a new thread - {{ mlist.display_name|default:mlist.name|escapeemail }} - {% endif %}
-
{% csrf_token %} {{ post_form|crispy }} diff --git a/hyperkitty/templates/messages/reply_form.html b/hyperkitty/templates/messages/reply_form.html index 44dcc3a..1b722de 100644 --- a/hyperkitty/templates/messages/reply_form.html +++ b/hyperkitty/templates/messages/reply_form.html @@ -2,7 +2,7 @@ Reply