diff options
author | Aurélien Bompard <aurelien@bompard.org> | 2013-05-03 19:30:42 +0200 |
---|---|---|
committer | Aurélien Bompard <aurelien@bompard.org> | 2013-05-03 19:30:42 +0200 |
commit | 4b1df7bbdb0f0fa35cf738235aff8170a37b7d04 (patch) | |
tree | 6c1567d5dcb5a692a9a3b2cf5f5e29d7b1caf934 /hyperkitty/views/message.py | |
parent | 3123d2ed9220ab1103a800041e4e46d0f6fbf6c8 (diff) | |
download | hyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.tar.gz hyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.tar.xz hyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.zip |
Handle errors when Mailman's REST server is down
Diffstat (limited to 'hyperkitty/views/message.py')
-rw-r--r-- | hyperkitty/views/message.py | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/hyperkitty/views/message.py b/hyperkitty/views/message.py index bb6f364..e526977 100644 --- a/hyperkitty/views/message.py +++ b/hyperkitty/views/message.py @@ -33,7 +33,7 @@ from django.core.exceptions import SuspiciousOperation from django.template import RequestContext, loader from django.contrib.auth.decorators import login_required -from hyperkitty.lib import get_store, get_months, post_to_list +from hyperkitty.lib import get_store, get_months, post_to_list, PostingFailed from hyperkitty.lib.voting import set_message_votes from hyperkitty.models import Rating from forms import SearchForm, ReplyForm, PostForm @@ -167,7 +167,10 @@ def reply(request, mlist_fqdn, message_id_hash): subject = "Re: %s" % subject headers = {"In-Reply-To": "<%s>" % message.message_id, "References": "<%s>" % message.message_id, } - post_to_list(request, mlist, subject, form.cleaned_data["message"], headers) + try: + post_to_list(request, mlist, subject, form.cleaned_data["message"], headers) + except PostingFailed, e: + return HttpResponse(str(e), content_type="text/plain", status=500) return HttpResponse("The reply has been sent successfully.", mimetype="text/plain") @@ -179,11 +182,10 @@ def new_message(request, mlist_fqdn): """ store = get_store(request) mlist = store.get_list(mlist_fqdn) + failure = None if request.method == 'POST': form = PostForm(request.POST) if form.is_valid(): - post_to_list(request, mlist, form.cleaned_data['subject'], - form.cleaned_data["message"]) today = datetime.date.today() redirect_url = reverse( 'archives_with_month', kwargs={ @@ -191,12 +193,19 @@ def new_message(request, mlist_fqdn): 'year': today.year, 'month': today.month}) redirect_url += "?msg=sent-ok" - return redirect(redirect_url) + try: + post_to_list(request, mlist, form.cleaned_data['subject'], + form.cleaned_data["message"]) + except PostingFailed, e: + failure = str(e) + else: + return redirect(redirect_url) else: form = PostForm() context = { "mlist": mlist, "post_form": form, + "failure": failure, 'months_list': get_months(store, mlist.name), } return render(request, "message_new.html", context) |