1
0
Fork 0
mirror of https://github.com/Ysurac/openmptcprouter-feeds.git synced 2025-02-12 18:41:51 +00:00

Use tunnel when available as default route

This commit is contained in:
Ycarus 2018-03-19 16:19:24 +01:00
parent fe1fbe26d4
commit b2696685a7
4 changed files with 60 additions and 17 deletions

View file

@ -17,7 +17,6 @@ uci -q batch <<-EOF >/dev/null
set network.glorytun.proto=dhcp
set network.glorytun.ip4table=vpn
set network.glorytun.multipath=off
set network.glorytun.defaultroute=0
commit network
EOF
uci -q batch <<-EOF >/dev/null

View file

@ -6,18 +6,18 @@ set_route() {
INTERFACE=$1
PREVINTERFACE=$2
multipath_config=$(uci -q get "network.$INTERFACE.multipath" || echo "off")
multipath_current_config=$(multipath $INTERFACE | grep deactivated)
interface_if=$(uci -q get "network.$INTERFACE.ifname")
multipath_current_config=$(multipath $interface_if | grep deactivated)
if [ "$multipath_config" != "off" ] && [ "$SETROUTE" != true ] && [ "$INTERFACE" != "$PREVINTERFACE" ] && [ "$multipath_current_config" = "" ]; then
#if [ "$multipath_config" != "off" ] && [ "$SETROUTE" != true ]; then
#if [ "$multipath_config" != "off" ] && [ "$INTERFACE" != "$PREVINTERFACE" ] && [ "$SETROUTE" != true ]; then
interface_gw=$(uci -q get "network.$INTERFACE.gateway")
if [ -z $interface_gw ]; then
$interface_gw=$(ubus call network.interface.$INTERFACE status | jsonfilter -e '@.route[0].nexthop' | tr -d "\d")
$interface_gw=$(ubus call network.interface.$INTERFACE status | jsonfilter -e '@.route[0].nexthop' | tr -d "\n")
fi
if [ -z $interface_gw ]; then
$interface_gw=$(ubus call network.interface.$INTERFACE status | jsonfilter -e '@.inactive.route[0].nexthop' | tr -d "\d")
$interface_gw=$(ubus call network.interface.$INTERFACE status | jsonfilter -e '@.inactive.route[0].nexthop' | tr -d "\n")
fi
interface_if=$(uci -q get "network.$INTERFACE.ifname")
if [ "$interface_gw" != "" ]; then
_log "Replace default route by $interface_gw dev $interface_if"
ip route replace default scope global nexthop via $interface_gw dev $interface_if && SETROUTE=true
@ -25,6 +25,24 @@ set_route() {
fi
}
set_ss_route() {
local server_ip
config_get server_ip $1 server
if [ "$(ip route show dev $OMR_TRACKER_DEVICE | grep $server_ip | grep $OMR_TRACKER_DEVICE_GATEWAY)" = "" ]; then
_log "Set server route via $OMR_TRACKER_DEVICE"
ip route replace $server_ip via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
fi
}
del_ss_route() {
local server_ip
config_get server_ip $1 server
if [ "$(ip route show dev $OMR_TRACKER_DEVICE | grep $server_ip | grep $OMR_TRACKER_DEVICE_GATEWAY)" != "" ]; then
_log "Remove server route via $OMR_TRACKER_DEVICE"
ip route delete $server_ip via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
fi
}
sleep `expr $RANDOM % 10`
# Get the current multipath status
@ -45,20 +63,36 @@ if [ "$OMR_TRACKER_STATUS" = "ERROR" ]; then
multipath "$OMR_TRACKER_DEVICE" off
if [ "$default_gw" = "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]; then
config_load network
config_foreach set_route interface $OMR_TRACKER_DEVICE
config_foreach set_route interface $OMR_TRACKER_INTERFACE
fi
config_load shadowsocks-libev
config_foreach del_ss_route server
exit 0
fi
if [ "$OMR_TRACKER_INTERFACE" = "glorytun" ]; then
if [ "$default_gw" != "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]; then
_log "Tunnel up : Replace default route by $current_interface_gw dev $OMR_TRACKER_DEVICE"
ip route replace default scope global nexthop via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
fi
exit 0
fi
multipath_config=$(uci -q get "network.$OMR_TRACKER_INTERFACE.multipath" || echo "off")
[ "$multipath_config" = "master" ] && [ "$multipath_status" = "on" ] && exit 0
[ "$multipath_status" = "$multipath_config" ] && exit 0
_log "$OMR_TRACKER_DEVICE switched to $multipath_config"
if [ "$multipath_config" = "master" ]; then
if [ "$default_gw" != "$OMR_TRACKER_DEVICE_GATEWAY" ] || [ "$default_gw" = "" ]; then
_log "Master up : Replace default route by $current_interface_gw dev $OMR_TRACKER_INTERFACE"
ip route replace default scope global nexthop via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_INTERFACE
if [ "$(ip route show default | grep -v metric | awk '/default/ {print $5}' | grep tun)" = "" ]; then
_log "Master up : Replace default route by $current_interface_gw dev $OMR_TRACKER_DEVICE"
ip route replace default scope global nexthop via $OMR_TRACKER_DEVICE_GATEWAY dev $OMR_TRACKER_DEVICE
else
config_load shadowsocks-libev
config_foreach set_ss_route server
fi
fi
multipath_config="on"
fi
[ "$multipath_config" = "master" ] && [ "$multipath_status" = "on" ] && exit 0
[ "$multipath_status" = "$multipath_config" ] && exit 0
_log "Multipath $OMR_TRACKER_DEVICE switched to $multipath_config"
multipath "$OMR_TRACKER_DEVICE" "$multipath_config"

View file

@ -31,7 +31,7 @@ _validate_section() {
_launch_tracker() {
case "$1" in
loopback|lan*|if0*|glorytun*|tun*) return;;
loopback|lan*|if0*|tun*) return;;
esac
local interface_type
@ -46,7 +46,7 @@ _launch_tracker() {
config_get multipath "$1" multipath
config_get gateway "$1" gateway
[ -z "$ifname" ] || [ -z "$multipath" ] || [ "$multipath" = "off" ] && return
[ -z "$ifname" ] || [ -z "$multipath" ] || [ "$multipath" = "off" ] && [ "$1" != "glorytun" ] && return
[ -z "$type" ] && type="ping"
procd_open_instance

View file

@ -5,13 +5,23 @@ uci -q batch <<-EOF >/dev/null
set qos.wan1=interface
set qos.wan1.classgroup="Default"
set qos.wan1.enabled="0"
set qos.wan1.upload="128"
set qos.wan1.download="1024"
set qos.wan1.upload="256"
set qos.wan1.download="2048"
set qos.wan2=interface
set qos.wan2.classgroup="Default"
set qos.wan2.enabled="0"
set qos.wan2.upload="128"
set qos.wan2.download="1024"
set qos.wan2.upload="256"
set qos.wan2.download="2048"
delete qos.@classify[-1]
add qos classify
set qos.@classify[-1].target='Express'
set qos.@classify[-1].ports='5600'
set qos.@classify[-1].comments='SIP'
add qos classify
set qos.@classify[-1].target='Express'
set qos.@classify[-1].portrange='27000-27050'
set qos.@classify[1].proto='udp'
set qos.@classify[-1].comments='Steam'
commit qos
EOF
rm -f /tmp/luci-indexcache