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