Whole document tree
    

Whole document tree

The Mailman Wishlist - GNU Project - Free Software Foundation (FSF)
  
  

The Mailman Wishlist

You should consider this list of items a good basis for the requirements for Mailman 3.0. It essentially contains a dream list of all the things that are too painful or destabilizing for the 2.x series.

Email Handling

  • Use VERP or DSN for address tracing, perhaps tied to the monthly password reminders, or VERPing the occasional regular message.
  • Re-implement bulk mailer the Right Way: an asynchat/asyncore server to do DNS lookups and remote MTA delivery directly (optional).
  • Plain text digests should conform to RFC 1153.
  • If a message has MIME parts and the header/footer is going to be added, the message should be transformed into a mulitpart/mixed with the header and footer added as text/plain parts.

Documentation

  • A detailed feature list
  • A user's guide
  • A site-admin's guide
  • A list-admin's guide
  • More on-line documentation and UI help
  • A developer's guide w/ architecture and API information
  • manpages for the scripts in bin and cron
  • Integrate Christopher Kolar's documentation

General Web UI

  • NO DEAD ENDS
  • All web UI must be configurable so that it more easily integrates into an existing site's design. Probably means using a template language/system like Quixote or PHP.
  • Default UI should add a navigation sidebar to all web pages.
  • A heirarchy of page designs and information: e.g. the most specialized of the following wins: site, virtual host, list, language, user.
  • Web pages should never mention turned-off features.

List Administration

  • Separate list admin role from list moderator role
  • Allow the moderator to edit posts being held for approval (make it evident, either through a header or other means that the message was edited by the moderator).
  • Allow "urgent" postings to all members by the list admin which bypasses normal digest delivery.
  • A button that will bundled and deliver a digest Right Now.
  • Allow the list-admin to require approvals for unsubs
  • Allow the admin to disable option settings by users
  • Ability to set defaults for the various user settings from the "Membership Management" page.
  • Allow admins to control and set individual headers, adding, removing, or overriding those in the original message (sometimes very useful, but could be dangerous!)
  • Member management page should display case-preserved email addresses (but still sort case-insensitively).
  • Member management page should work better for humongous lists, both in terms of performance, and in usability
  • Searching for members/addresses with regular expressions from both the command line and web interface.
  • New moderation choice: archive but don't send to list.
  • New moderation choice: annotate and send to author for resubmittal.
  • Make it easier for an admin who manages multiple lists to handling pending requests sitting on all those lists.
  • Ability to ban specific troublesome users (from posting, subscribing, etc). Posts from banned users would be discarded.
  • Better integration with moderated newsgroups (and allow some addresses to bypass even that moderation and be delivered to a secondary channel, like moderators@isc.org).
  • Ability to set the next digest volume and issue number from the web
  • Add an option to include Reply-To: header in the membership test for a members-only list posting

List Membership

  • Editing your user options should put you back to the edit-options page
  • Allow the user to be excluded from postings if they're getting them in the to: or cc: headers. Be smarter about filtering out duplicate deliveries.
  • Have one account per user per site, with multiple email addresses and fallbacks. Allow them to subscribe whichever address they want to whichever list, with different options per subscription.
  • Allow the user to get BOTH normal and digested delivery (but I still don't understand why someone would want this)
  • More flexible digests: index digests (subject and authors only, with URLs to retrieve the article)
  • Allow users to subscribe without selecting a password and have Mailman create a password for them.
  • Timed vacations, allowing a user to postpone or discard email for a certain number of days or weeks.

Site Administration

  • Allow the site admin to define list styles or themes, and list admins to choose one of the canned styles to apply to their list.
  • Full creation, deletion, renaming, etc. of lists through the web (and email?), including fixing aliases file updates.
  • add_members should have a switch to disable admin notifications

Other Usability Improvments

  • Allow individuals to turn off password reminders
  • Confirmations should be both email and web based, and be used for both subscription and unsubscription (configurable by the list admin).
  • A better strategy is needed for sub-lists and super-lists, including dealing with the resulting password reminders and authorization to modify the sub & superlists. Majordomo2 is reported to have some good features in this regard.
  • Add a limit on the number of posts from any one individual within a period of time (1 post per day, 10 per week, etc).
  • Don't use the first public mailing list as the `originator' of password reminders.

Mailcmd interface

  • Provide an email interface to all administrative commands
  • Allow email unsubs from matching address to unsubscribe, possibly adding an "allow open unsubscribes" option to control this. Also, adding a confirmation with hit-reply to resubscribe
  • Add -join and -remove addresses for easy subscription, unsubscription
  • For email subscribes, keep an audit of where requests are coming from, and send the original request headers in the confirmation message. Helps track down subscribe bombs.
  • Investigate Majordomo2's email admin capabilities.
  • Support the `which' command.

Portability & architecture

  • Replace cron stuff with our own scheduling mechanism.
  • Get rid of the one-shot process model altogether in favor of a multithreaded monolithic architecture.
  • Better support for distributed processing
  • Use a real transactional database for all information, and allow various bits of information to come from different sources (a relational database, ZODB, LDAP, etc)
  • Keep a members Real Name with their email address
  • Member profiles
  • Do a serious and thorough security audit
  • Allow lists of the same name in two different virtual domains
  • More sophisticated attachment handling: strip and discard attachments, post attachments (e.g. via WebDAV) and rewrite to include URLs, etc. Should be admin configurable based on MIME type. Check out Bill Bumgarner's work on this.
  • Should include a --with-username=NAME option to configure (and not require it be literally "mailman").
  • Should be able to gather statistics, such as deliveries/day, performance, number of subscribers over time, etc.
  • Implement something like Roundup's nosy lists, maybe even integrate with Roundup.
  • Split Mailman into libraries so, e.g. the delivery part could be used by other projects.

Bounce handling

  • Make a distinction between disabled addresses due to bouncing and a user's explicit disabling of an address
  • Add more patterns for bounce handling (never ending)
  • Occasionally remove stale bounce entries
  • Send mail to people who are being removed without their knowledge (even though they're likely not to get it).
  • Reminders to disabled addresses. The idea is that if an addr is disabled due to bouncing, we should send out periodic reminders. We may want to do this for explicitly disabled addrs too, but perhaps with a different schedule.
  • Delete bounce disabled address after some period of retry

Pipermail + Archiving mechanism

  • Search engine for archives
  • Provide downloadable tar.gz's of the html archives
  • sort by date should go most-recent to oldest
  • allow list owner to edit archive messages
  • archive link should do *something* reasonable before the first message has been posted to the list.
  • optional form front-end to public interfaces as a filter to address harvesters.
  • clobber_date should support third option: only munge the date if the Date: field is unreasonable (far in the future or far in the past).
  • In general the whole Pipermail subsystem needs a good rewrite.

Code cleanup

  • Use all the new wizzy Python 2.0 features
  • Use the re module where regexp and regsub are used (not many left)
  • Refine any remaining unqualified exception guards to specify target exceptions, when appropriate.
  • Turn all remaining string exceptions into class exceptions
  • Remove dead code.
  • Unit and system test suite!