X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/611b7465e12dd869b9635b241c8d65165860ad89..f7628dac50cd43cd44bb4f7e5c343fe990b5af3f:/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 4a16fb098..7273cff5e 100644 --- a/cookbooks/networking/templates/default/nftables.conf.erb +++ b/cookbooks/networking/templates/default/nftables.conf.erb @@ -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 -%> } @@ -47,15 +47,13 @@ table inet chef-filter { } <% node[:networking][:firewall][:sets].each do |set| -%> - set <%= set %> { -<% if set.end_with?("-ip") -%> - type ipv4_addr -<% elsif set.end_with?("-ip6") -%> - type ipv6_addr + set <%= set[:name] %> { + type <%= set[:type] %> +<% if set[:flags] -%> + flags <%= set[:flags].join(", ") %> <% end -%> - flags dynamic -<% unless set.start_with?("connlimit-") -%> - timeout 120s +<% if set[:timeout] -%> + timeout <%= set[:timeout] %>s <% end -%> } @@ -166,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 -%> }