diff options
| author | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2006-11-22 23:30:57 +0000 | 
|---|---|---|
| committer | nbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2006-11-22 23:30:57 +0000 | 
| commit | 05adaa9794e41d02870a74a1ed7ba58cc59b9286 (patch) | |
| tree | b34e972b2aa8e22dc921b0b9967d811e7525e3bc /package/base-files/files/usr/share | |
| parent | 356535ffd7bc1343ce6bc2fc367f788cc2c1bd24 (diff) | |
rename default/ to files/
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@5622 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/files/usr/share')
| -rwxr-xr-x | package/base-files/files/usr/share/udhcpc/default.script | 57 | 
1 files changed, 57 insertions, 0 deletions
diff --git a/package/base-files/files/usr/share/udhcpc/default.script b/package/base-files/files/usr/share/udhcpc/default.script new file mode 100755 index 000000000..53c8faf31 --- /dev/null +++ b/package/base-files/files/usr/share/udhcpc/default.script @@ -0,0 +1,57 @@ +#!/bin/sh +[ -z "$1" ] && echo "Error: should be run by udhcpc" && exit 1 +. /etc/functions.sh +include /lib/network + +RESOLV_CONF="/tmp/resolv.conf" + +hotplug_event() { +	scan_interfaces +	for ifc in $interfaces; do +		config_get ifname $ifc ifname +		[ "$ifname" = "$interface" ] || continue + +		config_get proto $ifc proto +		[ "$proto" = "dhcp" ] || continue + +		env -i ACTION="$1" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug iface +	done +} + +case "$1" in +	deconfig) +		ifconfig $interface 0.0.0.0 +		hotplug_event ifdown +	;; +	renew|bound) +		ifconfig $interface $ip \ +		netmask ${subnet:-255.255.255.0} \ +		broadcast ${broadcast:-+} + +		if [ -n "$router" ] ; then +			echo "deleting routers" +			while route del default gw 0.0.0.0 dev $interface >&- 2>&- ; do :; done +					 +			for i in $router ; do +				echo "adding router $i" +				route add default gw $i dev $interface +			done +		fi +		 +		[ -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 +		} +		 +		hotplug_event ifup +		 +		# user rules +		[ -f /etc/udhcpc.user ] && . /etc/udhcpc.user +	;; +esac + +exit 0  | 
