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/lib/__init__.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/lib/__init__.py')
-rw-r--r-- | hyperkitty/lib/__init__.py | 17 |
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( |