]> git.openstreetmap.org Git - chef.git/commitdiff
Expire rate limit sets
authorTom Hughes <tom@compton.nu>
Sun, 5 Mar 2023 20:33:41 +0000 (20:33 +0000)
committerTom Hughes <tom@compton.nu>
Sun, 5 Mar 2023 20:33:41 +0000 (20:33 +0000)
cookbooks/networking/resources/firewall_rule.rb
cookbooks/networking/templates/default/nftables.conf.erb

index 218a6b5f482a7de4bf3f2ca851067e6702cfaf4a..75d73dc11ebb8dc217004a0a75e8194940057246 100644 (file)
@@ -148,7 +148,7 @@ action_class do
 
       node.default[:networking][:firewall][:sets] << set
 
 
       node.default[:networking][:firewall][:sets] << set
 
-      rule << "add @#{set} { #{ip} saddr limit rate #{rate}/second burst #{burst} packets }"
+      rule << "update @#{set} { #{ip} saddr limit rate #{rate}/second burst #{burst} packets }"
     end
 
     rule << case action
     end
 
     rule << case action
index 94c3835252fb84ac318374e92724a540c9dc2c20..325e7740a3c23c8e915a8fef8f899fc7e276fd39 100644 (file)
@@ -25,25 +25,23 @@ table inet filter {
   set ip-blacklist {
     type ipv4_addr
     flags dynamic
   set ip-blacklist {
     type ipv4_addr
     flags dynamic
-    size 0
   }
 
   set ip6-blacklist {
     type ipv6_addr
     flags dynamic
   }
 
   set ip6-blacklist {
     type ipv6_addr
     flags dynamic
-    size 0
   }
 
   set ratelimit-icmp-echo-ip {
     type ipv4_addr
     flags dynamic
   }
 
   set ratelimit-icmp-echo-ip {
     type ipv4_addr
     flags dynamic
-    size 0
+    timeout 120s
   }
 
   set ratelimit-icmp-echo-ip6 {
     type ipv6_addr
     flags dynamic
   }
 
   set ratelimit-icmp-echo-ip6 {
     type ipv6_addr
     flags dynamic
-    size 0
+    timeout 120s
   }
 
 <%- node[:networking][:firewall][:sets].each do |set| %>
   }
 
 <%- node[:networking][:firewall][:sets].each do |set| %>
@@ -54,7 +52,7 @@ table inet filter {
     type ipv6_addr
 <%- end %>
     flags dynamic
     type ipv6_addr
 <%- end %>
     flags dynamic
-    size 0
+    timeout 120s
   }
 
 <%- end %>
   }
 
 <%- end %>
@@ -82,11 +80,11 @@ table inet filter {
     ct state { established, related } accept
 
     icmp type { destination-unreachable } accept
     ct state { established, related } accept
 
     icmp type { destination-unreachable } accept
-    icmp type { echo-request } add @ratelimit-icmp-echo-ip { ip saddr limit rate 1/second } accept
+    icmp type { echo-request } update @ratelimit-icmp-echo-ip { ip saddr limit rate 1/second } accept
     icmp type { echo-request } drop
 
     icmpv6 type { nd-neighbor-solicit, nd-neighbor-advert, nd-router-solicit, nd-router-advert } accept
     icmp type { echo-request } drop
 
     icmpv6 type { nd-neighbor-solicit, nd-neighbor-advert, nd-router-solicit, nd-router-advert } accept
-    icmpv6 type { echo-request } add @ratelimit-icmp-echo-ip6 { ip6 saddr limit rate 1/second } accept
+    icmpv6 type { echo-request } update @ratelimit-icmp-echo-ip6 { ip6 saddr limit rate 1/second } accept
     icmpv6 type { echo-request } drop
 
     meta l4proto { icmp, icmpv6 } jump log-and-drop
     icmpv6 type { echo-request } drop
 
     meta l4proto { icmp, icmpv6 } jump log-and-drop