X-Git-Url: https://git.madduck.net/etc/mailfilter.git/blobdiff_plain/79aefc4e56fb0bc243999c4437dbbb4bd5afa27c..7478c422e79142bfb2f067b002c627c063b33a8b:/bin/process-tickler diff --git a/bin/process-tickler b/bin/process-tickler index c853294..71f750a 100755 --- a/bin/process-tickler +++ b/bin/process-tickler @@ -15,28 +15,32 @@ import time HOME = os.getenv('HOME') MAILDIR = os.path.join(HOME, '.maildir') TICKLER_DIR = os.path.join(MAILDIR, '.tickler') -INBOX_DIR = MAILDIR +DEST_DIR = os.path.join(MAILDIR, '.resubmit') tmd = mailbox.Maildir(TICKLER_DIR) -imd = mailbox.Maildir(INBOX_DIR) +dmd = mailbox.Maildir(DEST_DIR) msgids = dict() -def move_to_inbox(key): +def resubmit(key): msg = tmd.get_message(key) - print >>sys.stdout, 'I: move message %s to inbox' % key - imd.add(msg) + print >>sys.stdout, 'I: resubmit message %s' % key + if msg.has_key('X-Tickle-Delivered'): + msg.replace_header('X-Tickle-Delivered', time.strftime('%c')) + else: + msg.add_header('X-Tickle-Delivered', time.strftime('%c')) + dmd.add(msg) tmd.discard(key) for key, msg in tmd.iteritems(): msgid = msg.get('Message-Id') if msgid is None: print >>sys.stderr, 'W: message without ID: ' + key - move_to_inbox(key) + resubmit(key) tickle = msg.get('X-Tickle') if tickle is None: print >>sys.stderr, 'W: message without tickle information: ' + key - move_to_inbox(key) + resubmit(key) if msgids.get(msgid, None) is None: msgids[msgid] = list() @@ -54,7 +58,7 @@ for msgid, msgs in msgids.iteritems(): t = time.time() if t >= tickle: - move_to_inbox(key) + resubmit(key) else: print >>sys.stdout, 'I: message %s still has %d seconds' % (key, int(tickle - t))