[postfix-es] fqdn hostname
Rodolfo Pilas
rodolfo en pilas.net
Jue Sep 18 18:28:19 CEST 2008
Alejandro Vilte escribió:
> Ahora quería comentarte que me pareció interesante el mensaje que pensás
> redactarle para el remitente. Lo pudistes hacer ? Yo tenía idea, pero no
> investigue mucho al respecto todavía.
Claro, te cuento que es lo que he hecho:
a) un archivo con los dominios que tienen problemas
----- archivo impuros -----
dominio1.com
dominio2.com
...
b) un script que lee el log, saca los rechazados, los unifica (para no
tener repeticiones) y se fija los from en el archivo impuros, si alguno
coincide le manda mensaje, aquí va el script (correo.py):
> #!/usr/bin/env python
>
> import fileinput
> import os
> import smtplib
> from email.MIMEText import MIMEText
>
> logfile = "/var/log/mail.log"
> impfile = "impuros"
> parse = []
> impuros = []
>
> try:
> os.path.isfile(impfile)
> for line in open(impfile,'r').readlines():
> impuros.append(line.rstrip())
>
> except IndexError:
> print "Error al leer"+impfile
>
>
> try:
> os.path.isfile(logfile)
> for line in fileinput.input([logfile]):
> if line.find("NOQUEUE: reject: RCPT from") > -1:
> if line.find("cannot find your hostname") > -1:
> imp = line.split()
>
> # [222.253.182.149]; from=<zeebarb en tnni.net> to=<jtenor en kdes.com>
> IP = imp[19].replace('[', '').replace('];', '')
> VIENEDE = imp[20].replace('from=<', '').replace('>', '')
> IBAPARA = imp[21].replace('to=<', '').replace('>', '')
>
> # solo agrego cuando from no es vacio -> from=<>
> if len(VIENEDE) > 0:
> parse.append( (IP, VIENEDE, IBAPARA) )
>
> # quito repetidos (uniq) y se guardan en reject
> for reject in set(parse):
>
> # reviso si from esta en listado impuros
> for i in range(len(impuros)):
> if reject[1].find(impuros[i]) > -1:
>
> msg = MIMEText("""ATENCION:
>
> Usted recibe este correo, pues ayer ha enviado un mensaje a:
>
> """+reject[2]+"""
>
> y su mensaje HA SIDO RECHAZADO POR NUESTRO SERVIDOR DE CORREO.
>
> El motivo de este rechazo es que su servidor, identificado con la
> direccion IP """+reject[0]+""" no se cumple los estandares de
> configuracion para envio de correo.
>
> Por favor, debe ponerse en contacto con el administrador del servidor
> para que ajuste la configuracion de SU servidor para cumplir con
> con los estandares.
>
> Hasta que su servidor no sea reparado, TODOS los correos que envie seran
> interpretados como SPAM y seran rechazados.
>
> Quedamos a sus ordenes por cualquier duda.
>
> --
> PostMaster
>
> Las inversiones en fiabilidad aumentaran hasta que superen el coste probable
> de los errores o hasta que alguien insista en que el trabajo se haga bien...
> -- 4ta. Ley de Gilb
>
> """)
> msg['Subject'] = 'ATENCION CORREO RECHAZADO'
> #msg['From'] = "Postmaster "
> msg['Reply-to'] = "postmaster en rootway.com"
> msg['To'] = reject[1]
>
> s = smtplib.SMTP()
> s.connect("localhost")
> s.sendmail("postmaster en servidor.com", reject[1], msg.as_string())
> s.close()
>
> # imprime stdout para poder mandar mail con resultado consolidado
> # correo.py | mail -s "resultado" rpilas en servidor.com
> print reject
>
> except IndexError:
> print "Error al leer"+logfile
>
No me aguanté y les mando la 4ta. Ley de Gilb a los orígenes.
En caso que algun dominio "arregle" el problema, los correos son
aceptados, entonces nunca mas seran tenidos en cuenta por este script.
Dicho de otro forma, si lo arreglan, no hay necesidad de borrar los
dominios correctos de la lista de impuros.
Saludos,
Rodolfo Pilas
------------ próxima parte ------------
Se ha borrado un mensaje que no está en formato texto plano...
Nombre : signature.asc
Tipo : application/pgp-signature
Tamaño : 249 bytes
Descripción: OpenPGP digital signature
Url : http://lists.wl0.org/pipermail/postfix-es/attachments/20080918/fb269e5b/attachment.pgp
More information about the postfix-es
mailing list