Code

- Forgot to include modified helpviewer ;-(
[gosa.git] / doc / guide / admin / es / manual_gosa_es_mail.tex
1 \chapter{Servidores de Correo Electrónico}
3 Un E-mail (Correo Electrónico es un sistema de composición, envio y recepción de mensajes sobre sistemas de comunicación electrónica.
4 El Correo Electrónico comenzo en 1965 como una forma de enviar mensajes entre maquinas de un mismo sistema, pero no fue hasta la aprición de ARPANET cuando se hizo realmente popular.
6 En 1980 el IETF desarrollo el procolo SMTP (Simple Mail Transfer Protocol) que se ha convertido en el protocolo dominante para el envio de correo.
8 \section{Funcionamiento del Correo Electrónico}
10 Tenemos dos usuarios A y B, con sus dos maquinas HA y HB, dos servidores de correo a.org y b.org con cuentas de correo a@a.org y b@b.org.
13 \begin{enumerate}
14 \item A compone un nuevo mensaje en su MUA (Mail User Agent / Agente de Correo Electrónico) e indica en el mensaje en un campo denominado TO: la dirección de correo electrónico de B que sera b@b.org.\\
15 Al enviar el mensaje, el MUA lo formateara y lo enviara al servidor MTA (Mail Transfer Agent / Agente de Envio de Correo Electrónico) de A a traves de SMTP (smtp.a.org), este servidor estará configurado en el MUA de A.
16 \item La dirección de B es b@b.org, que está formada por dos partes, una antes de la "@" que es el nombre de usuario y otra despues que es el servidor de correo del usuario, por lo tanto el servidor SMTP de A(smtp.a.org) buscara a traves de los DNS el campo MX (Mail Exchange / Intercambiador de Correo Electrónico).
17 \item El servidor DNS le devolvera la dirección MX de b.org (en nuestro ejemplo sera mx.b.org).
18 \item El servidor smtp.a.org enviara el mensaje mx.b.org usando SMTP y mx.b.org lo guardara en la carpeta del usuario.
19 \item El usuario B quiere ver su correo y tendra dos formas de verlo:
20 \begin{enumerate}
21 \item Descargarlo, el usuario B utiliza un MUA que se descarga el correo en su maquina y utilizara el protocolo POP3 para ello.
22 \item Acceder sin descargarlo, el usuario B accede a su correo y lo lee, pero no los descarga en su maquina, usara entonces el protocolo IMAP4 para ello.
23 \end{enumerate}
24 \end{enumerate}
26 \section{SMTP Servers}
28 SMTP (Simple Mail Transfer Protocol / Protocolo simple de transferencia de correo electrónico) es el protocolo estandar de envío de correo electrónico a través de Internet.\\
29 SMTP usa el para las comunicaciones el puerto TCP 25.\\
30 Para encontar el servidor SMTP de un dominio se hace una buscada dns del campo MX de ese dominio.\\
31 RFC relacionados con SMTP: RFC 2821 \cite{2821}, RFC 2822 \cite{2822}, RFC 1869 \cite{1869}, RFC 1891 \cite{1891}, RFC 2554 \cite{2554}
34 \subsection{El problema del SPAM}
35 El SPAM (Recepción de mensajes no solicitados) es el gran problema del correo electrónico, mas del 50 por ciento del correo es correo basura. Para ello se están desarrollando técnicas como smtp-auth y el uso de paquetes especializados en la detección de estes  \ref{spam}.
37 \subsection{SMTP-AUTH}
39 Es una extensión al protocolo SMTP para que estos soporten autentificación, de esta manera el usuario que quiere enviar correo debe tener un usuario y contraseña en el servidor, asi queda registrado y se comprueba su identidad.
41 La idea original es que los servidores SMTP no estén en open-relay (Abiertos al publico) de tal manera que solo se puedan enviar correo desde redes controladas y que cada usuario sea identificado, así los servidores con smtp-auth no pueden ser utilizados por sistemas externos para el envio de SPAM.
43 \subsection{Comandos SMTP Básicos}
45 \begin{itemize}
46 \item[HELO] Identifica el servidor SMTP que envia al que recibe.
47 \item[MAIL] Comienza una transferencia de Correo Electrónico a uno o mas recipientes.\\ Indica quien envía el mensaje.
48 \item[RCPT] Identifica al usuario que va ha recibir el Correo Electrónico.
49 \item[DATA] La siguientes lineas serán el contenido del correo electrónico.
50 \item[SEND] Envia el correo electrónico a una o mas estacones.
51 \item[RSET] Termina una transferencia.
52 \item[VRFY] Pregunta al SMTP receptor si el usuario ha sido identificado.
53 \item[EXPN] Pregunta al receptor si la lista de correo ha sido identificada.
54 \item[QUIT] Cierra la conexión.
55 \end{itemize}
57 \subsection{Codigos de Error SMTP mas usuales}
59 Codigos de Error:
60 \begin{itemize}
61 \item[421] Service not available. Esto ocurre normalmente cuando el servidor remoto está caido.
62 \item[450] Mailbox unavailable. Suele ocurrir cuando no se tiene acceso a la carpeta de correo del recipiente o esta esta bloqueada por otra aplicación.
63 \item[451] Requested action aborted. Ocurre cuando existe un problema en la ejecución del SMTP.
64 \item[452] Requested action not taken. Tambien ocurre cuando hay problemas con la carpeta de correo del recipiento o está llena.
65 \item[500] Syntax error, command unrecognized. El servidor SMTP no soporta este comando.
66 \item[501] Syntax error in parameters. Soporta el comando, pero los argumentos no son correctos.
67 \item[502] Command not implemented. Un caso parecido a 500.
68 \item[503] Bad sequence of commands. La secuencias de comando no es correcta.
69 \item[550] mailbox unavailable. Como 450.
70 \item[554] Transaction failed. La transferencia no ha sido valida.
71 \end{itemize}
73 Codigo de Estado:
74 \begin{itemize}
75 \item[211] System status. Estado del sistema.
76 \item[214] Help message. Ayuda del sistema.
77 \item[220] Service ready. El servidor esta preparado para aceptar correo.
78 \item[221] Service closing transmission channel. El servidor cierra la conexión.
79 \item[250] Requested mail action okay. El comando pedido al servidor, se ha ejecutado correctamente.
80 \item[354] Start mail input; end with . . Indica que se puede enviar el contenido del mensaje, este debe terminar en un linea que contenga solo un ".".
81 \end{itemize}
84 \section{Postfix}
86 Postfix en un servidor SMTP opensource desarrollado originalmente por Wietse Venema en los laboratorios de IBM.\\
87 Es el recomendado para su uso con GOsa, entre otras cosas por sus caracteristicas tecnicas en el acceso ldap.
89 \subsection{Instalación}
91 Postfix se puede descargar de \hlink{http://www.postfix.org/download.html}, existe abundante documentación tanto en su página web en \hlink{http://www.postfix.org/documentation.html}, como en el wiki: \hlink{http://postfixwiki.org/index.php?title=Main\_Page}.
93 Postfix soporta una gran cantidad de extensiones, con las cuales gestionar los usuarios y los dominios. Existe incluso un howto que le permite usar qmail.schema para convertir sistemas basados en qmail-ldap a postfix y viceversa en  \hlink{http://gentoo-wiki.com/HOWTO\_Postfix-LDAP\_virtual\_users\_with\_qmail\_schema}.
95 En este manual nos concentraremos en su extensión ldap, para ello necesitaremos tener instalado el servidor ldap \ref{down_ldap}, openSSL \ref{down_ssl} y SaSL \ref{down_sasl}. Descargamos y descomprimimos postfix-2.2.X.tgz en /usr/src, y ejecutamos:
97 \bbox
98 \verb|# make makefiles CCARGS="-DMAX_DYNAMIC_MAPS -DHAS_PCRE -DHAS_LDAP -DHAS_SSL \ |\\
99 \verb|       -I/usr/include/openssl -DUSE_SASL_AUTH -I/usr/include/sasl -DUSE_TLS" |\\
100 \verb|# make install|\\
101 \ebox
103 En la instalación de ejemplo no se ha ejecutado make install y se han seguido las directrices del paquete debian, estas son:
105 \bbox
106 \verb|# install lib/*.1 /usr/lib|\\
107 \verb|# for i in /usr/lib/*.1; do ln -sf ${i##*/} ${i%.*.*}; done|\\
108 \verb|# install lib/dict_ldap.so /usr/lib/postfix|\\
109 \verb|# install lib/dict_pcre.so /usr/lib/postfix|\\
110 \verb|# install lib/dict_tcp.so /usr/lib/postfix|\\
111 \verb|# install libexec/[a-z]* /usr/lib/postfix|\\
112 \verb|# install bin/[a-z]* /usr/sbin|\\
113 \verb|# install auxiliary/qshape/qshape.pl /usr/sbin/qshape|\\
114 \verb|# install -m 0444 HISTORY /usr/share/doc/postfix/changelog|\\
115 \verb|# ln -s ../sbin/rmail /usr/bin/rmail|\\
116 \verb|# ln -s ../sbin/sendmail /usr/bin/newaliases|\\
117 \verb|# ln -s ../sbin/sendmail /usr/bin/mailq|\\
118 \verb|# ln -s ../sbin/sendmail /usr/lib/sendmail|\\
119 \verb|# install -m 0755 conf/postfix-script conf/post-install /etc/postfix|\\
120 \verb|# install -m 0644 conf/postfix-files /etc/postfix|\\
121 \verb|# install -m 0644 conf/main.cf /usr/share/postfix/main.cf.dist|\\
122 \verb|# install -m 0644 conf/master.cf /usr/share/postfix/master.cf.dist|\\
123 \verb|# install man/man1/*.1 /usr/share/man/man1|\\
124 \verb|# install man/man5/*.5 /usr/share/man/man5|\\
125 \verb|# for f in man/man8/*.8; do \|\\
126 \verb|  install ${f} /usr/share/${f}postfix; \|\\
127 \verb|done|\\
128 \verb|# install rmail/rmail.8 /usr/share/man/man8|\\
129 \verb|# gzip -9 /usr/share/man/man8/*.8postfix|\\
130 \verb|# ln -sf bounce.8postfix.gz /usr/share/man/man8/trace.8postfix.gz|\\
131 \verb|# ln -sf bounce.8postfix.gz /usr/share/man/man8/defer.8postfix.gz|\\
132 \ebox
134 \subsection{Configuración}
136 Antes de poder utilizar postfix debemos configurarlo, su configuración está guardada en /etc/postfix, y los puntos importantes de esta son:
138 \subsubsection{main.cf}
140 Es la configuración principal de postfix y se indican numerosos parametros de funcionamiento (Gracias a Cajus Pollmeier por la configuración):
142 \cbbox
143 \verb|# Configuración principal de POSTFIX|\\
144 \\
145 \verb|# Configuración específica para debian|\\
146 \verb|command_directory = /usr/sbin|\\
147 \verb|daemon_directory = /usr/libexec/postfix|\\
148 \verb|program_directory = /usr/libexec/postfix|\\
149 \verb|# Que muestra el servidor en un HELO|\\
150 \verb|smtpd_banner = $myhostname ESMTP $mail_name|\\
151 \verb|setgid_group = postdrop|\\
152 \verb|biff = no|\\
153 \verb|append_dot_mydomain = no|\\
154 \\
155 \verb|# Seguridad|\\
156 \verb|disable_vrfy_command = yes|\\
157 \verb|smtpd_sasl_auth_enable = yes|\\
158 \verb|smtpd_sasl_local_domain = $myhostname|\\
159 \verb|smtpd_tls_auth_only = no|\\
160 \verb|#smtpd_sasl_security_options = noplaintext|\\
161 \verb|smtpd_use_tls = yes|\\
162 \verb|smtpd_tls_cert_file = /etc/postfix/cert.pem|\\
163 \verb|smtpd_tls_key_file = /etc/postfix/key.pem|\\
164 \verb|smtpd_tls_CAfile = /etc/postfix/CAcert.pem|\\
165 \\
166 \verb|# Fix Microsoft mail clients|\\
167 \verb|broken_sasl_auth_clients = yes|\\
168 \\
169 \verb|# Cuotas por defecto|\\
170 \verb|mail_size_limit = 10240000|\\
171 \verb|message_size_limit = 10240000|\\
172 \verb|header_size_limit = 10240|\\
173 \verb|bounce_size_limit = 500000|\\
174 \\
175 \verb|# Colas por defecto|\\
176 \verb|virtualsource_server_host = 10.3.66.11|\\
177 \verb|virtualsource_search_base = dc=gonicus,dc=de|\\
178 \verb#virtualsource_query_filter = (&(|(mail=%s)(gosaMailAlternateAddress=%s))(objectClass=gosaAccount))#\\
179 \verb|virtualsource_result_attribute = uid,gosaMailForwardingAddress|\\
180 \\
181 \verb|# Carpetas compartidas|\\
182 \verb|sharedsource_server_host = 10.3.66.11|\\
183 \verb|sharedsource_search_base = dc=gonicus,dc=de|\\
184 \verb#sharedsource_query_filter = (&(|(mail=%s)(gosaMailAlternateAddress=%s))(objectClass=posixGroup))#\\
185 \verb|sharedsource_result_attribute = gosaSharedFolderTarget,gosaMailForwardingAddress|\\
186 \\
187 \verb|# Access Lists for Non Local Delivery|\\
188 \verb|acllocal_server_host = 10.3.66.11|\\
189 \verb|acllocal_search_base = dc=gonicus,dc=de|\\
190 \verb#acllocal_query_filter = (&(|(mail=%s)(gosaMailAlternateAddress=%s))(gosaMailDeliveryMode=*L*))#\\
191 \verb|acllocal_result_attribute = mail|\\
192 \verb|acllocal_result_filter = insiders_only|\\
193 \\
194 \verb|# Origen|\\
195 \verb|myorigin = $mydomain|\\
196 \\
197 \verb|# destinos|\\
198 \verb|mydestination = $myhostname localhost.localdomain localhost.$mydomain /etc/postfix/locals|\\
199 \\
200 \verb|# redes locales|\\
201 \verb|mynetworks = 127.0.0.0/8 10.0.0.0/8|\\
202 \\
203 \verb|# Nombre de host|\\
204 \verb|myhostname = mail.gonicus.local|\\
205 \\
206 \verb|# Dominio|\\
207 \verb|mydomain = gonicus.de|\\
208 \\
209 \verb|# Interfaces que escuchan|\\
210 \verb|inet_interfaces = all|\\
211 \\
212 \verb|# Protección contra SPAM, reglas regex basicas|\\
213 \verb|#header_checks = regexp:/etc/postfix/header_checks|\\
214 \verb|# Bsp.: /etc/postfix/header_checks|\\
215 \verb|#  /^to: *friend@public\.com$/ REJECT|\\
216 \verb|#  /^to: *friend@public\.com$/ IGNORE|\\
217 \verb|#  /^to: *friend@public\.com$/ WARN|\\
218 \\
219 \verb|# Restricciones SMTP|\\
220 \verb|#smtpd_client_restrictions = hash:/etc/postfix/access, reject_maps_rbl|\\
221 \verb|#smtpd_client_restrictions = permit_mynetworks, reject_unknown_client, reject_maps_rbl|\\
222 \verb|smtpd_client_restrictions = permit_mynetworks|\\
223 \\
224 \verb|# Para el envio SMTP|\\
225 \verb|#smtpd_sender_restrictions = hash:/etc/postfix/access, check_sender_access hash:|\\
226 \verb|#smtpd_sender_restrictions = reject_unknown_sender_domain, reject_non_fqdn_sender|\\
227 \verb|smtpd_sender_restrictions = regexp:/etc/postfix/protected, check_sender_access hash:/etc/postfix/badmailfrom|\\
228 \\
229 \verb|# Para los recipientes|\\
230 \verb|#smtpd_recipient_restrictions = permit_sasl_authenticated, reject_non_fqdn_recipient, check_client_access hash:/var/lib/pop|\\
231 \verb|smtpd_recipient_restrictions = regexp:/etc/postfix/protected,|\\
232 \verb|   permit_mynetworks,|\\
233 \verb|   permit_sasl_authenticated,|\\
234 \verb|   check_relay_domains|\\
235 \\
236 \verb|# Restricciones la comando HELO|\\
237 \verb|smtpd_helo_required = no|\\
238 \verb|#smtpd_helo_restrictions = permit_mynetworks, reject_unknown_hostname, reject_invalid_hostname|\\
239 \verb|smtpd_helo_restrictions = permit_mynetworks|\\
240 \\
241 \verb|# |\\
242 \verb|smtpd_delay_reject = yes|\\
243 \verb|strict_rfc821_envelopes = yes|\\
244 \\
245 \verb|# Mapas antispam|\\
246 \verb|#maps_rbl_domains = hash:/etc/postfix/rbl|\\
247 \verb|maps_rbl_domains = blackholes.mail-abuse.org|\\
248 \\
249 \verb|# Sobre los usuarios y autentificación|\\
250 \verb|smtpd_sasl_auth_enable = yes|\\
251 \\
252 \verb|smtpd_restriction_classes = insiders_only|\\
253 \verb|insiders_only = check_sender_access regexp:/etc/postfix/insiders, reject|\\
254 \\
255 \verb|# relay|\\
256 \verb|relay_domains = $mydestination|\\
257 \\
258 \verb|# transportes|\\
259 \verb|fallback_transport = smtp|\\
260 \verb|mailbox_transport = lmtp:unix:/var/lib/imap/socket/lmtp|\\
261 \\
262 \verb|# Control de rendimiento|\\
263 \\
264 \verb|#local_destination_concurrency_limit = 2|\\
265 \verb|#default_destination_concurrency_limit = 10|\\
266 \verb|#uucp_destination_recipient_limit = 100|\\
267 \verb|#smtp_destination_recipient_limit = 100|\\
268 \\
269 \verb|# Manipulación de direcciones|\\
270 \verb|#rewrite gonicus.de!horst to horst@gonicus.de|\\
271 \verb|#rewrite horst%gonicus.de to horst@gonicus.de|\\
272 \verb|#rewrite horst to horst@gonicus.de|\\
273 \\
274 \verb|# Mapas canonicos|\\
275 \verb|#canonical_maps = hash:/etc/postfix/canonical|\\
276 \verb|#sender_canonical_maps = hash:/etc/postfix/sender_canonical|\\
277 \verb|#recipient_canonical_maps = hash:/etc/postfix/recipient_canonical|\\
278 \\
279 \verb|# Mascarada|\\
280 \verb|#masquerade_domains = $mydomain|\\
281 \verb|#masquerade_exceptions = root|\\
282 \verb|#masquerade_clases = envelope_sender, envelope_recipient, header-sender, header_recipient|\\
283 \\
284 \verb|# Direcciones Virtuales|\\
285 \verb|virtual_maps = ldap:virtualsource, ldap:sharedsource|\\
286 \\
287 \verb|# Mapas de Transportes|\\
288 \verb|#default_transport = smtp-relay|\\
289 \verb|#transport_maps = hash:/etc/postfix/transports|\\
290 \\
291 \verb|# Aliases|\\
292 \verb|alias_maps = hash:/etc/aliases|\\
293 \\
294 \verb|# Antivirus a traves de amavis|\\
295 \verb|#content_filter = vscan:|\\
296 \verb|#soft_bounce = yes|\\
297 \\
298 \ebox
300 \subsubsection{master.cf}
301 \subsubsection{sasl}
302 \subsubsection{ldap}
304 \section{Qmail-ldap}
306 \subsection{Instalación}
307 \subsection{Configuración}
309 \section{Sendmail}
311 \subsection{Instalación}
312 \subsection{Configuración}
314 \section{Exim}
316 \subsection{Instalación}
317 \subsection{Configuración}
319 \subsection{IMAP / POP Servers}
321 \section{Cyrus}
323 \section{Courier}
325 \section{SPAM}
326 \label{spam}
328 \section{VIRUS}
329 \label{virus}