blob: 08c840f6f8ba480137bcc032678912b19f6ec783 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
CONNTRACK=conntrack
SRC=1.1.1.1
DST=2.2.2.2
SPORT=2005
DPORT=21
case $1 in
dump)
echo "Dumping conntrack table"
$CONNTRACK -L
;;
flush)
echo "Flushing conntrack table"
$CONNTRACK -F
;;
new)
echo "creating a new conntrack"
$CONNTRACK -I --orig-src $SRC --orig-dst $DST \
--reply-src $DST --reply-dst $SRC -p tcp \
--orig-port-src $SPORT --orig-port-dst $DPORT \
--reply-port-src $DPORT --reply-port-dst $SPORT \
--state LISTEN -u SEEN_REPLY -t 50
;;
new-simple)
echo "creating a new conntrack (simplified)"
$CONNTRACK -I --orig-src $SRC --orig-dst $DST \
-p tcp --orig-port-src $SPORT --orig-port-dst $DPORT \
--state LISTEN -u SEEN_REPLY -t 50
;;
new-nat)
echo "creating a new conntrack (NAT)"
$CONNTRACK -I --orig-src $SRC --orig-dst $DST \
-p tcp --orig-port-src $SPORT --orig-port-dst $DPORT \
--state LISTEN -u SEEN_REPLY,SRC_NAT -t 50 -a 8.8.8.8
;;
get)
echo "getting a conntrack"
$CONNTRACK -G --orig-src $SRC --orig-dst $DST \
-p tcp --orig-port-src $SPORT --orig-port-dst $DPORT \
--reply-port-src $DPORT --reply-port-dst $SPORT
;;
change)
echo "change a conntrack"
$CONNTRACK -U --orig-src $SRC --orig-dst $DST \
--reply-src $DST --reply-dst $SRC -p tcp \
--orig-port-src $SPORT --orig-port-dst $DPORT \
--reply-port-src $DPORT --reply-port-dst $SPORT \
--state TIME_WAIT -u ASSURED,SEEN_REPLY -t 500
;;
delete)
$CONNTRACK -D --orig-src $SRC --orig-dst $DST \
-p tcp --orig-port-src $SPORT --orig-port-dst $DPORT
;;
output)
proc=$(cat /proc/net/ip_conntrack | wc -l)
netl=$($CONNTRACK -L | wc -l)
count=$(cat /proc/sys/net/ipv4/netfilter/ip_conntrack_count)
if [ $proc -ne $netl ]; then
echo "proc is $proc and netl is $netl and count is $count"
else
if [ $proc -ne $count ]; then
echo "proc is $proc and netl is $netl and count is $count"
else
echo "now $proc"
fi
fi
;;
dump-expect)
$CONNTRACK -L expect
;;
flush-expect)
$CONNTRACK -F expect
;;
create-expect)
# requires modprobe ip_conntrack_ftp
$CONNTRACK -I expect --orig-src $SRC --orig-dst $DST \
--exp-src 4.4.4.4 --exp-dst 5.5.5.5 \
--mask-src 255.255.255.0 --mask-dst 255.255.255.255 \
-p tcp --orig-port-src $SPORT --orig-port-dst $DPORT \
-t 200 --mask-port-src 10 --mask-port-dst 300
;;
get-expect)
$CONNTRACK -G expect --orig-src 4.4.4.4 --orig-dst 5.5.5.5 \
--p tcp --orig-port-src 0 --orig-port-dst 0 \
--mask-port-src 10 --mask-port-dst 11
;;
delete-expect)
$CONNTRACK -D expect --orig-src 4.4.4.4 \
--orig-dst 5.5.5.5 -p tcp --orig-port-src 0 \
--orig-port-dst 0 --mask-port-src 10 --mask-port-dst 11
;;
*)
echo "Usage: $0 [dump"
echo " |new"
echo " |new-simple"
echo " |new-nat"
echo " |get"
echo " |change"
echo " |delete"
echo " |output"
echo " |flush"
echo " |dump-expect"
echo " |flush-expect"
echo " |create-expect"
echo " |get-expect"
echo " |delete-expect]"
;;
esac
|