#!/bin/sh # vpn.sh -- xl2tpd connect / disconnect # # Requirements: xl2tpd # # Copyright (C) 2014 Zeno Zeng # Copyright (C) 2014 Zhang Hai # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, but # WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see # . set_up_routes() { IP=$(ip route show 0/0 | cut -d " " -f 3) case "$IP" in 10.189.*) ;; 10.171.*) ;; *) # 内网静态路由 TODO ;; esac # # set up routes here # # interfaces # ip addr show | grep 'inet.*ppp' | grep ' 10.5.' # GW=$(ip route get $VPN_SERVER 2>/dev/null | grep via | awk '{print $3}') # PPP=$(ip addr show | grep ppp[0-9]: | cut "-d " -f2 | cut -d: -f1) # echo "[MSG] Detected gateway: $GW, PPP device: $PPP ." # ip route add 10.0.0.0/8 via $GW # ip route add 0.0.0.0/1 dev $PPP # ip route add 128.0.0.0/1 dev $PPP # todo nexthop } connect() { users=$("${BASEDIR}/user.sh" getall) for username in $users; do password=$("${BASEDIR}/user.sh" getpwd $username) echo "Login using ${username}" "${BASEDIR}/xl2tpd.sh" connect $username $password done set_up_routes } disconnect() { users=$("${BASEDIR}/user.sh" getall) for username in $users; do echo "Logout: ${username}" "${BASEDIR}/xl2tpd.sh" disconnect $username done set_up_routes } ##################################### # # Dispatch # ##################################### BASEDIR=$(dirname $0) case "$1" in -d) disconnect ;; disconnect) disconnect ;; *) connect ;; esac