blob: 8759f5401e8ea16831cd073e80e56661a60ae59b [file] [log] [blame]
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07001#!/bin/sh
2
3IFNAME=$1
4CMD=$2
5
6kill_daemon() {
7 NAME=$1
8 PF=$2
9
10 if [ ! -r $PF ]; then
11 return
12 fi
13
14 PID=`cat $PF`
15 if [ $PID -gt 0 ]; then
16 if ps $PID | grep -q $NAME; then
17 kill $PID
18 fi
19 fi
20 rm $PF
21}
22
23if [ "$CMD" = "P2P-GROUP-STARTED" ]; then
24 GIFNAME=$3
25 if [ "$4" = "GO" ]; then
26 kill_daemon dhclient /var/run/dhclient-$GIFNAME.pid
27 rm /var/run/dhclient.leases-$GIFNAME
28 kill_daemon dnsmasq /var/run/dnsmasq.pid-$GIFNAME
29 ifconfig $GIFNAME 192.168.42.1 up
30 if ! dnsmasq -x /var/run/dnsmasq.pid-$GIFNAME \
31 -i $GIFNAME \
32 -F192.168.42.11,192.168.42.99; then
33 # another dnsmasq instance may be running and blocking us; try to
34 # start with -z to avoid that
35 dnsmasq -x /var/run/dnsmasq.pid-$GIFNAME \
36 -i $GIFNAME \
37 -F192.168.42.11,192.168.42.99 --listen-address 192.168.42.1 -z
38 fi
39 fi
40 if [ "$4" = "client" ]; then
41 kill_daemon dhclient /var/run/dhclient-$GIFNAME.pid
42 rm /var/run/dhclient.leases-$GIFNAME
43 kill_daemon dnsmasq /var/run/dnsmasq.pid-$GIFNAME
44 dhclient -pf /var/run/dhclient-$GIFNAME.pid \
45 -lf /var/run/dhclient.leases-$GIFNAME \
46 -nw \
47 $GIFNAME
48 fi
49fi
50
51if [ "$CMD" = "P2P-GROUP-REMOVED" ]; then
52 GIFNAME=$3
53 if [ "$4" = "GO" ]; then
54 kill_daemon dnsmasq /var/run/dnsmasq.pid-$GIFNAME
55 ifconfig $GIFNAME 0.0.0.0
56 fi
57 if [ "$4" = "client" ]; then
58 kill_daemon dhclient /var/run/dhclient-$GIFNAME.pid
59 rm /var/run/dhclient.leases-$GIFNAME
60 ifconfig $GIFNAME 0.0.0.0
61 fi
62fi
63
64if [ "$CMD" = "P2P-CROSS-CONNECT-ENABLE" ]; then
65 GIFNAME=$3
66 UPLINK=$4
67 # enable NAT/masquarade $GIFNAME -> $UPLINK
68 iptables -P FORWARD DROP
69 iptables -t nat -A POSTROUTING -o $UPLINK -j MASQUERADE
70 iptables -A FORWARD -i $UPLINK -o $GIFNAME -m state --state RELATED,ESTABLISHED -j ACCEPT
71 iptables -A FORWARD -i $GIFNAME -o $UPLINK -j ACCEPT
72 sysctl net.ipv4.ip_forward=1
73fi
74
75if [ "$CMD" = "P2P-CROSS-CONNECT-DISABLE" ]; then
76 GIFNAME=$3
77 UPLINK=$4
78 # disable NAT/masquarade $GIFNAME -> $UPLINK
79 sysctl net.ipv4.ip_forward=0
80 iptables -t nat -D POSTROUTING -o $UPLINK -j MASQUERADE
81 iptables -D FORWARD -i $UPLINK -o $GIFNAME -m state --state RELATED,ESTABLISHED -j ACCEPT
82 iptables -D FORWARD -i $GIFNAME -o $UPLINK -j ACCEPT
83fi