Fix IPv6 SLAAC

This commit is contained in:
Daniel Winzen
2021-05-23 15:17:26 +02:00
parent 4d6ec598a4
commit 4ebebf6be5

View File

@ -29,12 +29,7 @@ ip6tables -t nat -A OUTPUT -m owner --uid-owner $tor -j RETURN;
iptables -A OUTPUT -m owner --uid-owner $tor -j ACCEPT; iptables -A OUTPUT -m owner --uid-owner $tor -j ACCEPT;
ip6tables -A OUTPUT -m owner --uid-owner $tor -j ACCEPT; ip6tables -A OUTPUT -m owner --uid-owner $tor -j ACCEPT;
)done )done
#allow querriying ntp servers (must mach /etc/systemd/timesyncd.conf #restrict local communication for hosting users
for clearnet in 88.191.68.178 51.15.142.60 51.255.197.148 91.121.181.58; do(
iptables -t nat -A OUTPUT -p udp --dport 123 -d $clearnet -j RETURN;
iptables -A OUTPUT -p udp --dport 123 -d $clearnet -j ACCEPT
)done
#restrict local communication for php and webserver
#allowed tcp ports #allowed tcp ports
for port in 3306 9040 9050 110 143 25 22 53; do( for port in 3306 9040 9050 110 143 25 22 53; do(
iptables -A OUTPUT -d 127.0.0.0/8 -p tcp --dport $port -m owner --gid-owner www-data -j ACCEPT; iptables -A OUTPUT -d 127.0.0.0/8 -p tcp --dport $port -m owner --gid-owner www-data -j ACCEPT;
@ -43,9 +38,24 @@ ip6tables -A OUTPUT -d ::1 -p tcp --dport $port -m owner --gid-owner www-data -j
#accept DNS #accept DNS
iptables -A OUTPUT -d 127.0.0.0/8 -p udp --dport 53 -m owner --gid-owner www-data -j ACCEPT iptables -A OUTPUT -d 127.0.0.0/8 -p udp --dport 53 -m owner --gid-owner www-data -j ACCEPT
ip6tables -A OUTPUT -d ::1 -p udp --dport 53 -m owner --gid-owner www-data -j ACCEPT ip6tables -A OUTPUT -d ::1 -p udp --dport 53 -m owner --gid-owner www-data -j ACCEPT
#REJECT all others #reject all other local communication
iptables -A OUTPUT -d 127.0.0.0/8 -m owner --gid-owner www-data -j REJECT iptables -A OUTPUT -d 127.0.0.0/8 -m owner --gid-owner www-data -j REJECT
ip6tables -A OUTPUT -d ::1 -m owner --gid-owner www-data -j REJECT ip6tables -A OUTPUT -d ::1 -m owner --gid-owner www-data -j REJECT
#redirect all outgoing DNS querries to our dns server
iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
ip6tables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
#redirect all other TCP traffic through tor
iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports 9040
ip6tables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports 9040
#reject all other hosting user traffic
iptables -A OUTPUT -m owner --gid-owner www-data -j REJECT
ip6tables -A OUTPUT -m owner --gid-owner www-data -j REJECT
#allow local communication
iptables -A OUTPUT -o lo -j ACCEPT
ip6tables -A OUTPUT -o lo -j ACCEPT
iptables -A INPUT -i lo -j ACCEPT
ip6tables -A INPUT -i lo -j ACCEPT
#unrestricted access to these IPs #unrestricted access to these IPs
for clearnet in 127.0.0.0/8; do( for clearnet in 127.0.0.0/8; do(
iptables -t nat -A OUTPUT -d $clearnet -j RETURN; iptables -t nat -A OUTPUT -d $clearnet -j RETURN;
@ -55,17 +65,14 @@ for clearnet in ::1; do(
ip6tables -t nat -A OUTPUT -d $clearnet -j RETURN; ip6tables -t nat -A OUTPUT -d $clearnet -j RETURN;
ip6tables -A OUTPUT -d $clearnet -j ACCEPT; ip6tables -A OUTPUT -d $clearnet -j ACCEPT;
) done ) done
#redirect all outgoing DNS querries to our tor #accet IPv6 ICMP packages required for SLAAC
iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53 ip6tables -A INPUT -p ipv6-icmp -j ACCEPT
ip6tables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53 ip6tables -A OUTPUT -p ipv6-icmp -j ACCEPT
#redirect everything else #allow querriying ntp servers (must mach /etc/systemd/timesyncd.conf
iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports 9040 for clearnet in 88.191.68.178 51.15.142.60 51.255.197.148 91.121.181.58; do(
ip6tables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports 9040 iptables -t nat -A OUTPUT -p udp --dport 123 -d $clearnet -j RETURN;
#allow local communication iptables -A OUTPUT -p udp --dport 123 -d $clearnet -j ACCEPT
iptables -A OUTPUT -o lo -j ACCEPT )done
ip6tables -A OUTPUT -o lo -j ACCEPT
iptables -A INPUT -i lo -j ACCEPT
ip6tables -A INPUT -i lo -j ACCEPT
#reject everything else #reject everything else
iptables -A OUTPUT -j REJECT iptables -A OUTPUT -j REJECT
ip6tables -A OUTPUT -j REJECT ip6tables -A OUTPUT -j REJECT