1
0
mirror of https://github.com/QSCTech/zjunet.git synced 2026-01-22 19:54:48 +08:00
zjunet/xl2tpd.sh

179 lines
3.7 KiB
Bash
Raw Normal View History

2014-09-20 21:54:42 +08:00
#!/bin/sh
# xl2tpd.sh -- xl2tpd connect / disconnect
#
# Copyright (C) 2014 Zeno Zeng <zenoofzeng@gmail.com>
2014-09-21 15:33:26 +08:00
# Copyright (C) 2014 Zhang Hai <Dreaming.in.Code.ZH@Gmail.com>
2014-09-20 21:54:42 +08:00
#
# 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
# <http://www.gnu.org/licenses/>.
2014-09-21 19:58:19 +08:00
LNS="10.5.1.9"
L2TPD_CFG_FILE=/etc/xl2tpd/xl2tpd.conf
USERNAME=$2
PASSWORD=$3
LAC_NAME=zju-l2tp-${USERNAME}
2014-09-21 23:50:35 +08:00
PPP_LOG_FILE=/tmp/zju-l2tp-log
2014-09-21 19:58:19 +08:00
PPP_OPT_FILE=/etc/ppp/peers/${LAC_NAME}
2014-09-21 17:20:38 +08:00
2014-09-21 23:50:35 +08:00
mkdir -p /var/log/zjunet/
LOG_FILE=/var/log/zjunet/${USERNAME}
XL2TPD_CONTROL_FILE=/var/run/xl2tpd/l2tp-control
xl2tpd_stop() {
# for Openwrt / Debian / Ubuntu
type systemctl >/dev/null 2>&1 || {
/etc/init.d/xl2tpd stop
}
# for Arch Linux
type systemctl >/dev/null 2>&1 && {
systemctl xl2tpd stop
}
}
2014-09-20 21:54:42 +08:00
xl2tpd_start() {
2014-09-20 21:54:42 +08:00
# for Openwrt / Debian / Ubuntu
type systemctl >/dev/null 2>&1 || {
/etc/init.d/xl2tpd start
2014-09-20 21:54:42 +08:00
}
2014-09-21 15:33:26 +08:00
# for Arch Linux
2014-09-20 21:54:42 +08:00
type systemctl >/dev/null 2>&1 && {
systemctl xl2tpd start
2014-09-20 21:54:42 +08:00
}
}
xl2tpd_restart() {
xl2tpd_stop
rm -f ${XL2TPD_CONTROL_FILE}
xl2tpd_start
2014-09-20 21:54:42 +08:00
# wait until ready
for i in $(seq 0 10); do
if [ -e ${XL2TPD_CONTROL_FILE} ]; then
echo "[INFO] xl2tpd ready."
2014-09-20 21:54:42 +08:00
return 0
fi
sleep 1
done
echo "Fail to start xl2tpd"
exit 1
2014-09-20 21:54:42 +08:00
}
2014-09-21 15:33:26 +08:00
xl2tpd_create_lac() {
2014-09-21 17:20:38 +08:00
touch $PPP_LOG_FILE
2014-09-21 15:33:26 +08:00
cat > $PPP_OPT_FILE <<EOF
noauth
linkname $LAC_NAME
logfile $PPP_LOG_FILE
2014-09-21 19:58:19 +08:00
name $USERNAME
password $PASSWORD
2014-09-21 15:33:26 +08:00
EOF
chmod 600 $PPP_OPT_FILE
2014-09-21 17:20:38 +08:00
touch $L2TPD_CFG_FILE
if ! grep -q "\[lac ${LAC_NAME}\]" $L2TPD_CFG_FILE; then
cat >> $L2TPD_CFG_FILE <<EOF
2014-09-21 15:33:26 +08:00
[lac ${LAC_NAME}]
lns = $LNS
redial = no
redial timeout = 5
require chap = yes
require authentication = no
ppp debug = no
pppoptfile = ${PPP_OPT_FILE}
require pap = no
autodial = yes
EOF
fi
2014-09-20 21:54:42 +08:00
}
xl2tpd_connect() {
xl2tpd-control connect $1
}
xl2tpd_disconnect() {
xl2tpd-control disconnect $1
}
2014-09-21 15:33:26 +08:00
connect() {
xl2tpd_disconnect ${LAC_NAME}
xl2tpd_connect ${LAC_NAME}
2014-09-21 15:33:26 +08:00
2014-09-21 17:20:38 +08:00
echo -n > $PPP_LOG_FILE
2014-09-21 15:33:26 +08:00
prev_count=$(ip addr show | grep 'inet.*ppp' | grep ' 10.5.' | wc -l)
for i in $(seq 0 120); do
2014-09-21 17:20:38 +08:00
tail $PPP_LOG_FILE
2014-09-21 23:50:35 +08:00
tail $PPP_LOG_FILE >> $LOG_FILE
if [ $(tail $PPP_LOG_FILE | grep 'Connection terminated' | wc -l) -ne 0 ]
then
echo "[INFO] Connection terminated."
echo -n > $PPP_LOG_FILE
2014-09-28 21:39:15 +08:00
echo "[INFO] Retrying now. (force kicking off, may take some time)"
xl2tpd_disconnect ${LAC_NAME}
sleep 1
xl2tpd_connect ${LAC_NAME}
fi
2014-09-21 17:23:49 +08:00
echo -n > $PPP_LOG_FILE
2014-09-21 15:33:26 +08:00
count=$(ip addr show | grep 'inet.*ppp' | grep ' 10.5.' | wc -l)
if [ ${count} -gt ${prev_count} ]; then
2014-09-21 17:20:38 +08:00
echo "Bring up ppp, done."
2014-09-21 15:33:26 +08:00
return
fi
2014-09-21 17:20:38 +08:00
sleep 1
2014-09-21 15:33:26 +08:00
done
2014-09-21 17:28:07 +08:00
echo "Fail to bring up ppp, timeout."
2014-09-21 15:33:26 +08:00
xl2tpd_disconnect ${LAC_NAME}
2014-09-21 15:33:26 +08:00
}
2014-09-20 21:54:42 +08:00
2014-09-26 13:55:11 +08:00
disconnect() {
xl2tpd_disconnect ${LAC_NAME}
2014-09-26 13:55:11 +08:00
tail $PPP_LOG_FILE
echo -n > $PPP_LOG_FILE
}
2014-09-20 21:54:42 +08:00
case $1 in
restart)
xl2tpd_restart
;;
adduser)
2014-09-21 19:58:19 +08:00
xl2tpd_create_lac
;;
connect)
2014-09-21 19:58:19 +08:00
connect
2014-09-20 21:54:42 +08:00
;;
disconnect)
disconnect
;;
2014-09-20 21:54:42 +08:00
esac