diff options
author | Folker Bernitt <fbernitt@thoughtworks.com> | 2015-09-02 12:35:33 +0200 |
---|---|---|
committer | Folker Bernitt <fbernitt@thoughtworks.com> | 2015-09-02 12:35:33 +0200 |
commit | e5d718f982e0cd3fc85da00d3abdccce1907e488 (patch) | |
tree | ebf566a96a2b70c7f234c81065ee48054bf555a3 /service/pixelated/resources | |
parent | 503c917ede122fc97046e35af8ec30a25adbad32 (diff) |
Download attachments from mail store instead of querier
- Issue #435
- Improved error handling of attachment resource
Diffstat (limited to 'service/pixelated/resources')
-rw-r--r-- | service/pixelated/resources/attachments_resource.py | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/service/pixelated/resources/attachments_resource.py b/service/pixelated/resources/attachments_resource.py index 0a903cc4..a78022ec 100644 --- a/service/pixelated/resources/attachments_resource.py +++ b/service/pixelated/resources/attachments_resource.py @@ -18,7 +18,7 @@ import io import re from twisted.protocols.basic import FileSender -from twisted.python.log import err +from twisted.python.log import msg from twisted.web import server from twisted.web.resource import Resource from twisted.internet import defer @@ -34,23 +34,28 @@ class AttachmentResource(Resource): self.mail_service = mail_service def render_GET(self, request): + def error_handler(failure): + msg(failure, 'attachment not found') + request.code = 404 + request.finish() encoding = request.args.get('encoding', [None])[0] filename = request.args.get('filename', [self.attachment_id])[0] request.setHeader(b'Content-Type', b'application/force-download') request.setHeader(b'Content-Disposition', bytes('attachment; filename=' + filename)) d = self._send_attachment(encoding, filename, request) - d.addErrback(err) + d.addErrback(error_handler) return server.NOT_DONE_YET @defer.inlineCallbacks def _send_attachment(self, encoding, filename, request): - attachment = yield self.mail_service.attachment(self.attachment_id, encoding) + attachment = yield self.mail_service.attachment(self.attachment_id) bytes_io = io.BytesIO(attachment['content']) try: + request.code = 200 yield FileSender().beginFileTransfer(bytes_io, request) finally: bytes_io.close() |