瀏覽代碼

[Web] add manage f2b external option

FreddleSpl0it 2 年之前
父節點
當前提交
1537fb39c0
共有 1 個文件被更改,包括 28 次插入42 次删除
  1. 28 42
      data/Dockerfiles/netfilter/server.py

+ 28 - 42
data/Dockerfiles/netfilter/server.py

@@ -258,49 +258,35 @@ def permBan(net, unban=False):
   global f2boptions
   global lock
   if type(ipaddress.ip_network(net, strict=False)) is ipaddress.IPv4Network:
-    if int(f2boptions['manage_external']) != 1:
-      with lock:
-        chain = iptc.Chain(iptc.Table(iptc.Table.FILTER), 'MAILCOW')
-        rule = iptc.Rule()
-        rule.src = net
-        target = iptc.Target(rule, "REJECT")
-        rule.target = target
-        if rule not in chain.rules and not unban:
-          logCrit('Add host/network %s to blacklist' % net)
-          chain.insert_rule(rule)
-          r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
-        elif rule in chain.rules and unban:
-          logCrit('Remove host/network %s from blacklist' % net)
-          chain.delete_rule(rule)
-          r.hdel('F2B_PERM_BANS', '%s' % net)
-    elif not unban:
-      logCrit('Add host/network %s to blacklist' % net)
-      r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
-    elif unban:
-      logCrit('Remove host/network %s from blacklist' % net)
-      r.hdel('F2B_PERM_BANS', '%s' % net)
+    with lock:
+      chain = iptc.Chain(iptc.Table(iptc.Table.FILTER), 'MAILCOW')
+      rule = iptc.Rule()
+      rule.src = net
+      target = iptc.Target(rule, "REJECT")
+      rule.target = target
+      if rule not in chain.rules and not unban and int(f2boptions['manage_external']) != 1:
+        logCrit('Add host/network %s to blacklist' % net)
+        chain.insert_rule(rule)
+        r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
+      elif rule in chain.rules and unban:
+        logCrit('Remove host/network %s from blacklist' % net)
+        chain.delete_rule(rule)
+        r.hdel('F2B_PERM_BANS', '%s' % net)
   else:
-    if int(f2boptions['manage_external']) != 1:
-      with lock:
-        chain = iptc.Chain(iptc.Table6(iptc.Table6.FILTER), 'MAILCOW')
-        rule = iptc.Rule6()
-        rule.src = net
-        target = iptc.Target(rule, "REJECT")
-        rule.target = target
-        if rule not in chain.rules and not unban:
-          logCrit('Add host/network %s to blacklist' % net)
-          chain.insert_rule(rule)
-          r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
-        elif rule in chain.rules and unban:
-          logCrit('Remove host/network %s from blacklist' % net)
-          chain.delete_rule(rule)
-          r.hdel('F2B_PERM_BANS', '%s' % net)
-    elif not unban:
-      logCrit('Add host/network %s to blacklist' % net)
-      r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
-    elif unban:
-      logCrit('Remove host/network %s from blacklist' % net)
-      r.hdel('F2B_PERM_BANS', '%s' % net)
+    with lock:
+      chain = iptc.Chain(iptc.Table6(iptc.Table6.FILTER), 'MAILCOW')
+      rule = iptc.Rule6()
+      rule.src = net
+      target = iptc.Target(rule, "REJECT")
+      rule.target = target
+      if rule not in chain.rules and not unban and int(f2boptions['manage_external']) != 1:
+        logCrit('Add host/network %s to blacklist' % net)
+        chain.insert_rule(rule)
+        r.hset('F2B_PERM_BANS', '%s' % net, int(round(time.time())))
+      elif rule in chain.rules and unban:
+        logCrit('Remove host/network %s from blacklist' % net)
+        chain.delete_rule(rule)
+        r.hdel('F2B_PERM_BANS', '%s' % net)
 
 def quit(signum, frame):
   global quit_now