Cortafuegos con software libre. Diez años de PF

311e7060e962b7a9bd9016221e7bf184?s=47 Miguel Vidal
November 20, 2011

Cortafuegos con software libre. Diez años de PF

Brief introduction to open source firewalls with OpenBSD Packet Filter.

311e7060e962b7a9bd9016221e7bf184?s=128

Miguel Vidal

November 20, 2011
Tweet

Transcript

  1. 1.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Cortafuegos con software libre. Diez a˜ nos de PF Master oficial en Software Libre Miguel Vidal http://gsyc.urjc.es/~mvidal Twitter: @mvidallopez 17 de noviembre de 2011 1 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  2. 2.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF c 2011 Miguel Vidal This work is licensed under a Creative Commons Attribution 3.0 License http://creativecommons.org/licenses/by/3.0 2 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  3. 3.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Cortafuegos y filtrado de paquetes TCP/IP 3 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  4. 4.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 4 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  5. 5.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes ¿Qu´ e es un cortafuegos? Un equipo protegido y fiable que funciona como punto de regulaci´ on entre un grupo de redes (normalmente una red privada y una red p´ ublica). Todo el tr´ afico de red entre las redes involucradas se encamina a trav´ es del cortafuegos. En grandes corporaciones incluso puede haber cortafuegos dentro de la red corporativa para aislar las zonas importantes de la organizaci´ on. Crear cortafuegos es un arte: exige comprender muy bien la tecnolog´ ıa de red subyacente, pero tambi´ en la filosof´ ıa de dise˜ no de cortafuegos. 5 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  6. 6.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes ¿Qu´ e es un cortafuegos? Firewall (FW): t´ ermino usado para referirse a cosas muy dispares en los ´ ultimos a˜ nos. Se llama igual al FW casero que ponen en tu l´ ınea ADSL o al que le cuesta miles de d´ olares a una empresa. ¿Qu´ e diferencias hay? Funcionalidades que ofrece. Hardware en el que corre. Robustez y fiabilidad de su software. 6 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  7. 7.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes ¿Qu´ e es un cortafuegos? Un cortafuegos se configura mediante un conjunto de reglas que determina qu´ e tr´ afico puede pasar y cu´ al ser´ a bloqueado (con respuesta) o desechado (sin respuesta). Los cortafuegos pueden situarse de formas distintas: La forma m´ as simple (e insegura) es un solo equipo que adem´ as proporciona otros servicios. La forma m´ as sofisticada son las DMZ (o red perimetral), que puede involucrar a varios equipos cortafuegos. 7 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  8. 8.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 8 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  9. 9.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Dise˜ no de cortafuegos con un solo firewall 9 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  10. 10.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Dise˜ no de cortafuegos con 2 firewalls (DMZ) 10 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  11. 11.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 11 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  12. 12.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Tipos de procesado de paquetes Filtrado: decidir en distintos momentos del flujo si un paquete pasa o es bloqueado. Modificaci´ on: modificaci´ on mientras se mueve el flujo de paquetes Traducci´ on (NAT): permite redirigir el tr´ afico de forma transparente mediante la modificaci´ on de la fuente, el destino o los puertos. 12 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  13. 13.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes ¿Qu´ e es el filtrado IP? El filtrado IP consiste en decidir qu´ e paquetes se procesar´ an y cu´ ales ser´ an rechazados. Algunos criterios posibles para filtrar: Tipo de protocolo: TCP, UDP, ICMP, etc. N´ umero de puerto (para TCP/UDP) Tipo de paquete: SYN/ACK, datos, petici´ on de eco ICMP... Origen del paquete Destino del paquete Los conjuntos de reglas (rulesets) se componen mediante combinaci´ on de algunos de estos criterios. 13 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  14. 14.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes ¿Qu´ e es el filtrado de IP? El filtrado IP es una utilidad de capa de red (layer-3). No conoce nada de las aplicaciones que usan las conexiones de red. Por ejemplo, si filtramos por puerto, ese mismo servicio podr´ ıa ejecutarse en otro puerto y el firewall no lo impedir´ ıa. Para solucionar esto, se usan servidores proxy, que gestionan la conexi´ on y s´ ı comprenden el servicio. 14 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  15. 15.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Conceptos b´ asicos default accept versus default deny. Inspecci´ on de paquetes: Stateful vs stateless En los FW de primera generaci´ on no habia estado, lo que facilitaba el spoofing. La inspecci´ on de estado guarda registros de todas las conexiones de red que pasan por el cortafuegos. Establecimiento de la comunicaci´ on TCP en tres pasos (Three-way handshake): SYN packet: solicitud de sincronizaci´ on SYN+ACK packet: sincronizaci´ on y acuse de recibo del servidor ACK packet: acuse de recibo (acknowledgment) del cliente. 15 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  16. 16.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Filtrado de paquetes Un firewall avanzado puede hacer m´ as cosas adem´ as de bloquear. Realiza otras funcionalidades importantes: enmascaramiento, NAT, auditor´ ıas, gesti´ on de ancho de banda, balanceo de carga, filtrado por criterios espec´ ıficos, redundancia... 16 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  17. 17.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes Herramientas libres para filtrado de paquetes iptables: Linux ipfilter: *Solaris, illumos, FreeBSD, NetBSD, Linux, HP-UX, IRIX PF (Packet Filter): OpenBSD (nativo), FreeBSD, NetBSD, DragonFly. Comparativa: http://en.wikipedia.org/wiki/Comparison_of_firewalls 17 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  18. 18.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Diez a˜ nos de Packet Filter (PF) 18 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  19. 19.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF ¿Qu´ e es PF? Es un filtro de paquetes (o firewall) de tr´ afico TCP/IP basado en configuraci´ on din´ amica (stateful rules). Considerado el mejor software libre para cortafuegos, balanceo de carga y gesti´ on de tr´ afico de red. Comparable en funcionalidad a las soluciones privativas m´ as caras (Cisco, Juniper, etc., > 50K d´ olares). Desarrollado y mantenido por el equipo de desarrollo de OpenBSD (portado tambi´ en a otros BSD). Equivalente (aunque mucho m´ as funcional) a iptables en Linux. 19 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  20. 20.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 20 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  21. 21.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF ¿Qu´ e es PF? PF es parte de la pila de red del kernel. No solo protege de ataques, sino que permite redundancia (HA) y escalabilidad (combinado con CARP y pfsync). Tambi´ en NAT y control de ancho de banda: calidad del servicio (QoS) y ALTQ (priorizaci´ on de colas). Busca la sencillez de las reglas, la consistencia y la legibilidad. Filtra bas´ andose en cualquier paquete o conexi´ on: direcci´ on de origen o destino, protocolo, puerto, etc. A partir de estos criterios, PF ejecuta la acci´ on que especifiquemos. 21 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  22. 22.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 22 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  23. 23.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Antes de PF: Sobre BSD BSD es el acr´ onimo de Berkeley Software Distribution. Originalmente se refiere a un conjunto de software para Unix desarrollado en la Universidad de Berkeley (1975-1990). Por ejemplo, FFS o la implementaci´ on m´ as popular de TCP/IP (llamada Net/2). Con el tiempo se convirti´ o en Unix libre completo: 4.4BSD. Dio lugar a una familia de sistemas Unix: FreeBSD, NetBSD, OpenBSD, DragonFly BSD, y, para algunas definiciones, Mac OS X de Apple. PF nace en el ´ ambito del proyecto OpenBSD. 23 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  24. 24.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Antes de PF: ipfilter OpenBSD era ya en los 90 el BSD m´ as orientado a seguridad. OpenBSD usaba un subsistema llamado IPFilter, escrito por Darren Reed. Su c´ odigo usaba una extra˜ na variante de la licencia BSD. 24 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  25. 25.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Licencia de ipfilter (2000) /* * Copyright (C) 1993-2000 by Darren Reed. * * The author accepts no responsibility for the use of this software * and provides it on an ‘‘as is’’ basis without express or implied * warranty. * * Redistribution and use in source and binary forms are permitted * provided that this notice is preserved and due credit is given * to the original author and the contributors. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * I hate legaleese, don’t you ? */ 25 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  26. 26.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Antes de PF: ipfilter Se le pide a su autor, Darren Reed, que “clarifique” la licencia. 26 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  27. 27.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Aclaraci´ on a la licencia de ipfilter (2001) /* /* Copyright (C) 1993-2001 by Darren Reed. * * The author accepts no responsibility for the use of this software * and provides it on an ‘‘as is’’ basis without express or implied * warranty. * * Redistribution and use in source and binary forms are permitted * provided that this notice is preserved and due credit is given * to the original author and the contributors. * * Yes, this means that derivitive or modified works are not * permitted without the author’s prior consent. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * / 27 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  28. 28.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Antes de PF: ipfilter En 2001, aclara que esta variante no permit´ ıa modificar el c´ odigo sin permiso de Darren. ¡No era software libre! El 30 de mayo de 2001 ipfilter se borra del ´ arbol principal de OpenBSD. 28 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  29. 29.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Theo de Raadt anuncia que IPFilter ser´ a reemplazado Date: Tue, 29 May 2001 19:13:11 -0600 From: Theo de Raadt <deraadt@cvs.openbsd.org> Subject: ipf sometime in the next 20 hours, i will be removing ipf from the source tree since it does not meet our freedom requirements, as have been outlined in policy.html and goals.html since the start of our project. we will have to work on an alternative. 29 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  30. 30.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Auditor´ ıa de licencias OpenBSD decidi´ o auditar las licencias del ´ arbol de c´ odigo al completo. Se encontraron un buen n´ umero de licencias problem´ aticas. La mayor´ ıa se resolvieron hablando con el autor. Unas cuantas se resolvieron reescribiendo el c´ odigo o elimin´ andolo. ¡El “drama” de la licencia de IPFilter se resolvi´ o con un nuevo firewall y con fiabilidad de la licencias en el sistema base! 30 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  31. 31.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 31 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  32. 32.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Origen de PF En paralelo al problema con la licencia de ipfilter (2001), Daniel Hartmeier inici´ o un proyecto de filtrado de paquetes. En junio de 2001 ya ten´ ıa un prototipo (24 de junio, primer commit). Durante varias semanas, OpenBSD-current no dispuso de software para firewall. 1 de diciembre: primera versi´ on de PF (OpenBSD 3.0) Inicialmente era casi un clon de ipf. La compatibilidad con ipfilter dej´ o de ser una prioridad una vez que los usuarios de OpenBSD hab´ ıan migrado. Hoy no debe asumirse compatibilidad con ipfilter (requiere trabajo de conversi´ on). 32 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  33. 33.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Origen de PF PF fue escrito desde cero por desarrolladores expertos en seguridad. Paper de Harmeier en USENIX con comparativas de rendimiento (2002). PF 3.1 se comportaba igual o mejor bajo estr´ es que IPFilter, ambos en OpenBSD. Tambi´ en superaba a iptables de Linux. 33 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  34. 34.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Adopci´ on de PF Despert´ o la curiosidad de otros BSD y Unix. FreeBSD lo adopt´ o gradualmente: primero como paquete y luego (>5.3) en sus sistema base junto a ipfilter. Tambi´ en fue incorporado por NetBSD y DragonFly BSD. pfSense: distro de FreeBSD con PF, y con una GUI muy sofisticada que permite gestionar los conjuntos de reglas gr´ aficamente. 34 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  35. 35.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF GUIs: pfSense 35 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  36. 36.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Adopci´ on de PF: ¿Y Linux? Intentos de portarlo sin ´ exito. Desarrollo profundamente integrado con la pila de red de OpenBSD. Exigir´ ıa reescribir grandes partes de PF. Otros BSD conservan un origen com´ un con OpenBSD, lo que permiti´ o portarlo. ¡Hay software libre m´ as all´ a de Linux! 36 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  37. 37.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 37 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  38. 38.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF Funcionalidades de PF Network Address Translation (NAT) Gesti´ on de ancho de banda (QoS), priorizaci´ on de colas (v´ ıa ALTQ) Balanceo de carga ftp-proxy Logging y estad´ ısticas pfsync y CARP para Alta Disponibilidad 38 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  39. 39.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Conjuntos de reglas con PF 39 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  40. 40.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Tabla de contenidos 1 Cortafuegos y filtrado de paquetes TCP/IP ¿Qu´ e es un cortafuegos? Dise˜ nos de cortafuegos Procesado y filtrado de paquetes 2 Diez a˜ nos de Packet Filter (PF) ¿Qu´ e es PF? Antes de PF Origen y adopci´ on de PF Funcionalidades de PF 3 Conjuntos de reglas con PF Conjuntos de reglas (rulesets) 40 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  41. 41.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Un conjunto m´ ınimo de reglas Un conjunto m´ ınimo de reglas block in all pass out all keep state En OpenBSD 4.1 y superiores: keep state por defecto (se deja por legibilidad) Cargar las reglas $ sudo pfctl -ef /etc/pf.conf 41 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  42. 42.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Macros Se pueden definir variables (macros) para que las reglas sean m´ as legibles y manejables: Ejemplos de Macros webserver = 192.0.2.12 webport = 80 Macros dentro de una regla pass in proto tcp from any to $webserver port $webport 42 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  43. 43.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Listas Las listas son dos o m´ as objetos del mismo tipo agrupables en una regla: Ejemplo de Lista pass proto tcp to port { 22 80 443 } { 22 80 443 } es una lista. Macros y listas pueden combinarse web servers=‘‘{ 192.0.2.12,192.0.2.13,192.0.2.14 }’’ web ports=‘‘{ 80 443 }’’ 43 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  44. 44.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Tablas Las tablas (entre < >) sirven para agrupar direcciones IPv4 o IPv6: Ejemplo de Tabla table <goodguys> 192.0.2.0/24, !192.0.2.5 table <spammers> persist file ‘‘/etc/spammers’’ pass in on fxp0 from <goodguys> to any block in on fxp0 from <spammers> to any 44 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  45. 45.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Traducci´ on de Direcciones de Red (NAT) Permite mapear redes enteras Necesario cuando tenemos IPs p´ ublicas limitadas por ISP Nos permite aprovechar las direcciones RFC 1918 (rangos privados): 10.0.0.0/8 (10.0.0.0 - 10.255.255.255) 172.16.0.0/12 (172.16.0.0 - 172.31.255.255) 192.168.0.0/16 (192.168.0.0 - 192.168.255.255) Ejemplo de NAT pass out on em0 from 192.168.1.0/24 to any nat-to 24.5.0.5 Hace NAT en la interfaz em0 para cualquier paquete que venga de 192.168.1.0/24, y sustituye la direcci´ on IP de origen con 24.5.0.5. 45 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  46. 46.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Redireccionamiento de tr´ afico Permite acceder desde el exterior a servicios de la red interna. Ejemplo de redireccionamiento pass in on em0 proto tcp from any to any port 80 \ rdr-to 192.168.1.10 Se redirecciona el tr´ afico TCP del puerto 80 (un servidor web) a una m´ aquina dentro de la red interna (192.168.1.10). El redireccionamiento tiene implicaciones de seguridad. El sistema expuesto al exterior se suele aislar en una DMZ. 46 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  47. 47.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Antispoofing Previene la falsificaci´ on de la direcci´ on IP de origen (con el prop´ osito de esconder la direcci´ on real o de suplantar otro nodo en la red): Filtrado de paquetes falsificados por interfaz antispoof for em0 47 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  48. 48.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Balanceo de carga Tipos de balanceo de carga mediante reserva de IPs (address pooling): round-robin: rotaci´ on secuencial. Modo por defecto. random: env´ ıa cada conexi´ on a una IP aleatoria. source-hash: usa un hash de la IP para asignar una conexi´ on del pool de IPs. bitmask: un modo de hacer NAT entre dos bloques de direcciones IPs de igual tama˜ no. Ejemplo de balanceo de carga entrante web servers = ‘‘{ 10.0.0.10, 10.0.0.11, 10.0.0.13 }’’ match in on $ext if proto tcp to port 80 rdr-to \ $web servers round-robin 48 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  49. 49.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Comandos b´ asicos Control de PF con pfctl pfctl -e #activa PF pfctl -f /etc/pf.conf #carga las reglas pfctl -nf /etc/pf.conf #chequea sintaxis de las reglas sin cargarlas pfctl -vf /etc/pf.conf #modo verboso, vemos expansi´ on de reglas pfctl -s rules #ver reglas actuales pfctl -s all #ver todos los par´ ametros pfctl -d #desactiva PF sysctl net.inet.ip.forwarding=1 #Gateway. En /etc/sysctl.conf 49 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  50. 50.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) /etc/pf.conf Todo se configura y controla desde /etc/pf.conf. Este debe ser el orden de procesamiento de las reglas: Macros Tablas Opciones Normalizaci´ on de tr´ afico (scrubbing) Gesti´ on de ancho de banda Traducci´ on (NAT) Redirecci´ on Filtrado de paquetes 50 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  51. 51.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Registros de bit´ acora Demonio pflogd, por defecto /var/log/pflog. Logs en formato binario, legibles por tcpdump -r. Activar log de estad´ ısticas en iface externa set loginterface em0 Leer los logs $ sudo tcpdump -n -ttt -r /var/log/pflog $ sudo tcpdump -nettti pflog0 # tr´ afico en vivo 51 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  52. 52.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Un ejemplo completo de conjunto de reglas # Macros y listas pueden combinarse int if=‘‘em1’’ tcp services=‘‘{ 22, 113 }’’ udp services=‘‘{ domain }’’ icmp types=‘‘echoreq’’ # Opciones set block-policy return set loginterface em0 set skip on lo # NAT match out on egress inet from !(egress) to any nat-to (egress:0) # Filtrado - lo primero bloqueamos trafico en todas direcciones block in log pass out quick antispoof quick for { lo $int if } #Antispoofing # Permitimos paso a protocolos y puertos autorizados pass in on egress inet proto tcp from any to port $tcp services pass proto udp to port $udp services pass in inet proto icmp all icmp-type $icmp types #ping pass in on $int if # confiamos en tr´ afico de interfaz interno 52 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  53. 53.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Referencias Peter N.M. Hansteen, The Book of PF, 2nd Edition, No Starch, 2011. Daniel Hartmeier, “Design and Performance of the OpenBSD Stateful Packet Filter (pf)” (Usenix paper, 2002) http://www.benzedrine.cx/pf-paper.html 53 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF
  54. 54.

    Cortafuegos y filtrado de paquetes TCP/IP Diez a˜ nos de

    Packet Filter (PF) Conjuntos de reglas con PF Conjuntos de reglas (rulesets) Cortafuegos con software libre. Diez a˜ nos de PF Master oficial en Software Libre Miguel Vidal http://gsyc.urjc.es/~mvidal Twitter: @mvidallopez 17 de noviembre de 2011 54 / 54 Miguel Vidal Cortafuegos con software libre. Diez a˜ nos de PF