projects
/
openwrt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[gemini] disable the watchdog if the bootloader left it enabled
[openwrt.git]
/
package
/
pptp
/
files
/
pptp.sh
diff --git
a/package/pptp/files/pptp.sh
b/package/pptp/files/pptp.sh
index
0743082
..
e38c242
100644
(file)
--- a/
package/pptp/files/pptp.sh
+++ b/
package/pptp/files/pptp.sh
@@
-2,12
+2,18
@@
scan_pptp() {
scan_ppp "$@"
}
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
setup_interface_pptp() {
local config="$2"
local ifname
config_get device "$config" device
config_get ipproto "$config" ipproto
+ config_get server "$config" server
for module in slhc ppp_generic ppp_async ip_gre; do
/sbin/insmod $module 2>&- >&-
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}"
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
# fix up the netmask
config_get netmask "$config" netmask
@@
-25,8
+36,7
@@
setup_interface_pptp() {
config_get ifname "$config" ifname
uci_set_state network "$config" ifname "$ifname"
config_get ifname "$config" ifname
uci_set_state network "$config" ifname "$ifname"
- config_get mtu "$cfg" mtu
- config_get server "$cfg" server
+ config_get mtu "$config" mtu
mtu=${mtu:-1452}
start_pppd "$config" \
pty "/usr/sbin/pptp $server --loglevel 0 --nolaunchpppd" \
mtu=${mtu:-1452}
start_pppd "$config" \
pty "/usr/sbin/pptp $server --loglevel 0 --nolaunchpppd" \
This page took
0.038166 seconds
and
4
git commands to generate.