summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVictor Shyba <victor.shyba@gmail.com>2015-11-11 12:40:35 -0300
committerVictor Shyba <victor.shyba@gmail.com>2015-11-11 12:40:35 -0300
commit352163eefb9c1e1281b618e357f7673b07a49eb8 (patch)
treedf048c95f5b3427ee612604c00a4cc6f399a907c
parent67983902a6a35c5c6de531ba10214c5ef4ac33c9 (diff)
unhandled errors were not being logged and generated no response back
-rw-r--r--service/pixelated/resources/mails_resource.py10
1 files changed, 6 insertions, 4 deletions
diff --git a/service/pixelated/resources/mails_resource.py b/service/pixelated/resources/mails_resource.py
index 93a19a9b..499610de 100644
--- a/service/pixelated/resources/mails_resource.py
+++ b/service/pixelated/resources/mails_resource.py
@@ -160,21 +160,23 @@ class MailsResource(Resource):
_mail = InputMail.from_dict(content_dict)
draft_id = content_dict.get('ident')
+ def onError(error):
+ err(error, 'error saving draft')
+ respond_json_deferred("", request, status_code=422)
+
def defer_response(deferred):
deferred.addCallback(lambda pixelated_mail: respond_json_deferred({'ident': pixelated_mail.ident}, request))
+ deferred.addErrback(onError)
if draft_id:
deferred_check = self._mail_service.mail_exists(draft_id)
- def handleDuplicatedDraftException(error):
- respond_json_deferred("", request, status_code=422)
-
def return422otherwise(mail_exists):
if not mail_exists:
respond_json_deferred("", request, status_code=422)
else:
new_draft = self._draft_service.update_draft(draft_id, _mail)
- new_draft.addErrback(handleDuplicatedDraftException)
+ new_draft.addErrback(onError)
defer_response(new_draft)
deferred_check.addCallback(return422otherwise)