diff options
-rw-r--r-- | service/integration/tags_test.py | 10 | ||||
-rw-r--r-- | service/pixelated/adapter/mail_service.py | 3 | ||||
-rw-r--r-- | service/pixelated/adapter/pixelated_mail.py | 6 | ||||
-rw-r--r-- | service/pixelated/adapter/tag_service.py | 6 | ||||
-rw-r--r-- | service/pixelated/user_agent.py | 13 |
5 files changed, 29 insertions, 9 deletions
diff --git a/service/integration/tags_test.py b/service/integration/tags_test.py index a0743b6a..eb278a71 100644 --- a/service/integration/tags_test.py +++ b/service/integration/tags_test.py @@ -33,7 +33,7 @@ class TagsTest(unittest.TestCase, SoledadTestBase): mail = MailBuilder().with_subject('Mail with tags').build_input_mail() self.pixelated_mailboxes.inbox().add(mail) - self.post_tags(mail.ident, self._tags_json(['INBOX', 'IMPORTANT'])) + self.post_tags(mail.ident, self._tags_json(['IMPORTANT'])) mails = self.get_mails_by_tag('inbox') self.assertEquals({'inbox', 'important'}, set(mails[0].tags)) @@ -41,4 +41,12 @@ class TagsTest(unittest.TestCase, SoledadTestBase): mails = self.get_mails_by_tag('important') self.assertEquals('Mail with tags', mails[0].subject) + def test_addition_of_reserved_tags_is_not_allowed(self): + mail = MailBuilder().with_subject('Mail with tags').build_input_mail() + self.pixelated_mailboxes.inbox().add(mail) + + response = self.post_tags(mail.ident, self._tags_json(['DRAFTS'])) + self.assertEquals("None of the following words can be used as tags: ['drafts']", response) + mail = self.pixelated_mailboxes.inbox().mail(mail.ident) + self.assertNotIn('drafts', mail.tags) diff --git a/service/pixelated/adapter/mail_service.py b/service/pixelated/adapter/mail_service.py index c216e7ae..8be04984 100644 --- a/service/pixelated/adapter/mail_service.py +++ b/service/pixelated/adapter/mail_service.py @@ -35,6 +35,9 @@ class MailService: return sorted(_mails or [], key=lambda mail: mail.headers['Date'], reverse=True) def update_tags(self, mail_id, new_tags): + reserved_words = self.tag_service.extract_reserved(new_tags) + if len(reserved_words): + raise ValueError('None of the following words can be used as tags: %s' % list(reserved_words)) mail = self.mail(mail_id) return mail.update_tags(set(new_tags)) diff --git a/service/pixelated/adapter/pixelated_mail.py b/service/pixelated/adapter/pixelated_mail.py index 3e0f1ee0..2f13cb01 100644 --- a/service/pixelated/adapter/pixelated_mail.py +++ b/service/pixelated/adapter/pixelated_mail.py @@ -24,7 +24,6 @@ import pixelated.support.date from email.MIMEMultipart import MIMEMultipart from email.MIMEText import MIMEText from pycryptopp.hash import sha256 -from pixelated.support.functional import flatten class InputMail: @@ -250,8 +249,9 @@ class PixelatedMail: return self def mark_as_not_recent(self): - self.fdoc.content['flags'].remove(Status.PixelatedStatus.RECENT) - self.save() + if Status.PixelatedStatus.RECENT in self.fdoc.content['flags']: + self.fdoc.content['flags'].remove(Status.PixelatedStatus.RECENT) + self.save() return self def _persist_mail_tags(self, current_tags): diff --git a/service/pixelated/adapter/tag_service.py b/service/pixelated/adapter/tag_service.py index 00f28b40..ecc64fad 100644 --- a/service/pixelated/adapter/tag_service.py +++ b/service/pixelated/adapter/tag_service.py @@ -20,7 +20,11 @@ from pixelated.adapter.tag_index import TagIndex class TagService: instance = None - SPECIAL_TAGS = {Tag('inbox', True), Tag('sent', True), Tag('drafts', True), Tag('trash', True)} + SPECIAL_TAGS = [Tag('inbox', True), Tag('sent', True), Tag('drafts', True), Tag('trash', True)] + + @classmethod + def extract_reserved(cls, tags): + return set(tag.name for tag in cls.SPECIAL_TAGS if tag.name in tags) @classmethod def get_instance(cls): diff --git a/service/pixelated/user_agent.py b/service/pixelated/user_agent.py index 2dc71bf0..8c7440b0 100644 --- a/service/pixelated/user_agent.py +++ b/service/pixelated/user_agent.py @@ -47,9 +47,11 @@ app = Flask(__name__, static_url_path='', static_folder=static_folder) DISABLED_FEATURES = ['draftReply', 'signatureStatus', 'encryptionStatus', 'contacts'] -def respond_json(entity): - response = json.dumps(entity) - return Response(response=response, mimetype="application/json") +def respond_json(entity, status_code=200): + json_response = json.dumps(entity) + response = Response(response=json_response, mimetype="application/json") + response.status_code = status_code + return response @app.route('/disabled_features') @@ -127,7 +129,10 @@ def mail(mail_id): @app.route('/mail/<mail_id>/tags', methods=['POST']) def mail_tags(mail_id): new_tags = map(lambda tag: tag.lower(), request.get_json()['newtags']) - tags = mail_service.update_tags(mail_id, new_tags) + try: + tags = mail_service.update_tags(mail_id, new_tags) + except ValueError as ve: + return respond_json(ve.message, 403) return respond_json(list(tags)) |