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
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
|
Mailman - The GNU Mailing List Management System
Copyright (C) 1998,1999,2000,2001 by the Free Software Foundation, Inc.
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
FREQUENTLY ASKED QUESTIONS
Q. How do you spell this program?
A. You spell it "Mailman", with a leading capital "M" and a lowercase
second "m". It is incorrect to spell it "MailMan" (i.e. you should
not use StudlyCaps).
Q. I'm getting really terrible performance for outgoing messages. It
seems that if the MTA has trouble resolving DNS for any recipients,
qrunner just gets really slow clearing the queue. Any ideas?
A. What's likely happening is that your MTA is doing DNS resolution on
recipients for messages delivered locally (i.e. from Mailman to
your MTA via SMTPDirect.py). This is a Bad Thing. You need to
turn off synchronous DNS resolution for messages originating from
the local host.
In Exim, the value to edit is receiver_verify_hosts. See
README.EXIM for details. Other MTAs have (of course) different
parameters and defaults that control this. First check the README
file for your MTA and then consult your MTA's own documentation.
Q. What if I get "document contains no data" from the web server, or
mail isn't getting delivered, or I see "Premature end of script
headers" or "Mailman CGI error!!!"
A. The most likely cause of this is that the GID that is compiled into
the C wrappers does not match the GID that your Web server invokes
CGI scripts with. Note that a similar error could occur if your
mail system invokes filter programs under a GID that does not match
the one compiled into the C mail wrapper.
To fix this you will need to re-configure Mailman using the
--with-cgi-gid and --with-mail-gid options. See the INSTALL file
for details.
These errors are logged to syslog and they do not show up in the
Mailman log files. Problems with the CGI wrapper do get reported
in the Web browser though, and include the expected GID, so that
should help a lot.
You may want to have syslog running and configured to log the
mail.error log class somewhere; on Solaris systems, the line
mail.debug /var/log/syslog
causes the messages to go to them in /var/log/syslog, for example.
(The distributed syslog.conf forwards the message to the loghost,
when present. See the syslog man page for more details.)
If your system is set like this, and you get a failure trying to
visit the mailman/listinfo web page, and it's due to a UID or GID
mismatch, then you should get an entry at the end of
/var/log/syslog identifying the expected and received values.
Q. Why do my web pages hang?
A. CERN Web servers might leave Python processes running, and in some
cases might hang the CGI completely. In that case, switch to
Apache.
It is also possible that you have stale locks. Mailman tries to
be very careful about the lock files it creates to ensure the
integrity of its databases, but sometimes system faults can
cause stale locks to persist. Look in $prefix/locks for any
stale list locks and remove them (you can determine if they're
stale by getting the pid from the file contents and using ps to
see if those processes are still running or not).
Q. What should I check periodically?
A. Many of the scripts have their standard error logged to
~mailman/logs/error, and some of the modules write caught errors
there, as well, so you should check there at least occasionally to
look for bugs in the code and problems in your setup.
One thing that is *not* caught by the standard error hook is syntax
errors, but any of these should have been caught in the
installation phase, which byte-compiles all .py files in the
distribution. There may be syntax errors lurking if you hacked the
code, or in the scripts that are not modules.
You can always use the Python module `compile' or `compileall' to
force byte compilation of a file, or just fire up the Python
interpreter and try importing the module.
Q. Why doesn't the archive link work?
A. Have any messages been posted to the list? This is a known buglet;
the archive link doesn't work until at least one message has been
posted.
Q. Okay, the archive link works, but I can't access the public
archives. Why?
A. If you are using Apache, you must make sure that FollowSymLinks is
enabled for the path to the public archives. Note that the actual
archives always reside in the private tree, and only when archives
are public, is the symlink followed. See this archive message for
more details:
http://mail.python.org/pipermail/mailman-users/1998-November/000150.html
Q. Still having problems? Running QMail?
A. Make sure that you are using "preline" before calling "wrapper":
|preline /home/mailman/mail/wrapper post listname
"preline" adds a Unix-style "From " header which the archiver requires.
You can fix the archive mbox files by adding:
From somebody Mon Oct 9 12:27:34 MDT 2000
before every message and re-running the archive command
"bin/arch listname". The archives should now exist. See README.QMAIL
for more information.
Q. Still having problems? Running on GNU/Linux?
A. See the README.LINUX file.
Q. I want to get rid of some messages in my archive. How do I do
this?
A. David Rocher posts the following recipe:
* remove $prefix/archives/private/<listname>
* edit $prefix/archives/private/<listname>.mbox/<listname>.mbox [optional]
* run $prefix/bin/arch <listname>
Q. I set member_posting_only to yes because I want to limit posts to
members only, however it seems like all messages coming from
members are held for approval. Why?
A. There appears to be a problem on some systems where the envelope
sender (e.g. the Unix "From " line) is set incorrectly. This will
cause a negative match when checking to see if the sender is a
member of the list. Until 1.0b12, Mailman defaulted to using the
envelope sender before the sender (i.e. "From:" header) because the
former is set by the SMTP agent while the latter is easily
spoofable by the end user.
[ The possible causes for envelope sender munging taking place are
many, but the "owner-alias" sendmail feature probably deserves
special mention:
If mail arrives for list "foo", and there is an alias entry for
"owner-foo" as well, the envelope sender of the message will be
changed to the single-level expansion of the "owner-foo" alias.
Code has been included in post-1.0rc2 Mailman releases to try
working around the problem this (unconfigurable) sendmail feature
constitutes. Prior to this, some people worked around the
problem by not including the suggested "owner-LISTNAME" alias
entries for Mailman lists in their alias files. ]
However, if you are having this problem, you may opt to favor the
From: header over the envelope sender. Do this by adding the
following line to your mm_cfg.py file:
USE_ENVELOPE_SENDER=0
if you want (arguably) more security, add this to your mm_cfg.py
file:
USE_ENVELOPE_SENDER=1
However, read the comments about this variable in the Defaults.py
file for a full discussion of the issues. By default, Mailman 2.0
relies on the From: header for doing address matching.
Q. How secure are the authentication mechanisms used in Mailman's web
interface?
A. If your Mailman installation run on an SSL-enabled web server
(i.e. you access the Mailman web pages with "https://..." URLs),
you should be as safe as SSL itself is.
However, most Mailman installation run under standard,
encryption-unaware servers. There's nothing wrong with that for
most applications, but a sufficiently determined cracker *could*
get unauthorized access by:
* Packet sniffing: The password used to do the initial
authentication for any non-public Mailman page is sent as clear
text over the net. If you consider this to be a big problem, you
really should use an SSL-enabled server.
* Stealing a valid cookie: After successful password
authentication, Mailman sends a "cookie" back to the user's
browser. This cookie will be used for "automatic" authentication
when browsing further within the list's protected pages. Mailman
employs "session cookies" which are set until you quit your
browser or explicitly log out.
Gaining access to the user's cookie (e.g. by being able to read
the user's browser cookie database, or by means of packet
sniffing, or maybe even by some broken browser offering all it's
cookies to any and all sites the user accesses), and at the same
time being able to fulfill the other criteria for using the
cookie could result in unauthorized access.
Note that this problem is more easily exploited when users browse
the web via proxies -- in that case, the cookie would be valid
for any connections made through that proxy, and not just for
connections made from the particular machine the user happens to
be accessing the proxy from.
* Getting access to the user's terminal: This is really just
another kind of cookie stealing. The short cookie expiration
time is supposed to help defeat this problem. It can be
considered the price to pay for the convenience of not having to
type the password in every time.
Local Variables:
mode: text
indent-tabs-mode: nil
End:
|