X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/89142473eefb6cc4409dbbd0da6f004b38e8dd8f..50aea11082eaa90bd37593b9c987d38a082f4e1b:/cookbooks/networking/templates/default/nftables.conf.erb diff --git a/cookbooks/networking/templates/default/nftables.conf.erb b/cookbooks/networking/templates/default/nftables.conf.erb index 74d104fad..1ef38da7f 100644 --- a/cookbooks/networking/templates/default/nftables.conf.erb +++ b/cookbooks/networking/templates/default/nftables.conf.erb @@ -3,8 +3,8 @@ <% unless @interfaces.empty? -%> define external-interfaces = { <%= @interfaces.sort.uniq.join(", ") %> } <% end -%> - -define ip-private-addresses = { 0.0.0.0, 10.0.0.0/8, 127.0.0.0/8, 169.254.0.0/16, 172.16.0.0/12, 192.0.2.0/24, 192.168.0.0/16 } +# Exclude 169.254.169.0/24 from ip-private-addresses as is widely by cloud providers. +define ip-private-addresses = { 0.0.0.0, 10.0.0.0/8, 127.0.0.0/8, 169.254.0.0-169.254.168.255, 169.254.170.0-169.254.255.255, 172.16.0.0/12, 192.0.2.0/24, 192.168.0.0/16 } define ip-multicast-addresses = { 224.0.0.0/4 } define ip6-private-addresses = { 2001:db8::/32, fc00::/7 } define ip6-multicast-addresses = { ff00::/8 } @@ -12,15 +12,15 @@ define ip6-multicast-addresses = { ff00::/8 } table inet chef-filter { set ip-osm-addresses { type ipv4_addr -<% unless Array(@hosts["inet"]).empty? -%> - elements = { <%= Array(@hosts["inet"]).sort.join(", ") %> } +<% unless Array(@hosts[:inet]).empty? -%> + elements = { <%= Array(@hosts[:inet]).sort.join(", ") %> } <% end -%> } set ip6-osm-addresses { type ipv6_addr -<% unless Array(@hosts["inet"]).empty? -%> - elements = { <%= Array(@hosts["inet6"]).sort.join(", ") %> } +<% unless Array(@hosts[:inet6]).empty? -%> + elements = { <%= Array(@hosts[:inet6]).sort.join(", ") %> } <% end -%> } @@ -66,12 +66,12 @@ table inet chef-filter { <% end -%> chain log-and-drop { - limit rate 1/second log + limit rate 1/second log level notice drop } chain log-and-reject { - limit rate 1/second log + limit rate 1/second log level notice reject } @@ -164,9 +164,9 @@ table ip chef-nat { chain postrouting { type nat hook postrouting priority srcnat; -<% node.interfaces(:role => :external, :family => :inet).each do |external| -%> -<% node.interfaces(:role => :internal, :family => :inet).each do |internal| -%> - oifname { <%= external[:interface] %> } ip saddr { <%= internal[:network] %>/<%= internal[:prefix] %> } snat <%= external[:address] %> +<% node.interfaces(:role => :external).each do |external| -%> +<% node.ipaddresses(:role => :internal, :family => :inet).each do |internal| -%> + oifname { <%= external[:interface] %> } ip saddr { <%= internal.subnet %> } snat <%= external[:inet][:address] %> <% end -%> <% end -%> }