1 1.1.1.1.30.2 snj #!/bin/sh 2 1.1.1.1.30.2 snj 3 1.1.1.1.30.2 snj IFNAME=$1 4 1.1.1.1.30.2 snj CMD=$2 5 1.1.1.1.30.2 snj 6 1.1.1.1.30.2 snj kill_daemon() { 7 1.1.1.1.30.2 snj NAME=$1 8 1.1.1.1.30.2 snj PF=$2 9 1.1.1.1.30.2 snj 10 1.1.1.1.30.2 snj if [ ! -r $PF ]; then 11 1.1.1.1.30.2 snj return 12 1.1.1.1.30.2 snj fi 13 1.1.1.1.30.2 snj 14 1.1.1.1.30.2 snj PID=`cat $PF` 15 1.1.1.1.30.2 snj if [ $PID -gt 0 ]; then 16 1.1.1.1.30.2 snj if ps $PID | grep -q $NAME; then 17 1.1.1.1.30.2 snj kill $PID 18 1.1.1.1.30.2 snj fi 19 1.1.1.1.30.2 snj fi 20 1.1.1.1.30.2 snj rm $PF 21 1.1.1.1.30.2 snj } 22 1.1.1.1.30.2 snj 23 1.1.1.1.30.2 snj if [ "$CMD" = "P2P-GROUP-STARTED" ]; then 24 1.1.1.1.30.2 snj GIFNAME=$3 25 1.1.1.1.30.2 snj if [ "$4" = "GO" ]; then 26 1.1.1.1.30.2 snj kill_daemon udhcpc /var/run/udhcpc-$GIFNAME.pid 27 1.1.1.1.30.2 snj ifconfig $GIFNAME 192.168.42.1 up 28 1.1.1.1.30.2 snj udhcpd /etc/udhcpd-p2p.conf 29 1.1.1.1.30.2 snj fi 30 1.1.1.1.30.2 snj if [ "$4" = "client" ]; then 31 1.1.1.1.30.2 snj kill_daemon udhcpc /var/run/udhcpc-$GIFNAME.pid 32 1.1.1.1.30.2 snj kill_daemon udhcpd /var/run/udhcpd-$GIFNAME.pid 33 1.1.1.1.30.2 snj udhcpc -i $GIFNAME -p /var/run/udhcpc-$GIFNAME.pid \ 34 1.1.1.1.30.2 snj -s /etc/udhcpc.script 35 1.1.1.1.30.2 snj fi 36 1.1.1.1.30.2 snj fi 37 1.1.1.1.30.2 snj 38 1.1.1.1.30.2 snj if [ "$CMD" = "P2P-GROUP-REMOVED" ]; then 39 1.1.1.1.30.2 snj GIFNAME=$3 40 1.1.1.1.30.2 snj if [ "$4" = "GO" ]; then 41 1.1.1.1.30.2 snj kill_daemon udhcpd /var/run/udhcpd-$GIFNAME.pid 42 1.1.1.1.30.2 snj ifconfig $GIFNAME 0.0.0.0 43 1.1.1.1.30.2 snj fi 44 1.1.1.1.30.2 snj if [ "$4" = "client" ]; then 45 1.1.1.1.30.2 snj kill_daemon udhcpc /var/run/udhcpc-$GIFNAME.pid 46 1.1.1.1.30.2 snj ifconfig $GIFNAME 0.0.0.0 47 1.1.1.1.30.2 snj fi 48 1.1.1.1.30.2 snj fi 49 1.1.1.1.30.2 snj 50 1.1.1.1.30.2 snj if [ "$CMD" = "P2P-CROSS-CONNECT-ENABLE" ]; then 51 1.1.1.1.30.2 snj GIFNAME=$3 52 1.1.1.1.30.2 snj UPLINK=$4 53 1.1.1.1.30.2 snj # enable NAT/masquarade $GIFNAME -> $UPLINK 54 1.1.1.1.30.2 snj iptables -P FORWARD DROP 55 1.1.1.1.30.2 snj iptables -t nat -A POSTROUTING -o $UPLINK -j MASQUERADE 56 1.1.1.1.30.2 snj iptables -A FORWARD -i $UPLINK -o $GIFNAME -m state --state RELATED,ESTABLISHED -j ACCEPT 57 1.1.1.1.30.2 snj iptables -A FORWARD -i $GIFNAME -o $UPLINK -j ACCEPT 58 1.1.1.1.30.2 snj sysctl net.ipv4.ip_forward=1 59 1.1.1.1.30.2 snj fi 60 1.1.1.1.30.2 snj 61 1.1.1.1.30.2 snj if [ "$CMD" = "P2P-CROSS-CONNECT-DISABLE" ]; then 62 1.1.1.1.30.2 snj GIFNAME=$3 63 1.1.1.1.30.2 snj UPLINK=$4 64 1.1.1.1.30.2 snj # disable NAT/masquarade $GIFNAME -> $UPLINK 65 1.1.1.1.30.2 snj sysctl net.ipv4.ip_forward=0 66 1.1.1.1.30.2 snj iptables -t nat -D POSTROUTING -o $UPLINK -j MASQUERADE 67 1.1.1.1.30.2 snj iptables -D FORWARD -i $UPLINK -o $GIFNAME -m state --state RELATED,ESTABLISHED -j ACCEPT 68 1.1.1.1.30.2 snj iptables -D FORWARD -i $GIFNAME -o $UPLINK -j ACCEPT 69 1.1.1.1.30.2 snj fi 70