diff options
author | Waldemar Brodkorb <wbx@openadk.org> | 2009-11-27 19:33:58 +0100 |
---|---|---|
committer | Waldemar Brodkorb <wbx@openadk.org> | 2009-11-27 19:33:58 +0100 |
commit | 3d8d90f636eb9e1c7c89b3f99841948b6c30050c (patch) | |
tree | 4903e6ce7f4174e5e80ee3bd585b9af9d94c2255 /package/base-files/extra | |
parent | 0c6fb98d013e4ffc664935a51adce94254d10f83 (diff) | |
parent | 7d36caec53dbfeea4e696205ae71bdae8246a082 (diff) |
Merge branch 'master' of git+ssh://openadk.org/git/openadk
Diffstat (limited to 'package/base-files/extra')
-rwxr-xr-x | package/base-files/extra/etc/network/if-post-down.d/bridge | 24 | ||||
-rwxr-xr-x | package/base-files/extra/etc/network/if-pre-up.d/bridge | 32 | ||||
-rwxr-xr-x | package/base-files/extra/sbin/update | 66 |
3 files changed, 122 insertions, 0 deletions
diff --git a/package/base-files/extra/etc/network/if-post-down.d/bridge b/package/base-files/extra/etc/network/if-post-down.d/bridge new file mode 100755 index 000000000..eda1fe3bf --- /dev/null +++ b/package/base-files/extra/etc/network/if-post-down.d/bridge @@ -0,0 +1,24 @@ +#!/bin/sh + +if [ ! -x /usr/sbin/brctl ] +then + exit 0 +fi + +case "$IF_BRIDGE_PORTS" in + "") + exit 0 + ;; + none) + INTERFACES="" + ;; + *) + INTERFACES="$IF_BRIDGE_PORTS" + ;; +esac + +for IF in $INTERFACES; do + ip link set down dev $IF && brctl delif $IFACE $IF +done + +ip link set down dev $IFACE || exit 1 diff --git a/package/base-files/extra/etc/network/if-pre-up.d/bridge b/package/base-files/extra/etc/network/if-pre-up.d/bridge new file mode 100755 index 000000000..766084de1 --- /dev/null +++ b/package/base-files/extra/etc/network/if-pre-up.d/bridge @@ -0,0 +1,32 @@ +#!/bin/sh + +if [ ! -x /usr/sbin/brctl ] +then + exit 0 +fi + +case "$IF_BRIDGE_PORTS" in + "") + exit 0 + ;; + none) + INTERFACES="" + ;; + *) + INTERFACES="$IF_BRIDGE_PORTS" + ;; +esac + +brctl addbr $IFACE || exit 1 + +for IF in $INTERFACES; do + if ! grep -q $IF /proc/net/dev; then + echo "Error: interface '$IF' does not exist!" + brctl delbr $IFACE + exit 1 + fi + brctl addif $IFACE $IF + ip link set up dev $IF +done + +exit 0 diff --git a/package/base-files/extra/sbin/update b/package/base-files/extra/sbin/update new file mode 100755 index 000000000..a812bb23d --- /dev/null +++ b/package/base-files/extra/sbin/update @@ -0,0 +1,66 @@ +#!/bin/sh + +who=$(id -u) +if [ $who -ne 0 ]; then + echo 'Exit. System update must be run as root.' + exit 1 +fi + +cd / + +mount -o remount,rw / +umount /etc + +check_exit() { + if [ $? -ne 0 ];then + echo "Update failed." + exit 1 + fi +} + +extract_from_file() { + tar -xzvf $1 + check_exit +} + +extract_from_ssh() { + ssh $1 "cat $2" | tar -xzvf - + check_exit +} + +extract_from_http() { + wget -O - $1 | tar -xzvf - + check_exit +} + +case $1 in + file://*|/*) + url=$(echo $1|sed -e "s#file://##") + echo "Updating system from $1" + extract_from_file $url + ;; + ssh://*) + host=$(echo $1|sed -e "s#ssh://\(.*\):.*#\1#") + file=$(echo $1|sed -e "s#ssh://.*:\(.*\)#\1#") + echo "Updating system from $1" + extract_from_ssh $host $file + ;; + http://*|ftp://*) + echo "Updating system from $1" + extract_from_http $1 + ;; + *) + echo "No or wrong uri given. exit." + echo "Use one of the following uri:" + echo "http://myserver/myupdate.tar.gz" + echo "ssh://myuser@myserver:/my/path/myupdate.tar.gz" + echo "file:///mypath/myupdate.tar.gz" + exit 1 + ;; +esac + +sync +mount --bind /etc /tmp/.cfgfs/root + +echo "Check with cfgfs status if you need to merge and save any changes in /etc." +echo "You should reboot now." |