summaryrefslogtreecommitdiff
path: root/src/mailman/commands/cli_members.py
diff options
context:
space:
mode:
authorBarry Warsaw2010-01-23 19:48:00 -0500
committerBarry Warsaw2010-01-23 19:48:00 -0500
commit3ad94d9ff4649b5e5046174d5337d68266643128 (patch)
treead86b2f90ce0c8185ab7f65a4fb60507ea78f1e0 /src/mailman/commands/cli_members.py
parent0ea2e10deb8e05a6afd6bb0bd32f62ee4e00ba83 (diff)
downloadmailman-3ad94d9ff4649b5e5046174d5337d68266643128.tar.gz
mailman-3ad94d9ff4649b5e5046174d5337d68266643128.tar.zst
mailman-3ad94d9ff4649b5e5046174d5337d68266643128.zip
Diffstat (limited to 'src/mailman/commands/cli_members.py')
-rw-r--r--src/mailman/commands/cli_members.py29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/mailman/commands/cli_members.py b/src/mailman/commands/cli_members.py
index 538b885db..8cab15bfc 100644
--- a/src/mailman/commands/cli_members.py
+++ b/src/mailman/commands/cli_members.py
@@ -65,6 +65,18 @@ class Members:
dest='output_filename', metavar='FILENAME',
help=_("""Display output to FILENAME instead of stdout. FILENAME
can be '-' to indicate standard output."""))
+ command_parser.add_argument(
+ '-r', '--regular',
+ default=None, action='store_true',
+ help=_('Display only regular delivery members.'))
+ command_parser.add_argument(
+ '-d', '--digest',
+ default=None, metavar='KIND',
+ # BAW 2010-01-23 summary digests are not really supported yet.
+ choices=('any', 'plaintext', 'mime'),
+ help=_("""Display only digest members of KIND. 'any' means any
+ digest type, 'plaintext' means only plain text (RFC 1153) type
+ digests, 'mime' means MIME type digests."""))
# Required positional argument.
command_parser.add_argument(
'listname', metavar='LISTNAME', nargs=1,
@@ -98,12 +110,29 @@ class Members:
fp = sys.stdout
else:
fp = codecs.open(args.output_filename, 'w', 'utf-8')
+ if args.digest == 'any':
+ digest_types = [DeliveryMode.plaintext_digests,
+ DeliveryMode.mime_digests,
+ DeliveryMode.summary_digests]
+ elif args.digest is not None:
+ digest_types = [DeliveryMode(args.digest + '_digests')]
+ else:
+ # Don't filter on digest type.
+ pass
try:
addresses = list(mlist.members.addresses)
if len(addresses) == 0:
print >> fp, mlist.fqdn_listname, 'has no members'
return
for address in sorted(addresses, key=attrgetter('address')):
+ if args.regular:
+ member = mlist.members.get_member(address.address)
+ if member.delivery_mode != DeliveryMode.regular:
+ continue
+ if args.digest is not None:
+ member = mlist.members.get_member(address.address)
+ if member.delivery_mode not in digest_types:
+ continue
print >> fp, formataddr(
(address.real_name, address.original_address))
finally: