|
|
@@ -2,12 +2,18 @@ scan_pptp() {
|
|
|
scan_ppp "$@"
|
|
|
}
|
|
|
|
|
|
+find_gw() {
|
|
|
+ route -n | awk '$1 == "0.0.0.0" { print $2; exit }'
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
setup_interface_pptp() {
|
|
|
local config="$2"
|
|
|
local ifname
|
|
|
|
|
|
config_get device "$config" device
|
|
|
config_get ipproto "$config" ipproto
|
|
|
+ config_get server "$cfg" server
|
|
|
|
|
|
for module in slhc ppp_generic ppp_async ip_gre; do
|
|
|
/sbin/insmod $module 2>&- >&-
|
|
|
@@ -15,6 +21,11 @@ setup_interface_pptp() {
|
|
|
sleep 1
|
|
|
|
|
|
setup_interface "$device" "$config" "${ipproto:-dhcp}"
|
|
|
+ local gw="$(find_gw)"
|
|
|
+ [ -n "$gw" ] && {
|
|
|
+ route delete "$server" 2>/dev/null >/dev/null
|
|
|
+ route add "$server" gw "$gw"
|
|
|
+ }
|
|
|
|
|
|
# fix up the netmask
|
|
|
config_get netmask "$config" netmask
|
|
|
@@ -26,7 +37,6 @@ setup_interface_pptp() {
|
|
|
uci_set_state network "$config" ifname "$ifname"
|
|
|
|
|
|
config_get mtu "$cfg" mtu
|
|
|
- config_get server "$cfg" server
|
|
|
mtu=${mtu:-1452}
|
|
|
start_pppd "$config" \
|
|
|
pty "/usr/sbin/pptp $server --loglevel 0 --nolaunchpppd" \
|