diff options
| author | Tomás Touceda <chiiph@leap.se> | 2014-02-27 10:48:56 -0300 | 
|---|---|---|
| committer | Tomás Touceda <chiiph@leap.se> | 2014-02-27 10:48:56 -0300 | 
| commit | 80d8172c4bc141d4fd723ab376daa359bbe53fec (patch) | |
| tree | e0ef12472d8bf83583dbdb74ccd65f5fbcc9f4f3 | |
| parent | b0ad4109a3157cb48f60b6229eff530c0fe7d260 (diff) | |
| parent | 69f58cc351f6e645f18112d3177c50cb07d7fd6f (diff) | |
Merge remote-tracking branch 'refs/remotes/kali/bug/fix-notify' into develop
| -rw-r--r-- | mail/changes/bug_5167_fix-notify-after-copy | 2 | ||||
| -rw-r--r-- | mail/changes/bug_5177_fix_unread_signal_to_ui | 1 | ||||
| -rw-r--r-- | mail/src/leap/mail/imap/mailbox.py | 68 | 
3 files changed, 53 insertions, 18 deletions
| diff --git a/mail/changes/bug_5167_fix-notify-after-copy b/mail/changes/bug_5167_fix-notify-after-copy new file mode 100644 index 0000000..36ecd0b --- /dev/null +++ b/mail/changes/bug_5167_fix-notify-after-copy @@ -0,0 +1,2 @@ +  o Fix bug in which destination folder sometimes was not showing messages after copy/append. +    Closes: #5167 diff --git a/mail/changes/bug_5177_fix_unread_signal_to_ui b/mail/changes/bug_5177_fix_unread_signal_to_ui new file mode 100644 index 0000000..eac79f2 --- /dev/null +++ b/mail/changes/bug_5177_fix_unread_signal_to_ui @@ -0,0 +1 @@ +  o Fix unread notifications to client UI. Only INBOX is notified. Closes: #5177 diff --git a/mail/src/leap/mail/imap/mailbox.py b/mail/src/leap/mail/imap/mailbox.py index 947cf1b..d8e6cb1 100644 --- a/mail/src/leap/mail/imap/mailbox.py +++ b/mail/src/leap/mail/imap/mailbox.py @@ -371,15 +371,7 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          :rtype: int          """          with self.next_uid_lock: -            if self._memstore: -                return self.last_uid + 1 -            else: -                # XXX after lock, it should be safe to -                # return just the increment here, and -                # have a different method that actually increments -                # the counter when really adding. -                self.last_uid += 1 -                return self.last_uid +            return self.last_uid + 1      def getMessageCount(self):          """ @@ -474,7 +466,12 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          d = self._do_add_message(message, flags=flags, date=date)          if PROFILE_CMD:              do_profile_cmd(d, "APPEND") -        # XXX should notify here probably +        # A better place for this would be  the COPY/APPEND dispatcher +        # in server.py, but qtreactor hangs when I do that, so this seems +        # to work fine for now. +        d.addCallback(lambda r: self.reactor.callLater(0, self.notify_new)) +        d.addCallback(self.cb_signal_unread_to_ui) +        d.addErrback(lambda f: log.msg(f.getTraceback()))          return d      def _do_add_message(self, message, flags, date): @@ -485,7 +482,6 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          d = self.messages.add_msg(message, flags=flags, date=date)          return d -    @deferred_to_thread      def notify_new(self, *args):          """          Notify of new messages to all the listeners. @@ -494,13 +490,28 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          """          if not NOTIFY_NEW:              return + +        def cbNotifyNew(result): +            exists, recent = result +            for l in self.listeners: +                l.newMessages(exists, recent) +        d = self._get_notify_count() +        d.addCallback(cbNotifyNew) + +    @deferred_to_thread +    def _get_notify_count(self): +        """ +        Get message count and recent count for this mailbox +        Executed in a separate thread. Called from notify_new. + +        :return: number of messages and number of recent messages. +        :rtype: tuple +        """          exists = self.getMessageCount()          recent = self.getRecentCount()          logger.debug("NOTIFY (%r): there are %s messages, %s recent" % (              self.mbox, exists, recent)) - -        for l in self.listeners: -            l.newMessages(exists, recent) +        return exists, recent      # commands, do not rename methods @@ -595,6 +606,7 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          self.reactor.callInThread(self._do_fetch, messages_asked, uid, d)          if PROFILE_CMD:              do_profile_cmd(d, "FETCH") +        d.addCallback(self.cb_signal_unread_to_ui)          return d      # called in thread @@ -750,14 +762,27 @@ class SoledadMailbox(WithMsgFields, MBoxParser):              for msgid in seq_messg)          return result -    def signal_unread_to_ui(self, *args, **kwargs): +    def cb_signal_unread_to_ui(self, result):          """          Sends unread event to ui. +        Used as a callback in several commands. -        :param args: ignored -        :param kwargs: ignored +        :param result: ignored +        """ +        d = self._get_unseen_deferred() +        d.addCallback(self.__cb_signal_unread_to_ui) +        return result + +    @deferred_to_thread +    def _get_unseen_deferred(self): +        return self.getUnseenCount() + +    def __cb_signal_unread_to_ui(self, unseen): +        """ +        Send the unread signal to UI. +        :param unseen: number of unseen messages. +        :type unseen: int          """ -        unseen = self.getUnseenCount()          leap_events.signal(IMAP_UNREAD_MAIL, str(unseen))      def store(self, messages_asked, flags, mode, uid): @@ -798,6 +823,8 @@ class SoledadMailbox(WithMsgFields, MBoxParser):                                 mode, uid, d)          if PROFILE_CMD:              do_profile_cmd(d, "STORE") +        d.addCallback(self.cb_signal_unread_to_ui) +        d.addErrback(lambda f: log.msg(f.getTraceback()))          return d      def _do_store(self, messages_asked, flags, mode, uid, observer): @@ -880,6 +907,11 @@ class SoledadMailbox(WithMsgFields, MBoxParser):          d = defer.Deferred()          if PROFILE_CMD:              do_profile_cmd(d, "COPY") + +        # A better place for this would be  the COPY/APPEND dispatcher +        # in server.py, but qtreactor hangs when I do that, so this seems +        # to work fine for now. +        d.addCallback(lambda r: self.reactor.callLater(0, self.notify_new))          deferLater(self.reactor, 0, self._do_copy, message, d)          return d | 
