summaryrefslogtreecommitdiff
blob: 08865f3a3f85169395144f863293cf43669a7cc9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Id$

Follow these instructions to finish setting up mailman. This file and the
original ebuild were tweaked by me <lamer@gentoo.org> but were graciously
submitted by Joby Walker (YOU RULE!) 
2003 Jul 09: updated by Jesus Perez and re-tweaked by me <raker@gentoo.org>
for 2.1.x.

Please view the documentation on Mailman at: http://www.list.org/

This documentation assumes you're using the default gentoo path
(/usr/lib/mailman/), if you've changed it with MAILMAN_PREFIX, adjust them
accordingly.

1) If this is your first time installing mailman, after your "emerge mailman",
you need to add -D MAILMAN to /etc/conf.d/apache or /etc/conf.d/apache2 and restart
apache.

2) In your /etc/conf.d/apache (for apache 1.x)
	or /etc/conf.d/apache2 (for apache 2.x) 
	file add the additional option to the
	APACHE_OPTS or APACHE2_OPTS variable:

	-D MAILMAN

3) Make sure mailman is a part of the cron group

4) This must be done as user mailman:

	su - mailman

Add the cron jobs:

	cd cron
	crontab crontab.in
	cd ..

Create the site password:

	bin/mmsitepass

and main list:

	bin/newlist mailman


5) Change back to root:

	exit

(Postfix users: read the notes at the end of this file before you continue)
Add this to /etc/mail/aliases (and see point 9 for notes):
     mailman:              "|/usr/lib/mailman/mail/mailman post mailman"
     mailman-admin:        "|/usr/lib/mailman/mail/mailman admin mailman"
     mailman-bounces:      "|/usr/lib/mailman/mail/mailman bounces mailman"
     mailman-confirm:      "|/usr/lib/mailman/mail/mailman confirm mailman"
     mailman-join:         "|/usr/lib/mailman/mail/mailman join mailman"
     mailman-leave:        "|/usr/lib/mailman/mail/mailman leave mailman"
     mailman-owner:        "|/usr/lib/mailman/mail/mailman owner mailman"
     mailman-request:      "|/usr/lib/mailman/mail/mailman request mailman"
     mailman-subscribe:    "|/usr/lib/mailman/mail/mailman subscribe mailman"
     mailman-unsubscribe:  "|/usr/lib/mailman/mail/mailman unsubscribe mailman"

For courier, the aliases have to go to /etc/courier/aliases and you have to skip
the quotes.

Run newaliases (only if you use sendmail).

	newaliases
    
6) Start the mailman daemon:

	/etc/init.d/mailman start

and add it to default runlevel (optional but recommended):

	rc-update add mailman default

7) For each list created (either with web interface or with bin/newlist) 
this must be added to /etc/mail/aliases (see smrsh notes below)
replace <list-name> with the name of the list:

	<list-name>: "|/usr/lib/mailman/mail/mailman post <list-name>"
	<list-name>-admin: "|/usr/lib/mailman/mail/mailman admin <list-name>"
	<list-name>-bounces: "|/usr/lib/mailman/mail/mailman bounces <list-name>"
     	<list-name>-confirm: "|/usr/lib/mailman/mail/mailman confirm <list-name>"
     	<list-name>-join: "|/usr/lib/mailman/mail/mailman join <list-name>"
	<list-name>-leave: "|/usr/lib/mailman/mail/mailman leave <list-name>"
	<list-name>-owner: "|/usr/lib/mailman/mail/mailman owner <list-name>"
	<list-name>-request: "|/usr/lib/mailman/mail/mailman request <list-name>"
     	<list-name>-subscribe: "|/usr/lib/mailman/mail/mailman subscribe <list-name>"
	<list-name>-unsubscribe: "|/usr/lib/mailman/mail/mailman unsubscribe <list-name>"

For courier, the aliases have to go to /etc/courier/aliases and you have to skip
the quotes.

Run newaliases:

	newaliases

smrsh notes
-----------
(if you use sendmail, you are surely using srmsh) you must note that 
sendmail won't run any program outside of EBINDIR. I tried to change 
EBINDIR using,define(`confEBINDIR', `/usr/lib/mailman/mail')dnl in 
sendmail.mc but it didn't work, so mailman must be placed in EBINDIR, 
which in Gentoo is /usr/adm/sm.bin, so you must run as root:

     ln -s /usr/lib/mailman/mail/mailman /usr/adm/sm.bin/mailman

And the lines in /etc/mail/aliases which refer to 
/usr/lib/mailman/mail/mailman must be changed to mailman:

     <list-name>:              "|mailman post <list-name>"
     <list-name>-admin:        "|mailman admin <list-name>"
     <list-name>-bounces:      "|mailman bounces <list-name>"
     <list-name>-confirm:      "|mailman confirm <list-name>"
     <list-name>-join:         "|mailman join <list-name>"
     <list-name>-leave:        "|mailman leave <list-name>"
     <list-name>-owner:        "|mailman owner <list-name>"
     <list-name>-request:      "|mailman request <list-name>"
     <list-name>-subscribe:    "|mailman subscribe <list-name>"
     <list-name>-unsubscribe:  "|mailman unsubscribe <list-name>"

exim notes
----------
You can write an exim stanza for the router and transport that looks something
like (Derived from, and in part taken from cpanel):

mailman_virtual_router:
	driver = accept
	require_files = /var/lib/mailman/lists/${lc::$local_part}/config.pck
	local_part_suffix_optional
	local_part_suffix = -admin     : \
						-bounces   : -bounces+* : \
						-confirm   : -confirm+* : \
						-join      : -leave     : \
						-owner     : -request   : \
						-subscribe : -unsubscribe
	transport = mailman_virtual_transport

mailman_virtual_transport:
    driver = pipe
    command = /usr/lib/mailman/mail/mailman \
              '${if def:local_part_suffix \
                    {${sg{$local_part_suffix}{-(\\w+)(\\+.*)?}{\$1}}} \
                    {post}}' \
              ${lc:$local_part}
    current_directory = /usr/lib/mailman
    home_directory = /usr/lib/mailman
    user = mailman
    group = mailman

Note the double colon in the require files.  See
http://wiki.exim.org/FAQ/General_Debugging/Q0060 for more information.

This should be modified if you're using the vhosts USE flag, specifically you
need to modify the location of the config.pck file, to be
${lc::$local_part}-${lc::$domain} instead of simply ${lc::$local_part}, and for the
transport you need to change the last part of the command in the same fashion.

Other Helpful things to know...
-------------------------------
run "bin/check_perms -f" from the root mailman directory
(/usr/lib/mailman) to check and fix permission problems.

The INSTALL file is located in /usr/share/doc/mailman-$VERSION/ 

Postfix notes
-------------
If you're using Postfix, don't manually change your /etc/mail/aliases
file, as described above. Instead, follow these instructions:

http://list.org/mailman-install/node13.html

This will set up Mailman and Postfix to automatically generate the new
aliases when you create new lists. It will also make sure that Postfix
uses the correct group ID when it's talking to Mailman, otherwise you
will get security errors from Mailman.