summaryrefslogtreecommitdiff
path: root/package/base-files/extra
diff options
context:
space:
mode:
authorWaldemar Brodkorb <wbx@openadk.org>2009-11-27 19:33:58 +0100
committerWaldemar Brodkorb <wbx@openadk.org>2009-11-27 19:33:58 +0100
commit3d8d90f636eb9e1c7c89b3f99841948b6c30050c (patch)
tree4903e6ce7f4174e5e80ee3bd585b9af9d94c2255 /package/base-files/extra
parent0c6fb98d013e4ffc664935a51adce94254d10f83 (diff)
parent7d36caec53dbfeea4e696205ae71bdae8246a082 (diff)
Merge branch 'master' of git+ssh://openadk.org/git/openadk
Diffstat (limited to 'package/base-files/extra')
-rwxr-xr-xpackage/base-files/extra/etc/network/if-post-down.d/bridge24
-rwxr-xr-xpackage/base-files/extra/etc/network/if-pre-up.d/bridge32
-rwxr-xr-xpackage/base-files/extra/sbin/update66
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."