allow udhcpc to work properly for interfaces that are not configured through uci

SVN-Revision: 16664
master
Felix Fietkau 15 years ago
parent f3822efd8e
commit 7a576b004e
  1. 61
      package/base-files/files/usr/share/udhcpc/default.script

@ -6,11 +6,13 @@ include /lib/network
RESOLV_CONF="/tmp/resolv.conf.auto" RESOLV_CONF="/tmp/resolv.conf.auto"
change_state () { change_state () {
[ -n "$ifc" ] || return
uci_revert_state "$1" "$2" "$3" "$4" uci_revert_state "$1" "$2" "$3" "$4"
uci_set_state "$1" "$2" "$3" "$4" uci_set_state "$1" "$2" "$3" "$4"
} }
uci_get() { uci_get() {
[ -n "$ifc" ] || return
uci -P /dev/null get "$1" 2>/dev/null uci -P /dev/null get "$1" 2>/dev/null
} }
@ -23,9 +25,11 @@ setup_interface () {
local user_dns local user_dns
local user_router local user_router
config_get old_ip "$ifc" ipaddr [ -n "$ifc" ] && {
config_get old_broadcast "$ifc" broadcast config_get old_ip "$ifc" ipaddr
config_get old_subnet "$ifc" netmask config_get old_broadcast "$ifc" broadcast
config_get old_subnet "$ifc" netmask
}
[ "$ip" != "$old_ip" ] \ [ "$ip" != "$old_ip" ] \
|| [ "${broadcast:-+}" != "$old_broadcast" ] \ || [ "${broadcast:-+}" != "$old_broadcast" ] \
@ -40,12 +44,14 @@ setup_interface () {
# Default Route # Default Route
change_state network "$ifc" lease_gateway "$router" [ -n "$ifc" ] && {
config_get old_router "$ifc" gateway change_state network "$ifc" lease_gateway "$router"
user_router=$(uci_get "network.$ifc.gateway") config_get old_router "$ifc" gateway
[ -n "$user_router" ] && router="$user_router" user_router=$(uci_get "network.$ifc.gateway")
[ -n "$user_router" ] && router="$user_router"
}
[ -n "$router" ] && [ "$router" != "0.0.0.0" ] && [ "$router" != "$old_router" ] && { [ -n "$router" ] && [ "$router" != "0.0.0.0" ] && [ "$router" != "255.255.255.255" ] && [ "$router" != "$old_router" ] && {
echo "udhcpc: setting default routers: $router" echo "udhcpc: setting default routers: $router"
local valid_gw="" local valid_gw=""
@ -155,6 +161,7 @@ setup_interface () {
change_state network "$ifc" dns "$dns" change_state network "$ifc" dns "$dns"
} }
[ -n "$ifc" ] || return
# UCI State # UCI State
change_state network "$ifc" lease_server "$serverid" change_state network "$ifc" lease_server "$serverid"
@ -172,26 +179,34 @@ setup_interface () {
scan_interfaces scan_interfaces
applied=
for ifc in $interfaces; do for ifc in $interfaces __default; do
config_get ifname "$ifc" ifname if [ "$ifc" = __default ]; then
[ "$ifname" = "$interface" ] || continue ifc=""
[ -n "$applied" ] && continue
config_get proto "$ifc" proto else
[ "$proto" = "dhcp" ] || continue config_get ifname "$ifc" ifname
[ "$ifname" = "$interface" ] || continue
config_get proto "$ifc" proto
[ "$proto" = "dhcp" ] || continue
applied=true
fi
case "$1" in case "$1" in
deconfig) deconfig)
ifconfig "$interface" 0.0.0.0 ifconfig "$interface" 0.0.0.0
env -i ACTION="ifdown" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug-call iface [ -n "$ifc" ] && {
env -i ACTION="ifdown" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug-call iface
config_get device "$ifc" device config_get device "$ifc" device
config_get ifname "$ifc" ifname config_get ifname "$ifc" ifname
config_get aliases "$ifc" aliases config_get aliases "$ifc" aliases
uci_revert_state network "$ifc" uci_revert_state network "$ifc"
[ -n "$device" ] && uci_set_state network "$ifc" device "$device" [ -n "$device" ] && uci_set_state network "$ifc" device "$device"
[ -n "$ifname" ] && uci_set_state network "$ifc" ifname "$ifname" [ -n "$ifname" ] && uci_set_state network "$ifc" ifname "$ifname"
[ -n "$aliases" ] && uci_set_state network "$ifc" aliases "$aliases" [ -n "$aliases" ] && uci_set_state network "$ifc" aliases "$aliases"
}
;; ;;
renew) renew)
setup_interface update setup_interface update

Loading…
Cancel
Save