summaryrefslogtreecommitdiff
path: root/service/pixelated/adapter
diff options
context:
space:
mode:
Diffstat (limited to 'service/pixelated/adapter')
-rw-r--r--service/pixelated/adapter/mail_service.py2
-rw-r--r--service/pixelated/adapter/pixelated_mail.py14
2 files changed, 10 insertions, 6 deletions
diff --git a/service/pixelated/adapter/mail_service.py b/service/pixelated/adapter/mail_service.py
index 3cbbe90e..e3444b9f 100644
--- a/service/pixelated/adapter/mail_service.py
+++ b/service/pixelated/adapter/mail_service.py
@@ -62,7 +62,7 @@ class MailService:
raise NotImplementedError()
def mark_as_read(self, mail_id):
- raise NotImplementedError()
+ return self.mail(mail_id).mark_as_read()
def tags_for_thread(self, thread):
raise NotImplementedError()
diff --git a/service/pixelated/adapter/pixelated_mail.py b/service/pixelated/adapter/pixelated_mail.py
index cf0e12a5..8ed27262 100644
--- a/service/pixelated/adapter/pixelated_mail.py
+++ b/service/pixelated/adapter/pixelated_mail.py
@@ -33,7 +33,7 @@ class PixelatedMail:
mail.headers = mail._extract_headers()
mail.date = PixelatedMail._get_date(mail.headers)
mail.ident = leap_mail.getUID()
- mail.status = mail._extract_status()
+ mail.status = set(mail._extract_status())
mail.security_casing = {}
mail.tags = mail._extract_tags()
return mail
@@ -75,6 +75,9 @@ class PixelatedMail:
self._persist_mail_tags(tags)
return self.tags
+ def mark_as_read(self):
+ self.status.add("read")
+
def _persist_mail_tags(self, current_tags):
tags_headers = [tag.name for tag in current_tags]
hdoc = self.leap_mail.hdoc
@@ -126,8 +129,9 @@ class PixelatedMail:
def from_dict(mail_dict):
mail = PixelatedMail()
- mail.headers = mail_dict['header']
- mail.body = mail_dict['body']
- mail.ident = mail_dict['ident']
- mail.tags = mail_dict['tags']
+ mail.headers = mail_dict.get('header', {})
+ mail.body = mail_dict.get('body', '')
+ mail.ident = mail_dict.get('ident', None)
+ mail.tags = mail_dict.get('tags', [])
+ mail.status = set(mail_dict.get('status', []))
return mail