#! /usr/bin/python2
#
# Copyright (C) 1998-2011 by the Free Software Foundation, Inc.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
"""Remove the components of a mailing list with impunity - beware!
This removes (almost) all traces of a mailing list.  By default, the lists
archives are not removed, which is very handy for retiring old lists.
Usage:
    rmlist [-a] [-h] listname
Where:
    --archives
    -a
        Remove the list's archives too, or if the list has already been
        deleted, remove any residual archives.
    --help
    -h
        Print this help message and exit.
"""
import os
import re
import sys
import getopt
import shutil
import paths
from Mailman import mm_cfg
from Mailman import Utils
from Mailman import MailList
from Mailman.i18n import C_
try:
    True, False
except NameError:
    True = 1
    False = 0
def usage(code, msg=''):
    if code:
        fd = sys.stderr
    else:
        fd = sys.stdout
    print >> fd, C_(__doc__)
    if msg:
        print >> fd, msg
    sys.exit(code)
def remove_it(listname, filename, msg):
    if os.path.islink(filename):
        print C_('Removing %(msg)s')
        os.unlink(filename)
    elif os.path.isdir(filename):
        print C_('Removing %(msg)s')
        shutil.rmtree(filename)
    elif os.path.isfile(filename):
        os.unlink(filename)
    else:
        print C_('%(listname)s %(msg)s not found as %(filename)s')
def main():
    try:
        opts, args = getopt.getopt(sys.argv[1:], 'ah',
                                   ['archives', 'help'])
    except getopt.error, msg:
        usage(1, msg)
    if len(args) <> 1:
        usage(1)
    listname = args[0].lower().strip()
    removeArchives = False
    for opt, arg in opts:
        if opt in ('-a', '--archives'):
            removeArchives = True
        elif opt in ('-h', '--help'):
            usage(0)
    if not Utils.list_exists(listname):
        if not removeArchives:
            usage(1, C_('No such list (or list already deleted): %(listname)s'))
        else:
            print C_(
                'No such list: %(listname)s.  Removing its residual archives.')
    if not removeArchives:
        print C_('Not removing archives.  Reinvoke with -a to remove them.')
    REMOVABLES = []
    if Utils.list_exists(listname):
        mlist = MailList.MailList(listname, lock=0)
        # Do the MTA-specific list deletion tasks
        if mm_cfg.MTA:
            modname = 'Mailman.MTA.' + mm_cfg.MTA
            __import__(modname)
            sys.modules[modname].remove(mlist)
        REMOVABLES = [
            (os.path.join(mm_cfg.LIST_DATA_DIR, listname), C_('list info')),
            ]
    # Remove any stale locks associated with the list
    for filename in os.listdir(mm_cfg.LOCK_DIR):
        fn_listname = filename.split('.')[0]
        if fn_listname == listname:
            REMOVABLES.append((os.path.join(mm_cfg.LOCK_DIR, filename),
                               C_('stale lock file')))
    # Remove any held messages for this list
    for filename in os.listdir(mm_cfg.DATA_DIR):
        cre = re.compile('^heldmsg-%s-\d+\.(pck|txt)$' % listname,
                         re.IGNORECASE)
        if cre.match(filename):
            REMOVABLES.append((os.path.join(mm_cfg.DATA_DIR, filename),
                               C_('held message file')))
    if removeArchives:
        REMOVABLES.extend([
            (os.path.join(mm_cfg.PRIVATE_ARCHIVE_FILE_DIR, listname),
             C_('private archives')),
            (os.path.join(mm_cfg.PRIVATE_ARCHIVE_FILE_DIR, listname + '.mbox'),
             C_('private archives')),
            (os.path.join(mm_cfg.PUBLIC_ARCHIVE_FILE_DIR, listname),
             C_('public archives')),
            (os.path.join(mm_cfg.PUBLIC_ARCHIVE_FILE_DIR, listname + '.mbox'),
             C_('public archives')),
            ])
    for dir, msg in REMOVABLES:
        remove_it(listname, dir, msg)
if __name__ == '__main__':
    main()
 |