Advertisement
kheeper

iptables_server_script

Feb 6th, 2012
104
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Bash 3.44 KB | None | 0 0
  1. #!/bin/bash
  2.  
  3. IPT="/sbin/iptables"
  4. SPAMLIST="blockedip"
  5. SPAMDROPMSG="BLOCKED IP DROP"
  6.  
  7. echo "Starting IPv4 Wall..."
  8. $IPT -F
  9. $IPT -X
  10. $IPT -t nat -F
  11. $IPT -t nat -X
  12. $IPT -t mangle -F
  13. $IPT -t mangle -X
  14. modprobe ip_conntrack
  15.  
  16. [ -f /root/scripts/blocked.ips.txt ] && BADIPS=$(egrep -v -E "^#|^$" /root/scripts/blocked.ips.txt)
  17.  
  18. PUB_IF="venet0:0"
  19.  
  20. #unlimited
  21. $IPT -A INPUT -i lo -j ACCEPT
  22. $IPT -A OUTPUT -o lo -j ACCEPT
  23.  
  24. # DROP all incomming traffic
  25. $IPT -P INPUT DROP
  26. $IPT -P OUTPUT DROP
  27. $IPT -P FORWARD DROP
  28.  
  29. if [ -f /root/scripts/blocked.ips.txt ];
  30. then
  31. # create a new iptables list
  32. $IPT -N $SPAMLIST
  33.  
  34. for ipblock in $BADIPS
  35. do
  36.    $IPT -A $SPAMLIST -s $ipblock -j LOG --log-prefix "$SPAMDROPMSG"
  37.    $IPT -A $SPAMLIST -s $ipblock -j DROP
  38. done
  39. $IPT -I INPUT -j $SPAMLIST
  40. $IPT -I OUTPUT -j $SPAMLIST
  41. $IPT -I FORWARD -j $SPAMLIST
  42. fi
  43.  
  44. # Block sync
  45. $IPT -A INPUT -i ${PUB_IF} -p tcp ! --syn -m state --state NEW  -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Drop Sync"
  46. $IPT -A INPUT -i ${PUB_IF} -p tcp ! --syn -m state --state NEW -j DROP
  47.  
  48. # Block Fragments
  49. $IPT -A INPUT -i ${PUB_IF} -f  -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Fragments Packets"
  50. $IPT -A INPUT -i ${PUB_IF} -f -j DROP
  51.  
  52. # Block bad stuff
  53. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL FIN,URG,PSH -j DROP
  54. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL ALL -j DROP
  55.  
  56. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL NONE -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "NULL Packets"
  57. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL NONE -j DROP # NULL packets
  58.  
  59. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,RST SYN,RST -j DROP
  60.  
  61. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,FIN SYN,FIN -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "XMAS Packets"
  62. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags SYN,FIN SYN,FIN -j DROP #XMAS
  63.  
  64. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags FIN,ACK FIN -m limit --limit 5/m --limit-burst 7 -j LOG --log-level 4 --log-prefix "Fin Packets Scan"
  65. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags FIN,ACK FIN -j DROP # FIN packet scans
  66.  
  67. $IPT  -A INPUT -i ${PUB_IF} -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  68.  
  69. # Allow full outgoing connection but no incomming stuff
  70. $IPT -A INPUT -i eth0 -m state --state ESTABLISHED,RELATED -j ACCEPT
  71. $IPT -A OUTPUT -o eth0 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  72.  
  73. # Allow ssh
  74. $IPT -A INPUT -p tcp --destination-port 2222 -j ACCEPT
  75.  
  76. # allow incomming ICMP ping pong stuff
  77. $IPT -A INPUT -p icmp --icmp-type 8 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  78. $IPT -A OUTPUT -p icmp --icmp-type 0 -m state --state ESTABLISHED,RELATED -j ACCEPT
  79.  
  80. # Allow port 53 tcp/udp (DNS Server)
  81. $IPT -A INPUT -p udp --dport 53 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
  82. $IPT -A OUTPUT -p udp --sport 53 -m state --state ESTABLISHED,RELATED -j ACCEPT
  83.  
  84. $IPT -A INPUT -p tcp --destination-port 53 -m state --state NEW,ESTABLISHED,RELATED  -j ACCEPT
  85. $IPT -A OUTPUT -p tcp --sport 53 -m state --state ESTABLISHED,RELATED -j ACCEPT
  86.  
  87. # Open port 80
  88. $IPT -A INPUT -p tcp --destination-port 80 -j ACCEPT
  89.  
  90. # Do not log smb/windows sharing packets - too much logging
  91. $IPT -A INPUT -p tcp -i eth0 --dport 137:139 -j REJECT
  92. $IPT -A INPUT -p udp -i eth0 --dport 137:139 -j REJECT
  93.  
  94. # log everything else and drop
  95. $IPT -A INPUT -j LOG
  96. $IPT -A FORWARD -j LOG
  97. $IPT -A INPUT -j DROP
  98.  
  99. exit 0
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement