summaryrefslogtreecommitdiffstats
path: root/common
diff options
context:
space:
mode:
Diffstat (limited to 'common')
-rw-r--r--common/check_tools.sh11
-rw-r--r--common/init.sh21
-rw-r--r--common/log.sh15
-rw-r--r--common/update.sh18
4 files changed, 65 insertions, 0 deletions
diff --git a/common/check_tools.sh b/common/check_tools.sh
new file mode 100644
index 0000000..ba3640d
--- /dev/null
+++ b/common/check_tools.sh
@@ -0,0 +1,11 @@
+# check for necessary tools
+
+_check_tools() {
+ for prog in $@
+ do
+ if ! hash $prog 2>/dev/null ; then
+ echo "Error: This script needs '$prog'. Exiting..." >&2
+ exit 1
+ fi
+ done
+}
diff --git a/common/init.sh b/common/init.sh
new file mode 100644
index 0000000..a955f18
--- /dev/null
+++ b/common/init.sh
@@ -0,0 +1,21 @@
+# init common function for backup
+
+# get path to common script dir
+if [ -z "${BACKUP_ROOT}" -o ! -d "${BACKUP_ROOT}/common/" ]; then
+ echo "\$BACKUP_ROOT not set or invalid! (common dir not there)" >&2
+ echo "Please set it to the path to the root directory of the" >&2
+ echo "backup scripts before sourcing this init.sh file." >&2
+ exit 1
+fi
+
+# load all common scripts
+for file in ${BACKUP_ROOT}/common/*
+do
+ if [ "$(basename ${file})" != "init.sh" ]; then
+ source "${file}"
+ fi
+done
+
+# check if git is available for update
+_check_tools git
+_self_update
diff --git a/common/log.sh b/common/log.sh
new file mode 100644
index 0000000..622a9bb
--- /dev/null
+++ b/common/log.sh
@@ -0,0 +1,15 @@
+# log function for displaying output if loging enabled
+
+_log() {
+ # only output something,
+ # if logging is enabled
+ if [ $LOGGING -eq 0 ]; then
+ if [ -n "$1" ]; then
+ # echo arguments
+ echo "$@"
+ else
+ # echo stdin
+ cat
+ fi
+ fi
+}
diff --git a/common/update.sh b/common/update.sh
new file mode 100644
index 0000000..c4f0b5f
--- /dev/null
+++ b/common/update.sh
@@ -0,0 +1,18 @@
+# update backup scripts
+
+_self_update() {
+ pushd $(dirname $0) &>/dev/null
+
+ git fetch origin 2>/dev/null
+ if [[ -n "$(git whatchanged HEAD..origin/master)" ]]; then
+ echo "Selfupdating backupscript..." | log
+ git merge origin/master | log
+ echo "Selfupdating done." | log
+ echo | log
+
+ popd &>/dev/null
+ exec $0
+ fi
+
+ popd &>/dev/null
+}