diff options
author | Aurélien Bompard <aurelien@bompard.org> | 2013-01-31 23:37:09 +0100 |
---|---|---|
committer | Aurélien Bompard <aurelien@bompard.org> | 2013-02-01 16:37:23 +0100 |
commit | 0e944bed0d2f1774c2da52184ac30ab95dd8a11c (patch) | |
tree | 09d7cc08c91181580bc809b1aba7108805e711a0 /hyperkitty/views/message.py | |
parent | 238d19f7e09bfa754f4b91622f1c34d08f2ef26d (diff) | |
download | hyperkitty-0e944bed0d2f1774c2da52184ac30ab95dd8a11c.tar.gz hyperkitty-0e944bed0d2f1774c2da52184ac30ab95dd8a11c.tar.xz hyperkitty-0e944bed0d2f1774c2da52184ac30ab95dd8a11c.zip |
Inline replies
Diffstat (limited to 'hyperkitty/views/message.py')
-rw-r--r-- | hyperkitty/views/message.py | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/hyperkitty/views/message.py b/hyperkitty/views/message.py index b78d091..c278ac5 100644 --- a/hyperkitty/views/message.py +++ b/hyperkitty/views/message.py @@ -26,10 +26,12 @@ import urllib import django.utils.simplejson as simplejson from django.http import HttpResponse, HttpResponseRedirect, Http404 -from django.shortcuts import redirect +from django.shortcuts import redirect, render from django.template import RequestContext, loader from django.conf import settings from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger, InvalidPage +from django.core.urlresolvers import reverse +from django.core.mail import EmailMessage from django.contrib.auth.decorators import (login_required, permission_required, user_passes_test) @@ -92,6 +94,7 @@ def index(request, mlist_fqdn, hashid): 'hashid' : hashid, 'archives_length': get_months(store, mlist_fqdn), 'use_mockups': settings.USE_MOCKUPS, + 'reply_form': ReplyForm(), }) return HttpResponse(t.render(c)) @@ -154,3 +157,33 @@ def vote(request, mlist_fqdn): return HttpResponse(simplejson.dumps(status), mimetype='application/javascript') + + +@login_required +def reply(request, mlist_fqdn, message_id): + """ Sends a reply to the list. + TODO: unit tests + """ + if request.method != 'POST': + return HttpResponse("Something went wrong", content_type="text/plain", status=500) + form = ReplyForm(request.POST) + if not form.is_valid(): + return HttpResponse(form.errors.as_text(), content_type="text/plain", status=400) + store = get_store(request) + message = store.get_message_by_hash_from_list(mlist_fqdn, message_id) + subject = message.subject + if not message.subject.lower().startswith("re:"): + subject = "Re: %s" % subject + reply = EmailMessage( + subject=subject, + body=form.cleaned_data["message"], + from_email='"%s %s" <%s>' % + (request.user.first_name, request.user.last_name, + request.user.email), + to=[mlist_fqdn], + cc=['aurelien@bompard.org'], + headers={ + "In-Reply-To": message.message_id, + }) + reply.send() + return HttpResponse("The reply has been sent successfully.", mimetype="text/plain") |