summaryrefslogtreecommitdiffstats
path: root/hyperkitty/lib/__init__.py
diff options
context:
space:
mode:
authorAurélien Bompard <aurelien@bompard.org>2013-05-03 19:30:42 +0200
committerAurélien Bompard <aurelien@bompard.org>2013-05-03 19:30:42 +0200
commit4b1df7bbdb0f0fa35cf738235aff8170a37b7d04 (patch)
tree6c1567d5dcb5a692a9a3b2cf5f5e29d7b1caf934 /hyperkitty/lib/__init__.py
parent3123d2ed9220ab1103a800041e4e46d0f6fbf6c8 (diff)
downloadhyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.tar.gz
hyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.tar.xz
hyperkitty-4b1df7bbdb0f0fa35cf738235aff8170a37b7d04.zip
Handle errors when Mailman's REST server is down
Diffstat (limited to 'hyperkitty/lib/__init__.py')
-rw-r--r--hyperkitty/lib/__init__.py17
1 files changed, 7 insertions, 10 deletions
diff --git a/hyperkitty/lib/__init__.py b/hyperkitty/lib/__init__.py
index 7ae9ee9..4acb7d1 100644
--- a/hyperkitty/lib/__init__.py
+++ b/hyperkitty/lib/__init__.py
@@ -27,6 +27,7 @@ from django.conf import settings
from django.core.exceptions import SuspiciousOperation
from django.core.mail import EmailMessage
+from hyperkitty.lib import mailman
FLASH_MESSAGES = {
@@ -102,22 +103,18 @@ def daterange(start_date, end_date):
yield start_date + datetime.timedelta(n)
+class PostingFailed(Exception): pass
+
def post_to_list(request, mlist, subject, message, headers={}):
if not mlist:
# Make sure the list exists to avoid posting to any email addess
raise SuspiciousOperation("I don't know this mailing-list")
# Check that the user is subscribed
- client = Client('%s/3.0' % settings.MAILMAN_REST_SERVER,
- settings.MAILMAN_API_USER, settings.MAILMAN_API_PASS)
- rest_list = client.get_list(mlist.name)
try:
- member = rest_list.get_member(request.user.email)
- except ValueError:
- # not subscribed yet, subscribe the user without email delivery
- member = rest_list.subscribe(request.user.email,
- "%s %s" % (request.user.first_name, request.user.last_name))
- member.preferences["delivery_status"] = "by_user"
- member.preferences.save()
+ mailman.subscribe(mlist.name, request.user)
+ except mailman.MailmanConnectionError:
+ raise PostingFailed("Can't connect to Mailman's REST server, "
+ "your message has not been sent.")
# send the message
headers["User-Agent"] = "HyperKitty on %s" % request.build_absolute_uri("/")
msg = EmailMessage(