1. Collaborative maintenance of a single package
If you maintain collaboratively only a single package, you probably don't need a full Alioth project with mailing list and everything. You should use one VCS (subversion repository, GIT repository, bzr repository, ...) of the collab-maint project. Thanks to ACL, all Debian developers have write access on those repositories. For SVN, commit notifications are automatically sent to the Package Tracking System (you need to subscribe in "advanced mode" on the web interface and to activate the "cvs" keyword, check the PTS documentation).
To integrate your package in the subversion repository, use svn-inject (with option -o to avoid storing upstream sources) with the following URL: svn+ssh://svn.debian.org/svn/collab-maint/deb-maint/ It is also possible to import all your previous changes from an existing repository into the collab-maint repository, see Alioth/CollabMaintImport. If the package is maintained by external contributors, it should be put in the ext-maint directory instead of deb-maint (it can easily be moved later if needed).
If you need to grant access to external contributors, please send a signed email to email@example.com (and CC the contributor) saying:
Please grant access for FIRSTNAME LASTNAME (USERNAME-guest) to collab-maint. We are going to work together on project PROJECTNAME.
Contributors no longer need to apply to join the project first.
Debian maintainers do not need an advocate, they can ask access by sending signed email like this:
I am a DM and I need access to collab-maint. My alioth account name is NAME-guest and I am going to work on project PROJECTNAME.
1.1. Discussions between co-maintainers
Since you don't have a dedicated mailing list for the maintenance, you have 2 solutions:
- use extensively the BTS. You can submit wishlist bugs on your package to keep track of improvements that you want to do. Since co-maintainers are subscribed to the PTS, they will receive everything and the discussion can happen via the BTS itself. The BTS is the TODO list for your package and every contributor can follow your plans (and offer help and patches!).
use the alias <package>@packages.debian.org: the maintainer gets the mail directly and the co-maintainers get the mail through the PTS (if they are subscribed to the "contact" keyword)
1.2. Non-collaborative maintenance
If a maintainer wants to maintain his/her package within subversion, (s)he can use the collab-maint repository even if the package is not (yet) collaboratively maintained. This is always useful since contributors are more likely to propose patch if they can be sure that the work has not yet been done. That's why the use of the SVN repository should be documented through the Vcs-* field in debian/control (and through that, the PTS) or alternatively static news in the PTS (check the result on the debian-cd PTS page for examples).
2. Collaborative maintenance of a set of related packages
If you plan to maintain many related packages with the help of a team, you can request a dedicated Alioth project. Its name should start with "pkg-". This gives you access to all the services associated to an Alioth project (website, mailing lists, trackers, forums, etc.).
2.1. Configuring SVN to send commit notifications
It is very important that you install a SVN hook to send commit notifications to the Package Tracking System since this is the canonical way for many people to follow what's happening on a given source package.
Svnmailer is a python script that can be configured to handle this complicated task (extract the package name from the changeset and send out the diff to the right email) and it's available on svn.debian.org. You can find a sample configuration file with full comments (and a sample of a post-commit file for the hooks directory of a subversion repository) in the collab-maint SVN repository: post-commit and svnmailer.conf
You may need to modify the for_paths variable if packages maintained in the repository are somewhere else than in /packages/. If you have a mailing list which should receive all commit notifications, you can comment to_fake and use to_addr, listing there your mailing list for commits.
Please never disclose publicly the package_cvs _AT_ packages.qa.debian.org email address used to send the commit notification. That's why the default configuration above uses bcc_addr instead of to_addr to effectively send the mail to package_cvs@... while pretending to send to package@....
Feel free to ask on #alioth on IRC if you need more information on this subject.
2.2. Setup a basic web site
Having an empty project web page doesn't look good. Please put some useful information in /org/alioth.debian.org/chroot/home/groups/<project>/htdocs, at the very least some links to the subversion repository, to the web page used to follow the status of all the packages maintained within the project, etc.
Check for example http://pkg-perl.alioth.debian.org/.
2.3. Configure mailing lists appropriately
If you put a mailing list as Maintainer of a package, you must configure the list to accept mails from anyone otherwise people submitting bug reports and other legitimate mails will get notices indicating that their message is in the moderation queue.
For that, go to the mailman administrative page of the list and click on "Privacy options", "Sender filters" and there you have to change the option "Action to take for postings from non-members for which no explicit action is defined" to "Accept".
This configuration is perfectly acceptable as the anti-spam filters are quite effective. Whitelisting BTS mails is possible with the option "List of non-member addresses whose postings should be automatically accepted". You need to put "^.*@bugs.debian.org" in that field. You should also add "firstname.lastname@example.org" to get notifications by bts-link if upstream uses a bug tracking system that's supported by bts-link. Also consider adding "email@example.com" and "firstname.lastname@example.org" where "package" is the source package name. In such case, also set "require_explicit_destination: No".
We strongly encourage you to use the "open to everyone" policy as this is the standard for all lists on lists.debian.org. To do so, in addition to turn off moderation, you have to set "generic_nonmember_action" to "accept" in Privacy options... / Sender filters, set "require_explicit_destination" to "no" in Privacy options... / Recipient filters, and set the value of "max_message_size" at the bottom of the "General Options" to 0.
2.4. Disable Alioth services which are not needed
An Alioth project provide many services like trackers, forums, surveys, file download, etc. Most of those services are activated by default. Please disable all that you don't use via the administration web page.