commit 165c0fcd811c4f1766ff90c04f2b00ca10be9ab0 Author: David Fifield david@bamsoftware.com Date: Wed Oct 3 11:48:57 2012 -0700
Delete Gmail messages from Trash to really delete them.
After being deleted from INBOX, messages were being "archived" in All Mail. We can delete them for good by copying them to Trash and then deleting them. https://support.google.com/mail/bin/answer.py?answer=78755 http://gmailblog.blogspot.com/2008/10/new-in-labs-advanced-imap-controls.htm... --- facilitator/facilitator-email-poller | 33 ++++++++++++++++++++++++++++----- 1 files changed, 28 insertions(+), 5 deletions(-)
diff --git a/facilitator/facilitator-email-poller b/facilitator/facilitator-email-poller index 3f5c4d8..412b5eb 100755 --- a/facilitator/facilitator-email-poller +++ b/facilitator/facilitator-email-poller @@ -239,14 +239,32 @@ def handle_message(msg): log(u"registering %s" % safe_str(fac.format_addr(client_addr))) fac.put_reg(FACILITATOR_ADDR, client_addr)
+def imap_empty_trash(imap): + typ, data = imap.select("[Gmail]/Trash") + imap.store("1:*", "+FLAGS", "\Deleted") + imap.expunge() + +# Gmail's IMAP folders are funny: they are not real folders, but actually views +# of messages having a particular label. INBOX consists of messages having the +# INBOX label, for example. Deleting a message from a folder just removes its +# label, but the message itself continues to exist in "[Gmail]/All Mail". +# https://support.google.com/mail/bin/answer.py?answer=78755 +# http://gmailblog.blogspot.com/2008/10/new-in-labs-advanced-imap-controls.htm... +# To really delete a message, you must copy it to "[Gmail]/Trash" and then +# delete it from there. Messages in Trash are deleted automatically after 30 +# days, but we do it immediately. def imap_loop(imap): + # Empty the trash first thing, in case there are messages there from a + # previous failed run of this program or something. + imap_empty_trash(imap) + while True: - typ, data = imap.select() + typ, data = imap.select("[Gmail]/All Mail") exists = int(data[0])
for i in range(exists): - # Grab and delete message 1 on each iteration; remaining messages - # shift down so the next message we process is also message 1. + # Grab message 1 on each iteration; remaining messages shift down so + # the next message we process is also message 1. typ, data = imap.fetch(1, "(BODY[])") if data[0] is None: break @@ -257,8 +275,13 @@ def imap_loop(imap): except Exception, e: log("Error processing message, deleting anyway: %s" % str(e))
- imap.store(1, "+FLAGS", "\Deleted") - imap.expunge() + imap.copy(1, "[Gmail]/Trash") + # Attempting to delete from All Mail here would have no effect. + # Messages disappear from All Mail when they are deleted from Trash + # in the next step. + + # Now delete all messages from Trash to really delete them. + imap_empty_trash(imap)
time.sleep(POLL_INTERVAL)
tor-commits@lists.torproject.org