PostfixAdminInstall » History » Version 40
Simone Piccardi, 07/23/2012 12:50 PM
1 | 37 | Simone Piccardi | h1. Installare e configurare _Postfixadmin_ |
---|---|---|---|
2 | 1 | Amministratore Truelite | |
3 | 35 | Simone Piccardi | "PostfixAdmin":http://postfixadmin.sourceforge.net/ è una potente interfaccia di gestione per la posta elettronica che consente di mantenere su un database e gestire tramite interfaccia web gli utenti di un numero arbitrario di domini di posta elettronica. Il programma è pensato per essere usato in combinazione con postfix, supporta inoltre l'uso di _MySQL_, _PostgresSQL_ e _SQLite_ come database, a cui poi si dovrà appoggiare un server IMAP per l'accesso alle caselle di posta. In questo caso faremo riferimento ad una installazione basata su _MySQL_ per il database e _Dovecot_ per il server IMAP su _Debian Lenny_. |
4 | 1 | Amministratore Truelite | |
5 | 37 | Simone Piccardi | h2. Installazione di _Postfixadmin_ |
6 | 34 | Amministratore Truelite | |
7 | 35 | Simone Piccardi | Il software viene distribuito direttamente in un pacchetto Debian dal mantainer, ma non tramite un repository, pertanto sarà necessario scaricare il @.deb@ a partire da "questo indirizzo.":http://sourceforge.net/project/showfiles.php?group_id=191583&package_id=225300 Una volta ottenuto il pacchetto sarà opportuno installare preventivamente le dipendenze, queste si ottengono con il comando: |
8 | 34 | Amministratore Truelite | |
9 | <pre> |
||
10 | dpkg -f postfixadmin_*.deb Depends |
||
11 | </pre> |
||
12 | 35 | Simone Piccardi | |
13 | 1 | Amministratore Truelite | che presenta però anche le alternative per quanto riguarda il server web ed il database di supporto da usare, e non prevede esplicitamente l'installazione di un database sulla stessa macchina. Nel nostro caso sarà allora opportuno installare almeno i seguenti pacchetti: |
14 | 35 | Simone Piccardi | |
15 | 2 | Amministratore Truelite | <pre> |
16 | 34 | Amministratore Truelite | aptitude install dbconfig-common wwwconfig-common \ |
17 | 21 | Amministratore Truelite | libapache2-mod-php5 php5 php5-imap php5-mysql \ |
18 | 4 | Amministratore Truelite | mysql-client mysql-server postfix-mysql |
19 | 5 | Amministratore Truelite | </pre> |
20 | 34 | Amministratore Truelite | |
21 | 1 | Amministratore Truelite | A questo punto sarà necessario creare un database ad uso di "PostfixAdmin":http://postfixadmin.sourceforge.net/, ed un utente dotato di adeguati privilegi per poterlo utilizzare, questo può essere fatto manualmente con le seguenti istruzioni: |
22 | 35 | Simone Piccardi | |
23 | 1 | Amministratore Truelite | <pre> |
24 | 34 | Amministratore Truelite | mysqladmin -u root -p create postfixadmin |
25 | 1 | Amministratore Truelite | mysql -u root -p |
26 | 15 | Amministratore Truelite | mysql> grant create, select, insert, update, delete, lock, index, alter, drop |
27 | on postfixadmin.* to 'postfixadmin'@'localhost' |
||
28 | 5 | Amministratore Truelite | identified by 'passsegretaedifficile'; |
29 | 1 | Amministratore Truelite | mysql> flush privileges; |
30 | mysql> \q |
||
31 | </pre> |
||
32 | 35 | Simone Piccardi | |
33 | 1 | Amministratore Truelite | dopo di che si potrà installare il pacchetto con: |
34 | 35 | Simone Piccardi | |
35 | 34 | Amministratore Truelite | <pre> |
36 | 1 | Amministratore Truelite | dpkg -i postfixadmin_*.deb |
37 | 34 | Amministratore Truelite | </pre> |
38 | 1 | Amministratore Truelite | |
39 | 35 | Simone Piccardi | ma si tenga presente che dalla versione 2.3 (ancora non rilasciata come stabile), con l'installazione di @dbconfig-common@ e @wwwconfig-common@, l'installazione del pacchetto consente di creare configurare automaticamente anche il database di appoggio ed il relativo utente (ed il passo precedente non serve più). |
40 | |||
41 | A seconda della versione che si installa si dovrà modificare a mano il file 2/etc/postfixadmin/config.inc.php@ per inserire le credenziali di accesso al database, modificando le righe: |
||
42 | |||
43 | 1 | Amministratore Truelite | <pre> |
44 | $CONF['configured'] = true; |
||
45 | 6 | Amministratore Truelite | ... |
46 | 1 | Amministratore Truelite | $CONF['database_type'] = 'mysql'; |
47 | $CONF['database_host'] = 'localhost'; |
||
48 | $CONF['database_user'] = 'postfixadmin'; |
||
49 | $CONF['database_password'] = 'passsegretaedifficile'; |
||
50 | $CONF['database_name'] = 'postfixadmin'; |
||
51 | </pre> |
||
52 | 7 | Amministratore Truelite | |
53 | 35 | Simone Piccardi | ma questo, con la 2.3, viene fatto da _debconf_ in maniera automatica con la richiesta della password di amministrazione di MySQL (quella impostata per root alla sua installazione) e di una altra password per l'utente usato da "PostfixAdmin":http://postfixadmin.sourceforge.net/, si ricordi però di rispondere, quando verrà richiesto, di installare la configurazione fornita dal pacchetto. |
54 | |||
55 | Si tenga infine presente che se si vuole evitare di rendere leggibili ad Apache le credenziali di accesso al database questo può essere fatto aggiungendo creando un _Virtual Host_ specifico per Postfixadmin (leggibile solo da root) in cui si impostano delle variabili di ambiente con le direttive: |
||
56 | |||
57 | 34 | Amministratore Truelite | <pre> |
58 | 35 | Simone Piccardi | SetEnv DB_USER "postfixadmin" |
59 | SetEnv DB_PASS "passsegretaedifficile" |
||
60 | 34 | Amministratore Truelite | </pre> |
61 | 35 | Simone Piccardi | |
62 | 34 | Amministratore Truelite | che poi si riusano nel file di configurazione con: |
63 | 35 | Simone Piccardi | |
64 | 34 | Amministratore Truelite | <pre> |
65 | 1 | Amministratore Truelite | $CONF['database_user'] = $_SERVER['DB_USER']; |
66 | $CONF['database_password'] = $_SERVER['DB_PASS']; |
||
67 | </pre> |
||
68 | |||
69 | Fatto questo la creazione della struttura del database e delle relative informazioni (o l'aggiornamento di eventuali modifiche della struttura del database in caso di installazioni di versioni successive del software) si fa puntando il browser all'indirizzo: |
||
70 | 35 | Simone Piccardi | |
71 | 1 | Amministratore Truelite | <pre> |
72 | 34 | Amministratore Truelite | http://IP.DEL.MIO.SERVER/postfixadmin/setup.php |
73 | 1 | Amministratore Truelite | </pre> |
74 | 35 | Simone Piccardi | |
75 | 1 | Amministratore Truelite | che esegue lo script di setup che crea e popola le tabelle del database; anche qui le cose cambiano a seconda della versione, fino alla 2.2 questo script consente di modificare l'amministratore e deve essere rimosso dopo l'uso, con la 2.3 è previsto la generazione di una password per il setup, e se questa non è impostata lo script la richiede e poi scrive in output l'hash crittografico che corrisponde da inserire nella configurazione (il file precedente) alla linea: |
76 | 35 | Simone Piccardi | |
77 | 1 | Amministratore Truelite | <pre> |
78 | 34 | Amministratore Truelite | $CONF['setup_password'] = 'changeme'; |
79 | 11 | Amministratore Truelite | </pre> |
80 | 1 | Amministratore Truelite | |
81 | 35 | Simone Piccardi | una volta fatta la modifica si potrà usare con successo il setup per la creazione di un utente di amministrazione, associato ad un indirizzo di posta, anch'esso installato nel database. Si potrà verificare il funzionamento della configurazione collegandosi direttamente all'indirizzo @http://IP.DEL.MIO.SERVER/postfixadmin@ controllando che l'utente di amministrazione impostato funzioni. |
82 | |||
83 | 34 | Amministratore Truelite | Una volta eseguita la configurazione di base e verificato che la connessione al database funziona, sarà necessario eseguire una serie di affinamenti; anzititto si dovrà impostare il programma per fare riferimento al proprio dominio, la cosa può essere fatto rapidamente con: |
84 | 35 | Simone Piccardi | |
85 | 34 | Amministratore Truelite | <pre> |
86 | 1 | Amministratore Truelite | cd /etc/postfixadmin/ |
87 | mv config.inc.php config.inc.php.orig |
||
88 | sed -e 's/change-this-to-your.domain.tld/miodominio.it/g' config.inc.php.orig > config.inc.php |
||
89 | </pre> |
||
90 | 35 | Simone Piccardi | |
91 | ma si verifichi poi il file per controllare che i link alle pagine web siano corretti (nel caso saranno sempre nella forma @http://miodominio.it@). Si dovranno poi modificare le seguenti configurazioni per avere le cartelle associate all'indirizzo @utente@miodominio.it@) nella forma @miodominio.it/utente@ (si dovrà usare la stessa forma anche nella configurazione del server IMAP): |
||
92 | |||
93 | 1 | Amministratore Truelite | <pre> |
94 | $CONF['domain_path'] = 'YES'; |
||
95 | $CONF['domain_in_mailbox'] = 'NO'; |
||
96 | </pre> |
||
97 | 35 | Simone Piccardi | |
98 | 1 | Amministratore Truelite | se poi si vogliono usare le quote occorrerà impostare: |
99 | 35 | Simone Piccardi | |
100 | 34 | Amministratore Truelite | <pre> |
101 | $CONF['quota'] = 'YES'; |
||
102 | </pre> |
||
103 | 35 | Simone Piccardi | |
104 | mentre per utilizzare @vacation@ sarà necessario impostare: |
||
105 | |||
106 | 34 | Amministratore Truelite | <pre> |
107 | $CONF['vacation'] = 'YES'; |
||
108 | 15 | Amministratore Truelite | $CONF['vacation_domain'] = 'autoreply.miodominio.it' |
109 | 1 | Amministratore Truelite | </pre> |
110 | |||
111 | 35 | Simone Piccardi | e configurare _Postfix_ per usare @autoreplay.miodominio.it@ come dominio per gestire @vacation@ (torneremo su questo nel seguito). |
112 | |||
113 | 6 | Amministratore Truelite | Si possono poi cambiare le seguenti impostazioni per inserire dei default più adatti alle proprie esigenze: |
114 | 35 | Simone Piccardi | |
115 | 1 | Amministratore Truelite | <pre> |
116 | 34 | Amministratore Truelite | $CONF['default_language'] = 'it'; |
117 | 1 | Amministratore Truelite | $CONF['min_password_length'] = 6; |
118 | $CONF['aliases'] = '10'; |
||
119 | $CONF['mailboxes'] = '10'; |
||
120 | 18 | Amministratore Truelite | $CONF['maxquota'] = '10'; |
121 | 34 | Amministratore Truelite | </pre> |
122 | 7 | Amministratore Truelite | |
123 | 35 | Simone Piccardi | Se si installa la versione 2.3 si tenga conto che questa permette anche di utilizzare una gestione semplificata per avere gli stessi alias su più domini, che però richiede più interrogazioni al database ed una diversa configurazione di postfix; se non si ha questa necessità è meglio non usarla e questa andrà disabilitata con: |
124 | |||
125 | 34 | Amministratore Truelite | <pre> |
126 | 1 | Amministratore Truelite | $CONF['alias_domain'] = 'NO'; |
127 | 32 | Amministratore Truelite | </pre> |
128 | 1 | Amministratore Truelite | |
129 | 37 | Simone Piccardi | h2. Configurare _Postfix_ per _Postfixadmin_ |
130 | 34 | Amministratore Truelite | |
131 | 35 | Simone Piccardi | Il passo successivo è configurare _Postfix_ per fare uso degli utenti e delle mailbox definite su _PostfixAdmin_, installando il pacchetto @postfix@ si abbia cura di rispondere alla configurazione automatica di utilizzare il profilo per il sito internet, specificando il proprio dominio principale. Per lo stoccaggio della posta si dovrà usare una directory apposita, la cui proprietà sarà di un utente dedicato; una volta che si sia scelto un filesystem con adeguato spazio, la si potrà creare con i comandi: |
132 | 34 | Amministratore Truelite | |
133 | 1 | Amministratore Truelite | <pre> |
134 | mkdir /var/mail/vmail |
||
135 | useradd -d /var/mail/vmail vmail |
||
136 | chown vmail:vmail /var/mail/vmail/ |
||
137 | chmod o-xr /var/mail/vmail/ |
||
138 | 24 | Amministratore Truelite | </pre> |
139 | 1 | Amministratore Truelite | |
140 | 35 | Simone Piccardi | Si deve inoltre evitare l'uso di procmail come LDA per cui si dovrà commentare la seguente linea standard presente nella configurazione di _Postfix_ installata da Debian: |
141 | |||
142 | 34 | Amministratore Truelite | <pre> |
143 | 1 | Amministratore Truelite | #mailbox_command = procmail -a "$EXTENSION" |
144 | 24 | Amministratore Truelite | </pre> |
145 | 1 | Amministratore Truelite | |
146 | 35 | Simone Piccardi | Poi si dovrà indicare a Postfix di usare i dati mantenuti su MySQL per le mailbox virtuali, per questo anzitutto si deve installare il pacchetto @postfix-mysql@, dopo di che si dovranno aggiungere le seguenti linee di configurazione al @main.cf@: |
147 | |||
148 | 34 | Amministratore Truelite | <pre> |
149 | virtual_alias_maps = proxy:mysql:/etc/postfix/mysql_virtual_alias_maps.cf |
||
150 | 9 | Amministratore Truelite | virtual_mailbox_domains = proxy:mysql:/etc/postfix/mysql_virtual_domains_maps.cf |
151 | 1 | Amministratore Truelite | virtual_mailbox_maps = proxy:mysql:/etc/postfix/mysql_virtual_mailbox_maps.cf |
152 | virtual_mailbox_base = /var/mail/vmail |
||
153 | virtual_minimum_uid = 106 |
||
154 | 7 | Amministratore Truelite | virtual_transport = virtual |
155 | 1 | Amministratore Truelite | virtual_uid_maps = static:106 |
156 | 7 | Amministratore Truelite | virtual_gid_maps = static:61 |
157 | 34 | Amministratore Truelite | </pre> |
158 | 1 | Amministratore Truelite | |
159 | 36 | Simone Piccardi | dove 106 e 61 sono rispettivamente uid e gid dell'utente @vmail@, questi possono essere diversi su ciascuna installazione si possono trovare con il comando @getent passwd|grep vmail@. |
160 | 35 | Simone Piccardi | |
161 | 36 | Simone Piccardi | Si dovranno inoltre creare il vari file @mysql_*@ con le configurazioni per l'uso del database, il primo file, @mysql_virtual_alias_maps.cf@, è quello che consente di utilizzare gli alias definiti nel database, e deve essere qualcosa del tipo: |
162 | 35 | Simone Piccardi | |
163 | 1 | Amministratore Truelite | <pre> |
164 | user = postfixadmin |
||
165 | password = passsegretaedifficile |
||
166 | hosts = localhost |
||
167 | dbname = postfixadmin |
||
168 | query = SELECT goto FROM alias WHERE address='%s' AND active = 1 |
||
169 | </pre> |
||
170 | 35 | Simone Piccardi | |
171 | 36 | Simone Piccardi | il secondo, @mysql_virtual_domains_maps.cf@, consente di ottenere l'elenco dei domini mantenuti nel database, e deve essere qualcosa del tipo: |
172 | 35 | Simone Piccardi | |
173 | 34 | Amministratore Truelite | <pre> |
174 | 1 | Amministratore Truelite | user = postfixadmin |
175 | password = passsegretaedifficile |
||
176 | hosts = localhost |
||
177 | dbname = postfixadmin |
||
178 | 34 | Amministratore Truelite | query = SELECT domain FROM domain WHERE domain='%s' and backupmx = '0' and active = '1' |
179 | 1 | Amministratore Truelite | </pre> |
180 | 35 | Simone Piccardi | |
181 | 36 | Simone Piccardi | il terzo, @mysql_virtual_mailbox_maps.cf@, consente di ottenere le directory con le mailbox che saranno create a partire dalla directory di base @/var/mail/vmail@, e deve essere qualcosa del tipo: |
182 | 35 | Simone Piccardi | |
183 | 31 | Amministratore Truelite | <pre> |
184 | 1 | Amministratore Truelite | user = postfixadmin |
185 | password = passsegretaedifficile |
||
186 | hosts = localhost |
||
187 | dbname = postfixadmin |
||
188 | query = SELECT maildir FROM mailbox WHERE username='%s' AND active = 1 |
||
189 | </pre> |
||
190 | 26 | Amministratore Truelite | |
191 | 35 | Simone Piccardi | Se poi si vogliono gestire con _PostfixAdmin_ anche eventuali secondari di posta, si potrà aggiungere al @main.cf@ di Postfix la riga: |
192 | |||
193 | 1 | Amministratore Truelite | <pre> |
194 | relay_domains = $mydestination, proxy:mysql:/etc/postfix/mysql_relay_domains_maps.cf |
||
195 | 34 | Amministratore Truelite | </pre> |
196 | 35 | Simone Piccardi | |
197 | dove in @mysql_relay_domains_maps.cf@ ci dovrà essere qualcosa del tipo: |
||
198 | |||
199 | 1 | Amministratore Truelite | <pre> |
200 | 15 | Amministratore Truelite | user = postfixadmin |
201 | 1 | Amministratore Truelite | password = passsegretaedifficile |
202 | 15 | Amministratore Truelite | hosts = localhost |
203 | dbname = postfixadmin |
||
204 | 34 | Amministratore Truelite | query = SELECT domain FROM domain WHERE domain='%s' and backupmx = '1' and active = '1' |
205 | 15 | Amministratore Truelite | </pre> |
206 | 1 | Amministratore Truelite | |
207 | Poiché questi file contengono una password in chiaro si verifichi che non siano leggibili da chiunque ed eventualmente si sistemino adeguatamente i permessi con: |
||
208 | 35 | Simone Piccardi | |
209 | 1 | Amministratore Truelite | <pre> |
210 | 15 | Amministratore Truelite | chgrp postfix /etc/postfix/mysql_* |
211 | 1 | Amministratore Truelite | chmod 640 /etc/postfix/mysql_* |
212 | </pre> |
||
213 | 34 | Amministratore Truelite | |
214 | 35 | Simone Piccardi | A questo punto sarà possibile spedire una email ad un utente creato con Postfixadmi e verificarne la corretta ricezione nei log di @/var/log/mail.log@. |
215 | 34 | Amministratore Truelite | |
216 | 37 | Simone Piccardi | h2. Uso di _vacation_ con _Postfix_ e _Postfixadmin_ |
217 | 34 | Amministratore Truelite | |
218 | 37 | Simone Piccardi | Se si è scelto di usare _vacation_ la configurazione diventa leggermente più complessa, anzitutto si deve creare un utente apposito per la gestione dei delle risposte automatiche, questo lo si può fare con i seguenti comandi che assicurano che l'utente abbia i minimi privilegi: |
219 | 15 | Amministratore Truelite | |
220 | 34 | Amministratore Truelite | <pre> |
221 | 15 | Amministratore Truelite | groupadd -g 65501 vacation |
222 | 34 | Amministratore Truelite | useradd -g 65501 -u 65501 -c Vacation -s /sbin/nologin -d /nonexistent vacation |
223 | 1 | Amministratore Truelite | </pre> |
224 | 35 | Simone Piccardi | |
225 | 34 | Amministratore Truelite | dopo di che si dovrà creare una directory ad accesso esclusivo di questo utente dove saranno mantenuti anche i suoi file temporanei, questo si fa con i comandi: |
226 | 35 | Simone Piccardi | |
227 | 1 | Amministratore Truelite | <pre> |
228 | mkdir /var/spool/vacation |
||
229 | 34 | Amministratore Truelite | chown -R vacation.vacation /var/spool/vacation |
230 | 1 | Amministratore Truelite | chmod o-xr /var/spool/vacation |
231 | 16 | Amministratore Truelite | </pre> |
232 | 35 | Simone Piccardi | |
233 | 1 | Amministratore Truelite | infine si dovrà copiare lo script perl fornito con "PostfixAdmin":http://postfixadmin.sourceforge.net/ nella suddetta directory e renderlo eseguibile: |
234 | 35 | Simone Piccardi | |
235 | 16 | Amministratore Truelite | <pre> |
236 | cd /usr/share/doc/postfixadmin/examples/VIRTUAL_VACATION/ |
||
237 | 1 | Amministratore Truelite | zcat vacation.pl.gz > /var/spool/vacation/vacation.pl |
238 | chmod 700 /var/spool/vacation/vacation.pl |
||
239 | chown vacation.vacation /var/spool/vacation/vacation.pl |
||
240 | </pre> |
||
241 | 35 | Simone Piccardi | |
242 | per farlo funzionare sono però necessari una serie di moduli per il Perl, che si dovranno installare con: |
||
243 | |||
244 | 1 | Amministratore Truelite | <pre> |
245 | 34 | Amministratore Truelite | aptitude install libemail-valid-perl libmime-encwords-perl libmime-perl \ |
246 | 40 | Simone Piccardi | libmail-sender-perl liblog-log4perl-perl libmail-sendmail-perl |
247 | 16 | Amministratore Truelite | </pre> |
248 | 35 | Simone Piccardi | |
249 | 16 | Amministratore Truelite | inoltre si dovranno modificare le prime righe dello script dove sono impostate le credenziali di accesso al database, con qualcosa del genere: |
250 | 35 | Simone Piccardi | |
251 | 16 | Amministratore Truelite | <pre> |
252 | 1 | Amministratore Truelite | our $db_type = 'mysql'; |
253 | our $db_host = 'localhost'; |
||
254 | our $db_username = 'postfixadmin'; |
||
255 | our $db_password = 'passsegretaedifficile'; |
||
256 | 16 | Amministratore Truelite | our $db_name = 'postfixadmin'; |
257 | 34 | Amministratore Truelite | |
258 | 10 | Amministratore Truelite | our $vacation_domain = 'autoreply.miodominio.it'; |
259 | </pre> |
||
260 | 1 | Amministratore Truelite | |
261 | 37 | Simone Piccardi | Occorre poi eseguire una configurazione ulteriore di Postfix, anzitutto occorre definire un nuovo tipo di trasporto ad uso di _vacation_, aggiungendo le righe seguenti a @/etc/postfix/master.cf@: |
262 | 35 | Simone Piccardi | |
263 | 1 | Amministratore Truelite | <pre> |
264 | 34 | Amministratore Truelite | vacation unix - n n - - pipe |
265 | flags=Rq user=vacation argv=/var/spool/vacation/vacation.pl -f ${sender} -- ${recipient} |
||
266 | 10 | Amministratore Truelite | </pre> |
267 | 35 | Simone Piccardi | |
268 | dopo di che si dovrà utilizzarlo per il trasporto delle email indirizzate ad @autoreply.miodominio.it@, definendo dentro @/etc/postfix/transport@: |
||
269 | |||
270 | 10 | Amministratore Truelite | <pre> |
271 | 1 | Amministratore Truelite | autoreply.miodominio.it vacation: |
272 | </pre> |
||
273 | 35 | Simone Piccardi | |
274 | ed infine aggiungere a @/etc/postfix/main.cf@: |
||
275 | |||
276 | 34 | Amministratore Truelite | <pre> |
277 | 10 | Amministratore Truelite | transport_maps = hash:/etc/postfix/transport |
278 | 34 | Amministratore Truelite | </pre> |
279 | 35 | Simone Piccardi | |
280 | 1 | Amministratore Truelite | fatto questo si dovrà fare usare a Postfix la nuova configurazione con: |
281 | 35 | Simone Piccardi | |
282 | 1 | Amministratore Truelite | <pre> |
283 | postmap /etc/postfix/transport |
||
284 | 10 | Amministratore Truelite | postfix reload |
285 | 34 | Amministratore Truelite | </pre> |
286 | |||
287 | 35 | Simone Piccardi | h2. Configurare _Dovecot_ per _Postfixadmin_ |
288 | 34 | Amministratore Truelite | |
289 | 35 | Simone Piccardi | Per l'accesso alla posta mantenuta da _Postfixadmin_ è necessario un server IMAP, vedremo allora come configurare _Dovecot_ che fornisce comunque anche l'accesso con POP, ed il tutto sia in chiaro che con cifratura sotto SSL. Si inizi anzitutto con l'installare le varie componenti di _Dovecot_, questo si fa al solito con (si aggiunga sempre @ntp@ perché _Dovecot_ non gradisce situazioni in cui il tempo ha dei movimenti all'indietro): |
290 | 34 | Amministratore Truelite | |
291 | <pre> |
||
292 | aptitude install dovecot-imapd dovecot-pop3d ntp |
||
293 | 1 | Amministratore Truelite | </pre> |
294 | 35 | Simone Piccardi | |
295 | 37 | Simone Piccardi | la configurazione di base dovrà essere modificata anzitutto per il fatto che la posta deve essere trovate in delle maildir a partire dalla directory @/var/mail/vmail@ nella forma @mydomain.it/username@ ed acceduta con l'utente @vmail@ creato in precedenza. Nel nostro caso questo comporta la modifica delle seguenti righe de file di configurazione principale che è @/etc/dovecot/dovecot.conf@: |
296 | 35 | Simone Piccardi | |
297 | 1 | Amministratore Truelite | <pre> |
298 | mail_location = maildir:/var/mail/vmail/%d/%n |
||
299 | 34 | Amministratore Truelite | mail_privileged_group = vmail |
300 | first_valid_uid = 106 |
||
301 | 1 | Amministratore Truelite | </pre> |
302 | |||
303 | 35 | Simone Piccardi | (dove 106 è l'uid dell'utente @vmail@). |
304 | |||
305 | Occorre poi disabilitare l'autenticazione sugli utenti locali (via PAM) ed utilizzare i dati di MySQL, questo comporta la sostituzione delle direttive @userdb@ e @passdb@ che fan riferimento a PAM con le seguenti che indicano il file da usare per i parametri di accesso al database: |
||
306 | |||
307 | 27 | Amministratore Truelite | <pre> |
308 | 1 | Amministratore Truelite | passdb sql { |
309 | args = /etc/dovecot/dovecot-mysql.conf |
||
310 | 27 | Amministratore Truelite | } |
311 | userdb sql { |
||
312 | args = /etc/dovecot/dovecot-mysql.conf |
||
313 | } |
||
314 | 1 | Amministratore Truelite | </pre> |
315 | 35 | Simone Piccardi | |
316 | ed infine dovremo inserire nel file @/etc/dovecot/dovecot-mysql.conf@ le necessarie configurazioni per l'accesso al database ed ai relativi dati, con un contenuto del tipo di: |
||
317 | |||
318 | 34 | Amministratore Truelite | <pre> |
319 | driver = mysql |
||
320 | 27 | Amministratore Truelite | connect = host=localhost dbname=postfixadmin user=postfixadmin password=passsegretaedifficile client_flags=0 |
321 | 1 | Amministratore Truelite | default_pass_scheme = MD5 |
322 | 27 | Amministratore Truelite | user_query = SELECT maildir, 106 AS uid, 61 AS gid FROM mailbox WHERE username = '%u' |
323 | 1 | Amministratore Truelite | password_query = SELECT password FROM mailbox WHERE username = '%u' AND active = '1' |
324 | 30 | Amministratore Truelite | </pre> |
325 | |||
326 | 35 | Simone Piccardi | (dove 106 e 61 sono _uid_ e _gid_ dell'utente @vmail@). |
327 | 34 | Amministratore Truelite | |
328 | 35 | Simone Piccardi | h2. Autenticazione SMTP |
329 | 30 | Amministratore Truelite | |
330 | 35 | Simone Piccardi | L'autenticazione delle sessioni SMTP può essere eseguita da Postfix rivolgendosi direttamente al servizio fornito da Dovecot attraverso un socket. Per fare tutto ciò il primo passo è quello di configurare Dovecot perché metta a disposizione il socket nel chroot di Postfix; questo si ottiene aggiungendo le seguenti righe a /etc/dovecot/dovecot.conf: |
331 | 30 | Amministratore Truelite | |
332 | 1 | Amministratore Truelite | <pre> |
333 | socket listen { |
||
334 | client { |
||
335 | 34 | Amministratore Truelite | path = /var/spool/postfix/private/auth |
336 | mode = 0660 |
||
337 | user = postfix |
||
338 | group = postfix |
||
339 | } |
||
340 | 27 | Amministratore Truelite | } |
341 | </pre> |
||
342 | 35 | Simone Piccardi | |
343 | e poi bisogna anche, per consentire l'accesso a client bacati come Outlook, modificare la riga dei mechanisms in @/etc/dovecot/dovecot.conf@ come di seguito: |
||
344 | |||
345 | 1 | Amministratore Truelite | <pre> |
346 | 27 | Amministratore Truelite | auth default { |
347 | ... |
||
348 | mechanisms = plain login |
||
349 | 34 | Amministratore Truelite | ... |
350 | } |
||
351 | </pre> |
||
352 | 35 | Simone Piccardi | |
353 | e dopo aver riavviato Dovecot si otterrà il socket all'interno del _chroot_ di Postfix come @private/auth@, come si potrà verificare con il comando: |
||
354 | |||
355 | 27 | Amministratore Truelite | <pre> |
356 | # ls /var/spool/postfix/private/auth -l |
||
357 | srw-rw---- 1 postfix postfix 0 29 set 18:59 /var/spool/postfix/private/auth |
||
358 | 34 | Amministratore Truelite | </pre> |
359 | |||
360 | 35 | Simone Piccardi | Il secondo passo è configurare Postfix per usare questo socket, basterà aggiungere a @/etc/postfix/main.cf@ le linee seguenti: |
361 | |||
362 | 27 | Amministratore Truelite | <pre> |
363 | 34 | Amministratore Truelite | smtpd_sasl_type = dovecot |
364 | 27 | Amministratore Truelite | smtpd_sasl_path = private/auth |
365 | 34 | Amministratore Truelite | </pre> |
366 | |||
367 | 35 | Simone Piccardi | Tutto il resto è la ordinaria configurazione di Postfix per abilitare l'uso di sessioni autenticate, e per far si che queste avvengano con connessioni cifrate sotto TLS; l'autenticazione si abilita aggiungendo a @/etc/postfix/main.cf@ le righe seguenti: |
368 | |||
369 | 34 | Amministratore Truelite | <pre> |
370 | 27 | Amministratore Truelite | smtpd_sasl_auth_enable = yes |
371 | 34 | Amministratore Truelite | smtp_sasl_application_name = smtpd |
372 | smtpd_sasl_local_domain = $myhostname |
||
373 | 27 | Amministratore Truelite | broken_sasl_auth_clients = yes |
374 | </pre> |
||
375 | 35 | Simone Piccardi | |
376 | 27 | Amministratore Truelite | mentre l'uso di TLS con le righe seguenti: |
377 | 35 | Simone Piccardi | |
378 | 1 | Amministratore Truelite | <pre> |
379 | 34 | Amministratore Truelite | smtpd_use_tls = yes |
380 | 1 | Amministratore Truelite | smtpd_tls_auth_only = yes |
381 | smtpd_tls_loglevel = 1 |
||
382 | smtpd_tls_received_header = yes |
||
383 | smtpd_tls_session_cache_timeout = 3600s |
||
384 | tls_random_source = dev:/dev/urandom |
||
385 | </pre> |
||
386 | 35 | Simone Piccardi | |
387 | infine si deve dare l'accesso in spedizione agli utenti aggiungendo la direttiva @permit_sasl_authenticated@ al parametro @smtpd_recipient_restrictions@ che dovrà essere qualcosa del tipo: |
||
388 | |||
389 | 1 | Amministratore Truelite | <pre> |
390 | smtpd_recipient_restrictions = |
||
391 | permit_mynetworks, |
||
392 | permit_sasl_authenticated, |
||
393 | reject_rbl_client zen.spamhaus.org, |
||
394 | reject_non_fqdn_sender, |
||
395 | reject_non_fqdn_recipient, |
||
396 | reject_unknown_sender_domain, |
||
397 | 34 | Amministratore Truelite | reject_unauth_destination |
398 | 1 | Amministratore Truelite | </pre> |
399 | 34 | Amministratore Truelite | |
400 | |||
401 | 35 | Simone Piccardi | h2. CLI script to massive account creation |
402 | 38 | Simone Piccardi | |
403 | _Postfixadmin_ è un'ottima interfaccia di gestione utenti e domini via web, ma come tutte le interfacce grafiche non è tanto pratica quando si tratta di creare centinaia di account in una sola volta. Per questo motivo abbiamo sviluppato un semplice script in _Python_ che consente di eseguire creazioni di massa, disponibile a "questo indirizzo":http://labs.truelite.it/attachments/82/inspostadmusers.py. Il suo limite principale è che può essere usato soltanto se il database di appoggio per PostfixAdmin è MySQL. |
||
404 | |||
405 | Lo script è relativamente semplice da usare, richiede un file CSV con la lista degli account. Dovrebbe lavorare con qualunque tipo di CSV, ma è stato controllato solo con l'output di OpenOffice Calc. La prima riga del file deve contenere i nomi delle colonne e lo script prenderà in considerazione soltanto le colonne con nomi _user_, _domain_, _password_ e _name_ il cui significato è illustrato nella tabella seguente: |
||
406 | |||
407 | |_.Colonna |_.Significato| |
||
408 | |user | parte utente dell'email (come user in @user@domain.com@)| |
||
409 | |password | password in chiaro| |
||
410 | |domain | nome a dominio (come '@domain.com@')| |
||
411 | |name | Nome completo ('Nome Cognome')| |
||
412 | |||
413 | E' necessario fornire almeno le colonne _user_, _domain_ e _password_ e lo script inizializzerà opportunamente le tabelle del database. Gli utenti di posta saranno nella forma @user@domain@ con la password presa dalla colonna omonima. Se non esistenti verranno creati automaticamente anche i domini citati nel file e, specificando l'opzione @-A@, verranno creati anche gli account di default (abuse, hostmaster, postmaster, webmaster) per ciascun dominio. |
||
414 | |||
415 | Lo script richiede un solo argomento, il nome del file CSV, e l'opzione @-p@ seguita dalla password di accesso per il database (cioè secondo le istruzioni precedenti, "passsegretaedifficile"). Ci sono ulteriori opzioni per impostare il nome del database, il relativo utente, l'indirizzo a cui connettersi, ecc. ma i valori di default dovrebbero essere già a posto essendo gli stessi usati dal pacchetto di PostfixAdmin. La lista completa delle opzioni può comunque essere stampata invocando lo script senza argomenti o con l'opzione @-h@. |
||
416 | |||
417 | Lo script non effettua nessuna validazione dei dati, pertanto è pubblicato senza garanzie sotto licenza GPL. Questo significa che fare un backup del database prima di usarlo sarebbe quantomai opportuno. Lo script stamperà un messaggio di errore se alcuni account o domini sono già presenti nel database, saltando la relativa creazione (non verranno cioè sovrascritti) ma proseguirà nella creazione degli altri account o domini non esistenti. Salterà anche la creazione di qualunque account duplicato. |