[10446] | 1 | #
|
---|
[10580] | 2 | # Wireless Leiden PF firewall configuration for (iLeiden) Proxy Setup.
|
---|
[10446] | 3 | #
|
---|
[10580] | 4 | # N.B: The features points are shared between all firewall configurations to
|
---|
| 5 | # make comparisions more easy to do
|
---|
| 6 | #
|
---|
[10446] | 7 | # 1) It supports outgoing NAT to specified ports. The so called iLeiden setup.
|
---|
| 8 | # 2) It supports incoming NAT from the private MGMT network, for maintenance use.
|
---|
| 9 | # 3) It protects the private MGMT network from WL requests to it's own services.
|
---|
| 10 | # 4) It portects the $ext_if by only allowing an subset of services.
|
---|
| 11 | # 5) The Wireless Leiden facing interfaces are not firewalled.
|
---|
[10448] | 12 | # 6) WL Captive Portal Support for interfaces who needs it.
|
---|
| 13 | # 7) Optional: Exposure of WL services to the outside
|
---|
[10579] | 14 | # 9) Protect the Wireless Network from junk traffic.
|
---|
[10580] | 15 | #
|
---|
| 16 | # Rick van der Zwet <rick@wirelessleiden.nl>
|
---|
| 17 | #
|
---|
[10446] | 18 |
|
---|
[13160] | 19 | # Standard port allow listings for external services
|
---|
[13233] | 20 | allow_ext_in_tcp="1022, openvpn"
|
---|
[13160] | 21 | allow_ext_in_udp="snmp, openvpn"
|
---|
[10448] | 22 |
|
---|
[13160] | 23 | # Standard port allow listings for services at host network (in case of NAT)
|
---|
| 24 | allow_private_in_tcp="domain"
|
---|
| 25 | allow_private_in_udp="domain"
|
---|
| 26 |
|
---|
[10951] | 27 | allow_ext_out_tcp = "domain, http, https, openvpn"
|
---|
| 28 | allow_ext_out_udp = "domain, ntp, openvpn"
|
---|
[10610] | 29 |
|
---|
[10862] | 30 |
|
---|
[10448] | 31 | # Default configuration for ALIX2 with vr0 as external interface and wlan0 as
|
---|
[13233] | 32 | # the public accesspoint in iLeiden setup, aliases on external interface OK.
|
---|
[11543] | 33 | ext_if="vr0"
|
---|
| 34 | ext_ip="(vr0:0)"
|
---|
| 35 | inet_if="vr0"
|
---|
| 36 | inet_ip="(vr0:0)"
|
---|
[10448] | 37 | captive_portal_interfaces="wlan0"
|
---|
| 38 | publicnat="http,https"
|
---|
[10520] | 39 | masterip="127.0.0.1"
|
---|
[10589] | 40 | # For an traditional proxy setup set (no iLeiden clients!), uncomment:
|
---|
[10448] | 41 | #publicnat=0
|
---|
| 42 |
|
---|
[10610] | 43 | # Global standards. NOT to be edited.
|
---|
| 44 | wl_net="172.16.0.0/12"
|
---|
[10842] | 45 | private="{ 10.0.0.0/8, 192.168.0.0/16 }"
|
---|
[10610] | 46 | ileiden_ports="http,https"
|
---|
| 47 |
|
---|
[10446] | 48 | # Always be nice, and return the fact we are blocking the packets
|
---|
| 49 | set block-policy return
|
---|
| 50 |
|
---|
[10448] | 51 | # Table used to authorized hosts (6)
|
---|
| 52 | table <wlportal> persist counters
|
---|
| 53 |
|
---|
[10446] | 54 | # NAT MGMT to Wireless Leiden (2)
|
---|
[10861] | 55 | nat on ! $ext_if from $private to $wl_net -> $masterip
|
---|
[10446] | 56 |
|
---|
| 57 | # Do NOT allow NAT to the Private Network (3)
|
---|
[10578] | 58 | no nat from $wl_net to $private
|
---|
[10446] | 59 |
|
---|
[13233] | 60 | # Nat the internet for iLeiden functionality allow for alias on vr0 (1)
|
---|
| 61 | nat on $inet_if inet proto tcp from $wl_net to ! $wl_net port { $publicnat } -> ($inet_ip)
|
---|
[10578] | 62 |
|
---|
[10448] | 63 |
|
---|
| 64 | # Redirect user to captive portal they have not clicked OK yet (6)
|
---|
[10610] | 65 | no rdr on { $captive_portal_interfaces } proto tcp from <wlportal> to !$wl_net port http
|
---|
| 66 | rdr on { $captive_portal_interfaces } proto tcp from $wl_net to !$wl_net port http -> 172.31.255.1 port 8081
|
---|
[10448] | 67 |
|
---|
[10704] | 68 | # Load autogenerated entries, like the remote mappings (7)
|
---|
| 69 | include "/etc/pf.hybrid.conf.local"
|
---|
[10694] | 70 |
|
---|
| 71 | # Make the device on WL find the proper gateway back (7)
|
---|
| 72 | nat on ! $ext_if inet from any to $wl_net tagged SRV -> $masterip
|
---|
| 73 |
|
---|
| 74 | # Special allow rules for inbound piercing (7)
|
---|
| 75 | pass in quick on $ext_if inet tagged SRV keep state
|
---|
| 76 |
|
---|
[10446] | 77 | # Localhost is considered safe (5)
|
---|
| 78 | pass quick on lo0 all
|
---|
| 79 |
|
---|
| 80 | # By default all interfaces are open (5)
|
---|
| 81 | pass all
|
---|
| 82 |
|
---|
[10579] | 83 | # By default deny all outgoing traffic to avoid systems spamming the network (9)
|
---|
| 84 | block out on { $captive_portal_interfaces } from any to !$wl_net
|
---|
| 85 |
|
---|
| 86 | # Note: not even HTTPS traffic allowed for those who has not clicked OK yet (6)
|
---|
[10610] | 87 | pass out on { $captive_portal_interfaces } proto tcp from <wlportal> to !$wl_net port { $publicnat } keep state
|
---|
[10579] | 88 |
|
---|
[10446] | 89 | # External interface is permissive (4)
|
---|
[10997] | 90 | block on $ext_if inet from any to !$wl_net
|
---|
[11543] | 91 | block on $inet_if inet from any to !$wl_net
|
---|
[10446] | 92 |
|
---|
[10842] | 93 | # Allow internal WL traffic on alias $ext_if interfaces (5)
|
---|
| 94 | pass in quick on $ext_if from $wl_net to $wl_net
|
---|
| 95 | pass out quick on $ext_if from $wl_net to $wl_net
|
---|
| 96 |
|
---|
[13160] | 97 | # Expose some local services for internal (NATted) network (4)
|
---|
| 98 | pass in on $ext_if inet proto tcp from $private to $ext_if port { $allow_private_in_tcp } keep state
|
---|
| 99 | pass in on $ext_if inet proto udp from $private to $ext_if port { $allow_private_in_udp } keep state
|
---|
| 100 | pass in on $ext_if inet proto icmp from $private to $ext_if icmp-type { echoreq }
|
---|
| 101 |
|
---|
| 102 | # Expose some local services for the external world (WWW) network (4)
|
---|
[10610] | 103 | pass in on $ext_if inet proto tcp from any to $ext_if port { $allow_ext_in_tcp } keep state
|
---|
| 104 | pass in on $ext_if inet proto udp from any to $ext_if port { $allow_ext_in_udp } keep state
|
---|
[10446] | 105 | pass in on $ext_if inet proto icmp from any to $ext_if icmp-type { echoreq }
|
---|
| 106 |
|
---|
| 107 | # Packets from the management LAN are allowed in (2)
|
---|
| 108 | pass in on $ext_if from $private to $wl_net keep state
|
---|
| 109 |
|
---|
| 110 | # Packets going out are the ones to the internet with an certain limit (1)
|
---|
[11543] | 111 | pass out on $inet_if inet proto tcp from $wl_net to any port { $publicnat } keep state \
|
---|
[10446] | 112 | (max-src-conn-rate 100/10, max-src-conn 10)
|
---|
| 113 |
|
---|
| 114 | # For proper functioning allow the local machine to initiate requests outside (4)
|
---|
[10610] | 115 | pass out on $ext_if inet proto udp from $ext_if to any port { $allow_ext_out_udp } keep state
|
---|
| 116 | pass out on $ext_if inet proto tcp from $ext_if to any port { $allow_ext_out_tcp } keep state
|
---|
[11543] | 117 | pass out on $ext_if inet proto icmp from $ext_if to any icmp-type { echoreq, trace }
|
---|
[10446] | 118 |
|
---|
[11543] | 119 | # For proper functioning allow the local machine to initiate requests outside + vpn (4)
|
---|
| 120 | pass out on $inet_if inet proto udp from $inet_if to any port { $allow_ext_out_udp } keep state
|
---|
| 121 | pass out on $inet_if inet proto tcp from $inet_if to any port { $allow_ext_out_tcp } keep state
|
---|
| 122 | pass out on $inet_if inet proto icmp from $inet_if to any icmp-type { echoreq, trace }
|
---|
| 123 |
|
---|
| 124 | # Uncomment to UDP traceroute from this host to start
|
---|
| 125 | #pass out on $ext_if inet proto udp from $ext_if to any port 33434 >< 33464 keep state
|
---|
| 126 | #pass out on $inet_if inet proto udp from $inet_if to any port 33434 >< 33464 keep state
|
---|
| 127 |
|
---|
[10446] | 128 | # Do not allow connections to the local MGNT LAN to start (3)
|
---|
| 129 | block out on $ext_if from any to $private
|
---|
| 130 |
|
---|
| 131 | # Limited acess PRIVATE network to allow DHCP/DNS to function (3)
|
---|
| 132 | pass out on $ext_if inet proto {udp, tcp} from $ext_if to $private port {domain} keep state
|
---|
| 133 |
|
---|
| 134 | # Uncomment to allow limited access to MGNT interfaces ON the private network (3)
|
---|
| 135 | #pass out on $ext_if inet proto tcp from $ext_if to $private port {ssh, http, https} keep state
|
---|
| 136 |
|
---|