diff options
-rw-r--r-- | service/app/adapter/pixelated_mail.py | 62 | ||||
-rw-r--r-- | service/test/adapter/pixelated_mail_test.py | 33 |
2 files changed, 95 insertions, 0 deletions
diff --git a/service/app/adapter/pixelated_mail.py b/service/app/adapter/pixelated_mail.py new file mode 100644 index 00000000..412414ed --- /dev/null +++ b/service/app/adapter/pixelated_mail.py @@ -0,0 +1,62 @@ +from app.tags import Tag + + +class PixelatedMail: + + LEAP_FLAGS = ['\\Seen', + '\\Answered', + '\\Flagged', + '\\Deleted', + '\\Draft', + '\\Recent', + 'List'] + + LEAP_FLAGS_STATUSES = { + '\\Seen': 'read', + '\\Answered': 'replied' + } + + LEAP_FLAGS_TAGS = { + '\\Deleted': 'trash', + '\\Draft': 'drafts', + '\\Recent': 'inbox' + } + + def __init__(self, leap_mail): + self.leap_mail = leap_mail + self.body = leap_mail.bdoc.content['raw'] + self.headers = self.extract_headers(leap_mail) + self.ident = leap_mail.getUID() + self.status = self.extract_status(leap_mail) + self.security_casing = {} + self.tags = self.extract_tags(leap_mail) + + def extract_status(self, leap_mail): + flags = leap_mail.getFlags() + return [converted for flag, converted in self.LEAP_FLAGS_STATUSES.items() if flag in flags] + + def extract_headers(self, leap_mail): + temporary_headers = {} + for header, value in leap_mail.hdoc.content['headers'].items(): + temporary_headers[header.lower()] = value + return temporary_headers + + def extract_tags(self, leap_mail): + flags = leap_mail.getFlags() + converted_tags = [Tag(converted) for flag, converted in self.LEAP_FLAGS_TAGS.items() if flag in flags] + tags = converted_tags + [Tag(flag) for flag in leap_mail.getFlags() if flag not in self.LEAP_FLAGS] + return tags + + def has_tag(self, tag): + return Tag(tag) in self.tags + + def as_dict(self): + tags = [tag.name for tag in self.tags] + return { + 'header': self.headers, + 'ident': self.ident, + 'tags': tags, + 'status': self.status, + 'security_casing': self.security_casing, + 'body': self.body + } diff --git a/service/test/adapter/pixelated_mail_test.py b/service/test/adapter/pixelated_mail_test.py new file mode 100644 index 00000000..9193464b --- /dev/null +++ b/service/test/adapter/pixelated_mail_test.py @@ -0,0 +1,33 @@ +import unittest + +from app.adapter.pixelated_mail import PixelatedMail +from mock import Mock +from app.tags import Tag + + +class TestPixelatedMail(unittest.TestCase): + + LEAP_FLAGS = ['\\Seen', + '\\Answered', + '\\Flagged', + '\\Deleted', + '\\Draft', + '\\Recent', + 'List'] + + def setUp(self): + self.leap_mail = Mock(getUID=Mock(return_value=0), + getFlags=Mock(return_value=self.LEAP_FLAGS), + bdoc=Mock(content={'raw': 'test'}), + hdoc=Mock(content={'headers': {}})) + + def test_leap_flags_that_are_tags_are_handled(self): + pixelated_mail = PixelatedMail(self.leap_mail) + self.assertIn(Tag('inbox'), pixelated_mail.tags) + self.assertIn(Tag('trash'), pixelated_mail.tags) + self.assertIn(Tag('drafts'), pixelated_mail.tags) + + def test_leap_flags_that_are_status_are_handled(self): + pixelated_mail = PixelatedMail(self.leap_mail) + self.assertIn('read', pixelated_mail.status) + self.assertIn('replied', pixelated_mail.status) |