Archivo etiqueta iptables
Shell Script para incluir/actualizar “drop.lasso” de Spamhaus usando iptables en Gentoo Linux
Este es un pequeño Shell Script para añadir y actualizar rangos de IPs de la lista drop.lasso de Spamhaus.org y que ha determinado como principales emisores de SPAM en Internet.
# declaramos las variables que vamos a usar.
IPTABLES="/sbin/iptables"
SPAM_URL_spamhaus="http://www.spamhaus.org/drop/drop.lasso"
SPAM_FILE_TMP="/home/backup/scripts/spamhaus.ips"
SPAM_TABLE_spamhaus="Spamhaus"
SPAM_IPS=$(cat $SPAM_FILE_TMP | grep -iE "^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}" | awk -F\; '{ print $1 }')
# borramos el fichero de ips anterior si existe.
rm -f $SPAM_FILE_TMP
# descargamos la ultima actualización realizada por spamhaus.org.
# -q no muestra ningún log de registro | -c para continuar la descarga si se cortara.
wget -qc $SPAM_URL_spamhaus -O $SPAM_FILE_TMP
# creamos las lista de ips.
$IPTABLES -n -L INPUT | grep -q "$SPAM_TABLE_spamhaus"
if [ $? -eq 0 ] ; then
# borramos todas las reglas que contiene la cadena spamhaus.
$IPTABLES -F $SPAM_TABLE_spamhaus
else
# crea una nueva cadena llamada spamhaus si no existe.
$IPTABLES -N $SPAM_TABLE_spamhaus
# añade la regla spamhaus para todo el tráfico entrante.
$IPTABLES -A INPUT -j $SPAM_TABLE_spamhaus
fi
# con RETURN salta el objetivo si existe.
$IPTABLES -A $SPAM_TABLE_spamhaus -j RETURN
# recorremos la lista de IPs para ir incluyéndolas una por una a iptables.
for IP in $SPAM_IPS
do
# inserta una nueva regla a la cadena con la opciones especificadas.
# -p all (bloquea el trafico recibido a través de los protocolos icmp, tcp, udp)
# -s ip (ip origen del paquete)
# -j DROP (elimina el paquete recibido)
$IPTABLES -I $SPAM_TABLE_spamhaus -p all -s $IP -j DROP
done
“El Shell Script ha sido probado correctamente en Gentoo y Fedora Core 5″
Como veis es bastante sencillo y probablemente mejorable … luego solo tendríamos que añadirlo a nuestro crontab para que se ejecute periódicamente.
Descargar el ejemplo.
Howto fail2ban en Gentoo Linux
Fail2Ban es un framework escrito en Python, el cual es capaz de correr en sistemas Linux y con firewalls ya funcionando como iptables, TCP Wrapper, etc … Es libre y se distribuye bajo licencia GNU. Su objetivo es leer logs del sistema y banear aquellas IPs que intentan loguear en el sistema un número determinado de veces. Para instalarlo necesitamos tener Python 2.3 o superior.
Instalación y ficheros de configuración.
# Como ya sabemos las instalaciones en Gentoo Linux son sencillas. emerge fail2ban. # el fichero de configuración esta localizado en /etc/fail2ban/fail2ban.conf # el fichero donde configuraremos los parámetros a configurar está en /etc/fail2ban/jail.conf # y los directorios de acciones y filtros a realizar en /etc/fail2ban/action.d/ /etc/fail2ban/filter.d/
# del fichero de configuración fail2ban.conf lo más importante es indicarle la ruta donde se guardará el log. logtarget = /var/log/fail2ban.log # el tiempo en segundos de baneo a una IP. bantime = 600 # el número de fallos antes de ejecutar un Ban a IP. maxretry = 3
A continuación muestro 2 ejemplos del fichero jail.conf para comprobar los accesos en los protocolos SSH y FTP usando IPtables.
[ssh-iptables] enabled = true filter = sshd action = iptables[name=SSH, port=ssh, protocol=tcp] mail-whois[name=SSH, dest=su@email.net] logpath = /var/log/auth.log maxretry = 3 [proftpd-iptables] enabled = true filter = proftpd action = iptables[name=ProFTPD, port=ftp, protocol=tcp] mail-whois[name=ProFTPD, dest=su@email.net] logpath = /var/log/auth.log maxretry = 3
true indica que deseamos activarlo, que el puerto y protocolo a usar será ssh o ftp, y que nos enviará un email en el caso de que se ejecute un Ban. Es muy importante indicarle el LOG donde chequeará tanto los fallos como el numero de intentos antes de proceder a banear una IP.
Puesta en marcha y comprobaciones varias.
# Para iniciar fail2ban ejecutamos fail2ban-client start # y para cargar nuevas configuraciones fail2ban-client reload # tambien debemos incluirlo para que se inicie como demonio al arrancar el sistema rc-update add fail2ban default # y chequearemos que está trabajando correctamente. ps -ef