diff options
author | Victor Shyba <victor.shyba@gmail.com> | 2015-08-24 20:49:31 -0300 |
---|---|---|
committer | Victor Shyba <victor.shyba@gmail.com> | 2015-08-24 20:49:31 -0300 |
commit | d0ae96039273ecc0c1d06f76209484ae420431f8 (patch) | |
tree | 26889e5daba02f2b9bf4beb701a336e7b88caa92 /service/pixelated/adapter/listeners | |
parent | 87553d5975084ff8a8c05ec876a2ce06c134bd3a (diff) |
[bug] adapt MailboxIndexer to mail_store
-- Issue #439
Diffstat (limited to 'service/pixelated/adapter/listeners')
-rw-r--r-- | service/pixelated/adapter/listeners/mailbox_indexer_listener.py | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/service/pixelated/adapter/listeners/mailbox_indexer_listener.py b/service/pixelated/adapter/listeners/mailbox_indexer_listener.py index 3af4e62e..ce056a3c 100644 --- a/service/pixelated/adapter/listeners/mailbox_indexer_listener.py +++ b/service/pixelated/adapter/listeners/mailbox_indexer_listener.py @@ -24,23 +24,25 @@ class MailboxIndexerListener(object): @classmethod @defer.inlineCallbacks - def listen(cls, account, mailbox_name, soledad_querier): - listener = MailboxIndexerListener(mailbox_name, soledad_querier) + def listen(cls, account, mailbox_name, mail_store): + listener = MailboxIndexerListener(mailbox_name, mail_store) if listener not in (yield account.getMailbox(mailbox_name)).listeners: mbx = yield account.getMailbox(mailbox_name) mbx.addListener(listener) - def __init__(self, mailbox_name, soledad_querier): + def __init__(self, mailbox_name, mail_store): self.mailbox_name = mailbox_name - self.querier = soledad_querier + self.mail_store = mail_store + @defer.inlineCallbacks def newMessages(self, exists, recent): indexed_idents = set(self.SEARCH_ENGINE.search('tag:' + self.mailbox_name.lower(), all_mails=True)) - soledad_idents = self.querier.idents_by_mailbox(self.mailbox_name) + soledad_idents = yield self.mail_store.get_mailbox_mail_ids(self.mailbox_name) + soledad_idents = set(soledad_idents) missing_idents = soledad_idents.difference(indexed_idents) - self.SEARCH_ENGINE.index_mails(self.querier.mails(missing_idents)) + self.SEARCH_ENGINE.index_mails((yield self.mail_store.get_mails(missing_idents))) def __eq__(self, other): return other and other.mailbox_name == self.mailbox_name |