File: INTRO

package info (click to toggle)
smartlist 3.15-28
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,308 kB
  • sloc: ansic: 9,238; sh: 4,901; makefile: 118
file content (219 lines) | stat: -rw-r--r-- 9,494 bytes parent folder | download | duplicates (11)
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
$Id: INTRO,v 1.11 1996/12/21 03:28:08 srb Exp $

			How to set up mailing lists
			---------------------------

	Copyright (c) 1993-1996, Stephen R. van den Berg, The Netherlands.
				 <srb@cuci.nl>

This document mainly describes a sendmail environment, much of it applies
to non-sendmail mail agents as well.


Contents:
---------	1. Intro
		2. Bouncing mail
		3. The disadvantages
		4. How to circumvent these disadvantages
		5. Why use procmail to filter the mailinglist mail?
		6. How do I use procmail to filter the mailinglist mail?

1. Intro
   -----

The simplest and most direct way to setup a mailinglist is by inserting a line
in the /usr/lib/aliases file looking like:

mylist: fred,john, wilma, barney@bedrock, pebbles

Now all the mail arriving at your machine for "mylist" (either local or
mylist@your.domain) will be automatically forwarded to all the mentioned
addresses (fred, john, etc.).

The address mylist@your.domain is intended for submissions to the list that
are supposed to be forwarded to all the subscribers.  For the administrative
tasks like removals from the list, new subscriptions to the list, or address
changes of subscribers, it is common practice to create a second entry in the
/usr/lib/aliases file:

mylist-request: your_login_name@your.domain


2. Bouncing mail
   -------------

In order to deal with bouncing mail gracefully, an extra precaution should
be taken.  If for example mail to wilma bounces (user non-existent, mail
filesystem full, etc.), it will bounce back to the original sender.
Now, the only person that should be concerned with distribution failures
should be the mylist-request holder.  Therefore you should be using a
sendmail special alias like:

owner-mylist: mylist-request@your.domain

This way local mail will bounce back to mylist-request@your.domain.

N.B. Do *not* use the owner alias in conjunction with a SmartList managed
     list.  It will backfire.


3. The disadvantages
   -----------------

If you are using the above methods, some obvious disadvantages come to mind
however:

a. The subscriber list cannot exceed 1000 bytes (on many sendmails).
b. The subscriber list cannot be changed on-the-fly (/usr/lib/aliases needs
   to be edited, and newaliases has to be run).
c. People cannot be prevented from submitting messages like "Please remove
   me from this mailinglist" to mylist (and thereby annoying all subscribers).
d. People cannot be guarded from themselves in case they insert
   "Return-Receipt-To:" fields in their headers (if they are particularly
   unlucky, they will receive an acknowledge mail from *every* subscriber's
   sendmail).
e. People including "Errors-To:" or "Sender:" fields can cause the bounce
   messages to bypass owner-mylist anyway.
f. There is no way of limiting the number of submitters, i.e. every person
   who knows the name of the mailing list and who can send mail to your.domain
   is able to submit messages to the list.  This means, for example, that you
   cannot limit a mailing list to local users (i.e. only local users can
   submit).
g. You are unable to insert a "Reply-To: mylist@your.domain" in case you
   would want to (this makes replying to the list easier, too easy as some
   people say).


4. How to circumvent these disadvantages
   -------------------------------------

a. Can be circumvented by using nested aliases like:
	mylist: mylist1, mylist2
	mylist1: fred,john
	mylist2: wilma,barney@bedrock,pebbles
   This can however, become extremely messy to maintain.

b. This can be avoided if you use aliases like:
	mylist: :include:/path/to/the/memberfile
   The memberfile should contain:
	fred,john,wilma,barney@bedrock,pebbles
   This will also take care of the upper limit on aliases expansions and
   newaliases need not be run again every time you change the file.

c. Can only be taken care of by using a mailfilter like procmail.

d. Can only be taken care of by using a mailfilter like procmail.

e. Can only be taken care of by using a mailfilter like procmail.

f. Can only be taken care of by using a mailfilter like procmail.

g. Can only be taken care of by using a mailfilter like procmail.


5. Why use procmail to filter the mailinglist mail?
   ------------------------------------------------

Instead of using a mailfilter you could also take care of most of the problems
three till seven by editing the sendmail.cf file.  I would strongly recommend
against this approach however, since this will be too much of a customising
operation and surely will not be a trivial task (in all cases).	 As a general
rule: don't mess with a sendmail.cf file once it works :-).

Now, you could, instead of procmail, simply use immediate VNIX commands
like grep, sed or awk to do the mail filtering.	 Again, there are some obvious
disadvantages with this approach:

A. In case any system resources go out (no more file descriptors, no more
   swap space, process table full, file system full (for temporary files))
   your awk or shell script will fail generously (i.e. several bad things
   could happen: mail munged, truncated, lost, hanging awk or sh programs,
   etc., you get the picture).

B. All mail headers (including From: and Reply-To:) could very well be
   multi-line headers; it will be very difficult to make it understandable
   to awk that somehow the header line could continue on the next line
   (in case you want to remove a header, or do some complicated substitution).

C. Another hairy problem will be determining the end of the header, of course
   that is solvable, but you have to take some extra precautions in your
   awk script to ensure that any substitutions/changes will not occur in
   the body of the message (further degrading performance and increasing the
   load on your machine).

D. Starting programs directly from within aliases or .forward files can get
   extremely messy, since the environment the program starts in is
   potentially hostile.

Procmail does not *directly* allow you to change any headers, but that
feature is not really necessary since you can tell procmail to send ONLY the
header through some filter of your choice.

To comment on the previously mentioned three disadvantages:

A. Procmail takes care of that.	 Should the filter have problems anyway,
   procmail will graciously notice that the filter was in some kind of
   trouble, and will try something else with the original unmunged mail
   (you can specify what it should do of course, obvious choices: try
   the same filter again, drop the mail in a file and send you a notice,
   forward the mail to you instead (unfiltered), etc.)

B. In order to make consistent scanning of the header possible using the
   egrep regular expressions built in to procmail, procmail will internally
   concatenate any headers that were continued according to the RCF 822
   recommendations, in order for external filters to benefit from this, you
   would use the formail program to pre-filter the mail.

C. Procmail can be told to send the header, the body or both through the
   filter, hence your filter need not watch out to avoid doing any
   substitutions in the body, and the filter can therefore be a lot simpler.

D. Procmail makes no assumptions about the environment it is started in, it
   assumes that everything is hostile and fights its way back to the
   civilised world by initialising *everything* to sane and expected default
   values.  Thereby providing a warm bed for any program started from within
   procmail.

But procmail has some additional advantages as well:

 -- It will probably all go a bit faster, since only the header of the mail
    is being piped through the filter.	Also, procmail reads in the mail in
    16KB chunks, not line by line as sed does.

 -- You could use procmail to filter out any messages to the normal mailing
    list that should have gone to the mylist-request and remail them to
    mylist-request.

Well, anyway, as you see, procmail does not give you everything you would want,
but this was intentional in accordance to the true VNIX spirit (modularity).
What procmail does provide is a *very* reliable hook (you might say it
provides an anchor :-) for any mail processing you might do.  For the more
complex things you still have to use shell scripts or call other programs
from within procmail, but then again, that saves you from learning any
particular syntax procmail would have had to do the same.

As it happens, the accompanying formail program is able to cater to most
(if not all) of your needs regarding mail munging.


6. How do I use procmail to filter the mailinglist mail?
   -----------------------------------------------------

In order to cater for most wishes regarding mailinglist setup, I took the
liberty to write some rcfiles for procmail that can readily be used to create
any number of mailinglists in a comfortable and simple way.  They are
called the "SmartList" mailinglist package.

See the FEATURES file in this directory for more information on what
the SmartList mailinglist scripts will do for you.

If the scripts do not exactly do what you would have liked, you are invited to
edit them to taste.  Perhaps you could send your changes to the SmartList
mailinglist if you feel that they could be useful to others.

To get started I suggest you read the INSTALL file in this directory.

For operating instructions you should read the Manual file in this directory.


P.S. Any suggestions/corrections/improvements on this document are welcome.