rev |
line source |
meillo@59
|
1 Additional information may be available in docs/ or on the website.
|
meillo@174
|
2 For installing on GNU/Linux distributions read docs/INSTALL.linux.
|
meillo@0
|
3
|
meillo@59
|
4
|
meillo@59
|
5 Installation instructions
|
meillo@59
|
6 -------------------------
|
meillo@59
|
7
|
meillo@165
|
8 To compile masqmail you need glib (>= 1.2) (http://www.gtk.org). Your
|
meillo@181
|
9 distribution probably provides it. Glib-2.0 works out of the box, for
|
meillo@181
|
10 glib-1.2, you need to adjust configure.ac. See the comment in there.
|
meillo@0
|
11
|
meillo@165
|
12 You need a user and a group for masqmail to run. If
|
meillo@165
|
13
|
meillo@165
|
14 grep '^mail:' /etc/passwd
|
meillo@165
|
15 grep '^trusted:' /etc/group
|
meillo@165
|
16
|
meillo@165
|
17 shows that the user `mail' and the group `trusted' exist, it's
|
meillo@165
|
18 probably best to use these. If they don't exist, create them:
|
meillo@0
|
19
|
meillo@59
|
20 groupadd -g 42 trusted
|
meillo@165
|
21 useradd -u 23 -g 42 -d / -s /bin/sh -c "Mail Transfer Agent" mail
|
meillo@0
|
22
|
meillo@165
|
23 If you use other names than `mail' and `trusted' use the options
|
meillo@165
|
24 described below for configure. The 23 and 42 are just a suggestion,
|
meillo@165
|
25 you can use any (not yet used) number you like, but preferably one
|
meillo@165
|
26 lower than 100. It does not have to be the same for the user `mail'
|
meillo@165
|
27 and the group `trusted'.
|
meillo@165
|
28
|
meillo@0
|
29
|
meillo@174
|
30 Compiling is a matter of the usual procedure. In the source directory,
|
meillo@59
|
31 after unpacking do:
|
meillo@0
|
32
|
meillo@59
|
33 ./configure
|
meillo@59
|
34 make
|
meillo@59
|
35 make install
|
meillo@0
|
36
|
meillo@0
|
37
|
meillo@0
|
38
|
meillo@59
|
39 Additional options for configure
|
meillo@59
|
40 --------------------------------
|
meillo@0
|
41
|
meillo@59
|
42 See the output of
|
meillo@0
|
43
|
meillo@59
|
44 ./configure -h
|
meillo@0
|
45
|
meillo@165
|
46 Here is a selection of the options with additional explanations:
|
meillo@0
|
47
|
meillo@165
|
48 --with-user=USER
|
meillo@165
|
49 sets the user as which masqmail will run. Default is 'mail'. USER has
|
meillo@165
|
50 to exist before you 'make install'.
|
meillo@0
|
51
|
meillo@165
|
52 --with-group=GROUP
|
meillo@165
|
53 sets the group as which masqmail will run. Default is 'trusted'. GROUP
|
meillo@165
|
54 has to exist before you 'make install'.
|
meillo@0
|
55
|
meillo@0
|
56
|
meillo@165
|
57 --with-logdir=LOGDIR
|
meillo@165
|
58 sets the directory where masqmail stores its log files. It will be
|
meillo@165
|
59 created if it does not exist. Default is /var/log/masqmail/.
|
meillo@0
|
60
|
meillo@165
|
61 --with-spooldir=SPOOLDIR
|
meillo@165
|
62 sets the directory where masqmail stores its spool files. It will be
|
meillo@165
|
63 created if it does not exist. Default is /var/spool/masqmail/.
|
meillo@0
|
64
|
meillo@165
|
65 --with-confdir=CONFDIR
|
meillo@165
|
66 sets the default configuration directory to CONFDIR, in case you
|
meillo@165
|
67 prefer another location than /etc/masqmail/.
|
meillo@0
|
68
|
meillo@0
|
69
|
meillo@165
|
70 --enable-auth
|
meillo@165
|
71 enables ESMTP AUTH support (disabled by default)
|
meillo@0
|
72
|
meillo@165
|
73 --enable-maildir
|
meillo@165
|
74 enables qmail style Maildir support (disabled by default)
|
meillo@0
|
75
|
meillo@165
|
76 --enable-ident
|
meillo@175
|
77 enables RFC 1413 support. If you have the libident dynamic library
|
meillo@165
|
78 installed, this will be linked, otherwise it will be statically linked
|
meillo@165
|
79 using the sources included in the package.
|
meillo@0
|
80
|
meillo@165
|
81 --enable-pop3
|
meillo@175
|
82 enables POP3 support (disabled by default)
|
meillo@0
|
83
|
meillo@165
|
84 --disable-resolver
|
meillo@175
|
85 disables resolver support. Without the resolver functions, masqmail
|
meillo@165
|
86 uses only gethostbyname() to resolve DNS names, and you cannot send
|
meillo@165
|
87 mail without a smart host. Not recommended.
|
meillo@0
|
88
|
meillo@165
|
89 --disable-smtp-server
|
meillo@175
|
90 disables SMTP server support. You may want this if you do not need
|
meillo@165
|
91 masqmail to listen. In this case, you cannot use masqmail as a smart
|
meillo@165
|
92 host for other hosts on your LAN, you cannot use mail clients that
|
meillo@165
|
93 send SMTP, you cannot even use pine. In short, use of this option is
|
meillo@165
|
94 discouraged unless your resources are extremely limited.
|
meillo@0
|
95
|
meillo@165
|
96
|
meillo@165
|
97 --with-libcryto
|
meillo@165
|
98 instead of using the md5 and hmac functions within the package, link
|
meillo@175
|
99 dynamically with libcrypto. This applies only if you have POP3 or SMTP
|
meillo@175
|
100 AUTH enabled. Only makes sense if your resources are limited and you
|
meillo@165
|
101 have libcrypto installed. Untested.
|
meillo@165
|
102
|
meillo@165
|
103 --with-glib-static
|
meillo@175
|
104 links with glib statically. This makes the binary larger by around 30K
|
meillo@165
|
105 (i386 architecture), but if masqmail is the only binary using glib,
|
meillo@165
|
106 you save some space in total, because you do not need the shared glib
|
meillo@0
|
107 library installed.
|
meillo@0
|
108
|
meillo@0
|
109
|
meillo@165
|
110 --disable-debug
|
meillo@175
|
111 disables debugging; setting it on the command line or in the
|
meillo@175
|
112 configuration has no effect. Strongly discouraged, since you miss
|
meillo@175
|
113 valuable information if something goes wrong.
|
meillo@0
|
114
|
meillo@59
|
115
|
meillo@59
|
116
|
meillo@165
|
117 Checking the installation
|
meillo@165
|
118 -------------------------
|
meillo@0
|
119
|
meillo@0
|
120 Check that 'make install' worked correctly. The following command:
|
meillo@0
|
121
|
meillo@59
|
122 ls -ld /usr/sbin/masqmail /etc/masqmail /var/log/masqmail/ \
|
meillo@174
|
123 /var/run/masqmail /var/spool/masqmail/ /var/spool/masqmail/*
|
meillo@0
|
124
|
meillo@0
|
125 should give output similar to
|
meillo@0
|
126
|
meillo@165
|
127 -rwsr-xr-x 1 root root 399356 May 10 12:34 /usr/local/sbin/masqmail
|
meillo@59
|
128 drwxr-xr-x 2 root root 4096 May 10 12:34 /etc/masqmail
|
meillo@59
|
129 drwxr-xr-x 2 mail trusted 4096 May 10 12:34 /var/log/masqmail
|
meillo@59
|
130 drwxr-xr-x 2 mail trusted 4096 May 10 12:34 /var/run/masqmail
|
meillo@59
|
131 drwxr-xr-x 5 mail trusted 4096 May 10 12:34 /var/spool/masqmail
|
meillo@59
|
132 drwxr-xr-x 2 mail trusted 4096 May 10 12:34 /var/spool/masqmail/input
|
meillo@59
|
133 drwxr-xr-x 2 mail trusted 4096 May 10 12:34 /var/spool/masqmail/lock
|
meillo@59
|
134 drwxr-xr-x 2 mail trusted 4096 May 10 12:34 /var/spool/masqmail/popuidl
|
meillo@0
|
135
|
meillo@165
|
136 Important are the set-user-id bit for /usr/local/sbin/masqmail and
|
meillo@165
|
137 the permissions of all files.
|
meillo@0
|
138
|
meillo@0
|
139
|
meillo@59
|
140
|
meillo@165
|
141 Making masqmail the default
|
meillo@165
|
142 ---------------------------
|
meillo@0
|
143
|
meillo@165
|
144 `sendmail' is the de-facto standard name of the system's MTA, no
|
meillo@165
|
145 matter which MTA actually runs. If you want to make masqmail the
|
meillo@185
|
146 system's MTA (i.e. replace sendmail, postfix, etc), make two symbolic
|
meillo@185
|
147 links:
|
meillo@0
|
148
|
meillo@165
|
149 ln -s /usr/local/sbin/masqmail /usr/lib/sendmail
|
meillo@185
|
150 ln -s /usr/local/sbin/masqmail /usr/sbin/sendmail
|
meillo@0
|
151
|
meillo@165
|
152 Now every mailer that used to call sendmail will now call masqmail.
|
meillo@165
|
153 If you already had an MTA installed and running, you can kill it and
|
meillo@165
|
154 start masqmail. Probably with:
|
meillo@59
|
155
|
meillo@165
|
156 /etc/init.d/sendmail restart
|
meillo@59
|
157
|
meillo@165
|
158 If this doesn't work as expected, you might need to add a special init
|
meillo@165
|
159 script for masqmail. Currently none is distributed with masqmail.
|
meillo@165
|
160 (Hopefully this will change soon.) Please ask on the mailing list for
|
meillo@165
|
161 help.
|
meillo@59
|
162
|
meillo@165
|
163 You can also directly start masqmail as daemon with:
|
meillo@59
|
164
|
meillo@165
|
165 /usr/local/sbin/masqmail -bd -q30m
|
meillo@59
|
166
|
meillo@59
|
167
|
meillo@59
|
168
|
meillo@165
|
169 Basic Configuration
|
meillo@165
|
170 -------------------
|
meillo@59
|
171
|
meillo@165
|
172 The only thing you must configure in order to use masqmail is the
|
meillo@165
|
173 hostname. It's the name under which masqmail operates. In most cases
|
meillo@165
|
174 it is the same as the machine's name, but it can be different.
|
meillo@59
|
175
|
meillo@165
|
176 The script `contrib/guess-hostname' tries to print the hostname of
|
meillo@165
|
177 your machine. The first output line is probably the best choice.
|
meillo@59
|
178
|
meillo@165
|
179 Create a minimal config with:
|
meillo@59
|
180
|
meillo@165
|
181 echo "host_name = HOSTNAME" >/etc/masqmail/masqmail.conf
|
meillo@59
|
182
|
meillo@165
|
183 (Substitute `HOSTNAME' with the real value, of course.)
|
meillo@59
|
184
|
meillo@165
|
185 Such a setup (i.e. the default one) does:
|
meillo@165
|
186 - deliver mail locally
|
meillo@165
|
187 - accept mail from local (via stdin)
|
meillo@185
|
188 - accept mail on localhost:25 (via SMTP) (if started as daemon)
|
meillo@185
|
189
|
meillo@165
|
190 It does not
|
meillo@185
|
191 - transfer mail to other machines
|
meillo@165
|
192 - accept mail from outside your machine
|
meillo@59
|
193
|
meillo@59
|
194
|
meillo@165
|
195 For more elaborate setups, have a look at docs/*setup and
|
meillo@165
|
196 docs/INSTALL*. You can also take the example configuration files in
|
meillo@165
|
197 examples/ as basis for your own. Take the man pages masqmail.conf(5)
|
meillo@165
|
198 and masqmail.route(5) for reference.
|
meillo@92
|
199
|
meillo@165
|
200 All configuration files should go into /etc/masqmail.
|
meillo@59
|
201
|
meillo@59
|
202
|
meillo@59
|
203
|
meillo@59
|
204 Written by oku.
|
meillo@165
|
205 Improved by meillo.
|