udhcpc: run dhcp hotplug events after dns has been set
[openwrt/svn-archive/archive.git] / package / base-files / files / usr / share / udhcpc / default.script
index a3a696be70a5c361dcf282a6672a5898fe7f6358..84c729783885785fb2ded256e91b0c6b7dda22ad 100755 (executable)
@@ -14,12 +14,21 @@ hotplug_event() {
                config_get proto $ifc proto
                [ "$proto" = "dhcp" ] || continue
                [ ifup = "$1" ] && {
-                       uci set "/var/state/network.$ifc.ipaddr=$ip"
-                       uci set "/var/state/network.$ifc.netmask=${subnet:-255.255.255.0}"
-                       uci set "/var/state/network.$ifc.dnsdomain=$domain"
-                       uci set "/var/state/network.$ifc.dns=$dns"
-                       uci set "/var/state/network.$ifc.gateway=$router"
+                       config_get userdns "$ifc" dns
+                       [ -n "$userdns" ] && {
+                               for i in $userdns; do
+                                       echo "custom dns $i"
+                                       echo "nameserver $i" >> "${RESOLV_CONF}.tmp"
+                               done
+                               dns="$userdns"
+                       }
+                       uci_set_state network "$ifc" ipaddr "$ip"
+                       uci_set_state network "$ifc" netmask "${subnet:-255.255.255.0}"
+                       uci_set_state network "$ifc" dnsdomain "$domain"
+                       uci_set_state network "$ifc" dns "$dns"
+                       uci_set_state network "$ifc" gateway "$router"
                }
+               
                env -i ACTION="$1" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug-call iface
        done
 }
@@ -45,18 +54,29 @@ case "$1" in
                        echo "deleting old routes"
                        $(route -n | awk '/^0.0.0.0\W{9}('$valid')\W/ {next} /^0.0.0.0/ {print "route del -net "$1" gw "$2";"}')
                }
+
+               [ -n "$dns" ] && \
+                       echo -n > "${RESOLV_CONF}.tmp"
                
                [ -n "$dns" ] && {
-                       echo -n > $RESOLV_CONF
-                       ${domain:+echo search $domain} >> $RESOLV_CONF
-                       for i in $dns ; do
-                               echo "adding dns $i"
-                               echo "nameserver $i" >> $RESOLV_CONF
-                       done
+                       [ -s "${RESOLV_CONF}.tmp" ] || {
+                               for i in $dns ; do
+                                       echo "adding dns $i"
+                                       echo "nameserver $i" >> "${RESOLV_CONF}.tmp"
+                               done
+                       }
+
+                       ${domain:+echo search $domain} >> "${RESOLV_CONF}.tmp"
+
+                       mv "${RESOLV_CONF}.tmp" "$RESOLV_CONF"
                }
-               
-               hotplug_event ifup
-               
+
+               if [ "$1" = "renew" ]; then
+                       hotplug_event update
+               else
+                       hotplug_event ifup
+               fi
+
                # user rules
                [ -f /etc/udhcpc.user ] && . /etc/udhcpc.user
        ;;