diff options
Diffstat (limited to 'package/base-files-network/files/sbin')
-rwxr-xr-x | package/base-files-network/files/sbin/ifdown | 57 | ||||
-rwxr-xr-x | package/base-files-network/files/sbin/ifup | 51 |
2 files changed, 108 insertions, 0 deletions
diff --git a/package/base-files-network/files/sbin/ifdown b/package/base-files-network/files/sbin/ifdown new file mode 100755 index 0000000000..1455a9de77 --- /dev/null +++ b/package/base-files-network/files/sbin/ifdown @@ -0,0 +1,57 @@ +#!/bin/sh +# Copyright (C) 2006-2011 OpenWrt.org + +. /etc/functions.sh +[ $# = 0 ] && { echo " $0 <group>"; exit; } + +case "$1" in + "-a") + [ -e "/tmp/resolv.conf.auto" ] && rm /tmp/resolv.conf.auto + config_cb() { + [ interface != "$1" -o -z "$2" ] || eval "$0 -w $2" + } + config_load network + exit 0 + ;; + "-w") shift ;; +esac + +include /lib/network +scan_interfaces + +cfg=$1 +debug "### ifdown $cfg ###" + +config_get proto "$cfg" proto +[ -z "$proto" ] && { echo "interface not found."; exit; } + +config_get iface "$cfg" device +[ "static" = "$proto" -o "none" = "$proto" ] && { + env -i ACTION="ifdown" INTERFACE="$cfg" DEVICE="$iface" PROTO="$proto" /sbin/hotplug-call "iface" +} + +# call interface stop handler +( type "stop_interface_$proto" ) >/dev/null 2>/dev/null && eval "stop_interface_$proto '$cfg'" + +config_get ifname "$cfg" ifname +config_get device "$cfg" device + +[ ."$device" != ."$ifname" ] || device= +for dev in $ifname $device; do + ifconfig "$dev" 0.0.0.0 down >/dev/null 2>/dev/null +done + +config_get iftype "$cfg" type +[ "bridge" = "$iftype" ] && brctl delbr "$ifname" >/dev/null 2>/dev/null + +# remove the interface's dns entries +remove_dns "$cfg" + +# remove the interface's network state +uci_revert_state network "$1" + +# revert aliases state as well +config_get aliases "$1" aliases +for config in $aliases; do + uci_revert_state network "$config" +done diff --git a/package/base-files-network/files/sbin/ifup b/package/base-files-network/files/sbin/ifup new file mode 100755 index 0000000000..5f8d80dc2d --- /dev/null +++ b/package/base-files-network/files/sbin/ifup @@ -0,0 +1,51 @@ +#!/bin/sh +# Copyright (C) 2006-2011 OpenWrt.org + +/sbin/ifdown "$@" + +. /etc/functions.sh +[ $# = 0 ] && { echo " $0 <group>"; exit; } + +setup_wifi=1 + +case "$1" in + "-a") + [ -e "/tmp/resolv.conf.auto" ] && rm /tmp/resolv.conf.auto + config_cb() { + [ interface != "$1" -o -z "$2" ] || eval "$0 -w $2" + } + config_load network + exit 0 + ;; + "-w") setup_wifi=0; shift ;; +esac + +if [ $setup_wifi -gt 0 ] && grep -q config /etc/config/wireless; then + find_related_radios() { + local wdev wnet + config_get wdev "$1" device + config_get wnet "$1" network + + if [ -n "$wdev" ] && [ "$wnet" = "$network" ]; then + append radio_devs "$wdev" "$N" + fi + } + + local radio_devs + local network="$1" + config_load wireless + config_foreach find_related_radios wifi-iface + + local dev + for dev in $(echo "$radio_devs" | sort -u); do + /sbin/wifi up "$dev" + done +fi + +include /lib/network +scan_interfaces + +config_get ifname "$1" device +for dev in ${ifname:-$1}; do + setup_interface "$dev" "$1" +done |