Subversion Repositories ALCASAR

Rev

Rev 40 | Rev 321 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log

Rev 40 Rev 64
1
#!/bin/sh
1
#!/bin/sh
-
 
2
# $Id: alcasar-iptables-bypass.sh 64 2010-04-08 20:01:24Z franck $
-
 
3
 
2
# script d'initialisation des regles du parefeu en mode ByPass
4
# script d'initialisation des regles du parefeu en mode ByPass
3
# Rexy - 3abtux
5
# Rexy - 3abtux
4
# version 1.8 - 12/2009
6
# version 1.8 - 12/2009
5
# changelog :
7
# changelog :
6
# 	+ prise en compte optionnelle d'un fichier iptables 'personnel' permettant de bloquer certains flux/services
8
# 	+ prise en compte optionnelle d'un fichier iptables 'personnel' permettant de bloquer certains flux/services
7
#	+ suppression log vers syslog
9
#	+ suppression log vers syslog
8
#	+ suppression du broadcast et du multicast sur les interfaces
10
#	+ suppression du broadcast et du multicast sur les interfaces
9
 
11
 
10
IPTABLES="/sbin/iptables"
12
IPTABLES="/sbin/iptables"
11
 
13
 
12
EXTIF="eth0"
14
EXTIF="eth0"
13
INTIF="eth1"
15
INTIF="eth1"
14
PRIVATE_NETWORK_MASK="192.168.182.0/24"
16
PRIVATE_NETWORK_MASK="192.168.182.0/24"
15
 
17
 
16
# On vide (flush) toutes les règles existantes
18
# On vide (flush) toutes les règles existantes
17
$IPTABLES -F
19
$IPTABLES -F
18
$IPTABLES -t nat -F
20
$IPTABLES -t nat -F
19
$IPTABLES -F INPUT
21
$IPTABLES -F INPUT
20
$IPTABLES -F FORWARD
22
$IPTABLES -F FORWARD
21
$IPTABLES -F OUTPUT
23
$IPTABLES -F OUTPUT
22
 
24
 
23
# On indique les politiques par défaut
25
# On indique les politiques par défaut
24
$IPTABLES -P INPUT DROP
26
$IPTABLES -P INPUT DROP
25
$IPTABLES -P FORWARD DROP
27
$IPTABLES -P FORWARD DROP
26
$IPTABLES -P OUTPUT ACCEPT
28
$IPTABLES -P OUTPUT ACCEPT
27
$IPTABLES -t nat -P PREROUTING ACCEPT
29
$IPTABLES -t nat -P PREROUTING ACCEPT
28
$IPTABLES -t nat -P POSTROUTING ACCEPT
30
$IPTABLES -t nat -P POSTROUTING ACCEPT
29
$IPTABLES -t nat -P OUTPUT ACCEPT
31
$IPTABLES -t nat -P OUTPUT ACCEPT
30
 
32
 
31
# On efface toutes les chaînes qui ne sont pas par défaut dans les tables filter et nat
33
# On efface toutes les chaînes qui ne sont pas par défaut dans les tables filter et nat
32
$IPTABLES -X
34
$IPTABLES -X
33
$IPTABLES -t nat -X
35
$IPTABLES -t nat -X
34
 
36
 
35
# On autorise tout sur loopback
37
# On autorise tout sur loopback
36
$IPTABLES -A INPUT -i lo -j ACCEPT
38
$IPTABLES -A INPUT -i lo -j ACCEPT
37
 
39
 
38
# on autorise les requêtes dhcp
40
# on autorise les requêtes dhcp
39
$IPTABLES -A INPUT -i $INTIF -p udp -m udp --sport bootpc --dport bootps -j ACCEPT
41
$IPTABLES -A INPUT -i $INTIF -p udp -m udp --sport bootpc --dport bootps -j ACCEPT
40
 
42
 
41
# Règles d'antispoofing
43
# Règles d'antispoofing
42
$IPTABLES -A INPUT -i $INTIF ! -s $PRIVATE_NETWORK_MASK -j ULOG --ulog-prefix "RULE Antispoof1 -- DENY "
44
$IPTABLES -A INPUT -i $INTIF ! -s $PRIVATE_NETWORK_MASK -j ULOG --ulog-prefix "RULE Antispoof1 -- DENY "
43
$IPTABLES -A INPUT -i $INTIF ! -s $PRIVATE_NETWORK_MASK -j DROP
45
$IPTABLES -A INPUT -i $INTIF ! -s $PRIVATE_NETWORK_MASK -j DROP
44
$IPTABLES -A INPUT -i $EXTIF -s $PRIVATE_NETWORK_MASK -j ULOG --ulog-prefix "RULE Antispoof2 -- DENY "
46
$IPTABLES -A INPUT -i $EXTIF -s $PRIVATE_NETWORK_MASK -j ULOG --ulog-prefix "RULE Antispoof2 -- DENY "
45
$IPTABLES -A INPUT -i $EXTIF -s $PRIVATE_NETWORK_MASK -j DROP
47
$IPTABLES -A INPUT -i $EXTIF -s $PRIVATE_NETWORK_MASK -j DROP
46
 
48
 
47
# On drop le broadcast et le multicasat sur les interfaces (sans Log)
49
# On drop le broadcast et le multicasat sur les interfaces (sans Log)
48
$IPTABLES -A INPUT -m addrtype --dst-type BROADCAST,MULTICAST -j DROP
50
$IPTABLES -A INPUT -m addrtype --dst-type BROADCAST,MULTICAST -j DROP
49
 
51
 
50
# On autorise le ping dans les deux sens (icmp N°0 & 8) en provenance du LAN
52
# On autorise le ping dans les deux sens (icmp N°0 & 8) en provenance du LAN
51
$IPTABLES -A INPUT -i $INTIF -s $PRIVATE_NETWORK_MASK -p icmp --icmp-type 0 -j ACCEPT
53
$IPTABLES -A INPUT -i $INTIF -s $PRIVATE_NETWORK_MASK -p icmp --icmp-type 0 -j ACCEPT
52
$IPTABLES -A INPUT -i $INTIF -s $PRIVATE_NETWORK_MASK -p icmp --icmp-type 8 -j ACCEPT
54
$IPTABLES -A INPUT -i $INTIF -s $PRIVATE_NETWORK_MASK -p icmp --icmp-type 8 -j ACCEPT
53
 
55
 
54
# On autorise le tranfert des requête DNS (sans LOG)
56
# On autorise le tranfert des requête DNS (sans LOG)
55
$IPTABLES -A FORWARD -i $INTIF -p udp --dport  domain -j ACCEPT
57
$IPTABLES -A FORWARD -i $INTIF -p udp --dport  domain -j ACCEPT
56
 
58
 
57
# On autorise le flux dans les deux sens (avec Log sur les demandes de connexion).
59
# On autorise le flux dans les deux sens (avec Log sur les demandes de connexion).
58
$IPTABLES -A FORWARD -i $INTIF -m state --state NEW -j ULOG --ulog-prefix "RULE Transfert -- ACCEPT "
60
$IPTABLES -A FORWARD -i $INTIF -m state --state NEW -j ULOG --ulog-prefix "RULE Transfert -- ACCEPT "
59
$IPTABLES -A FORWARD -i $INTIF -m state --state NEW -j ACCEPT
61
$IPTABLES -A FORWARD -i $INTIF -m state --state NEW -j ACCEPT
60
$IPTABLES -A FORWARD -i $INTIF -m state --state RELATED,ESTABLISHED -j ACCEPT
62
$IPTABLES -A FORWARD -i $INTIF -m state --state RELATED,ESTABLISHED -j ACCEPT
61
$IPTABLES -A FORWARD -o $INTIF -m state --state RELATED,ESTABLISHED -j ACCEPT
63
$IPTABLES -A FORWARD -o $INTIF -m state --state RELATED,ESTABLISHED -j ACCEPT
62
 
64
 
63
# On autorise les flux entrant ntp et ssh via INTIF
65
# On autorise les flux entrant ntp et ssh via INTIF
64
$IPTABLES -A INPUT -i $INTIF -p udp --dport ntp -j ACCEPT
66
$IPTABLES -A INPUT -i $INTIF -p udp --dport ntp -j ACCEPT
65
$IPTABLES -A INPUT -i $INTIF -p tcp --dport ssh -j ACCEPT
67
$IPTABLES -A INPUT -i $INTIF -p tcp --dport ssh -j ACCEPT
66
 
68
 
67
# On autorise les flux entrant des connexions déjà établies (ping à partir du portail par exemple)
69
# On autorise les flux entrant des connexions déjà établies (ping à partir du portail par exemple)
68
$IPTABLES -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
70
$IPTABLES -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
69
 
71
 
70
# On interdit et on log le reste sur les 2 interfaces d'accès
72
# On interdit et on log le reste sur les 2 interfaces d'accès
71
$IPTABLES -A INPUT -i $INTIF -j ULOG --ulog-prefix "RULE rej-int -- REJECT "
73
$IPTABLES -A INPUT -i $INTIF -j ULOG --ulog-prefix "RULE rej-int -- REJECT "
72
$IPTABLES -A INPUT -i $EXTIF -j ULOG --ulog-prefix "RULE rej-ext -- REJECT "
74
$IPTABLES -A INPUT -i $EXTIF -j ULOG --ulog-prefix "RULE rej-ext -- REJECT "
73
$IPTABLES -A INPUT -p tcp -j REJECT --reject-with tcp-reset
75
$IPTABLES -A INPUT -p tcp -j REJECT --reject-with tcp-reset
74
$IPTABLES -A INPUT -p udp -j REJECT --reject-with icmp-port-unreachable
76
$IPTABLES -A INPUT -p udp -j REJECT --reject-with icmp-port-unreachable
75
 
77
 
76
# On active le masquage d'adresse par translation (NAT)
78
# On active le masquage d'adresse par translation (NAT)
77
$IPTABLES -A POSTROUTING -t nat -o $EXTIF -j MASQUERADE
79
$IPTABLES -A POSTROUTING -t nat -o $EXTIF -j MASQUERADE
78
 
80
 
79
/etc/init.d/iptables save
81
/etc/init.d/iptables save
80
# Fin du script des regles du parefeu
82
# Fin du script des regles du parefeu
81
 
83
 
82
 
84
 
83

Generated by GNU Enscript 1.6.6.
85

Generated by GNU Enscript 1.6.6.
84
 
86
 
85
 
87
 
86
 
88