]> arthur.barton.de Git - backup-script.git/blobdiff - bin/backup-status
Add "[default_]exclude_dirs_add" options
[backup-script.git] / bin / backup-status
index e0c5c0457cade0c6f0b37184a8be7d01f05f931d..7c1c1830a66a6bf5a3eee26f84ae001827d9be4f 100755 (executable)
@@ -13,6 +13,7 @@
 NAME=`basename $0`
 PIDFILE="/var/run/backup-script.pid"
 QUICK=0
+ONLY_LATEST=0
 
 export LC_ALL=C
 
@@ -23,7 +24,7 @@ declare -i snapshots=0
 [ -d "/usr/local/etc/backup-script.d" ] \
        && conf_d="/usr/local/etc/backup-script.d" \
        || conf_d="/etc/backup-script.d"
-default_target=""
+default_target="/var/backups"
 default_generations=0
 
 # Search configuration file (last one is used as default!)
@@ -39,6 +40,12 @@ for conf in \
        fi
 done
 
+Usage() {
+       echo "Usage: $NAME [-q|--quick] [<system> [<system> [...]]]"
+       echo "       $NAME {-r|--running}"
+       exit 2
+}
+
 Check_Size() {
        # $1: directory
        # $2: padding
@@ -74,6 +81,12 @@ Check_Stamp() {
        fi
 }
 
+Snapshot_Info() {
+       echo "  - Snapshot: $1"
+       Check_Size "$1" "  "
+       Check_Stamp "$1/.stamp" "  "
+}
+
 if [ "$1" == "-r" -o "$1" == "--running" ]; then
        pid="$(cat "$PIDFILE" 2>/dev/null)"
        if [ -n "$pid" ]; then
@@ -91,18 +104,22 @@ if [ "$1" == "-r" -o "$1" == "--running" ]; then
        exit 1
 fi
 
-if [ "$1" == "-q" ]; then
-       QUICK=1
+while [ $# -gt 0 ]; do
+       case "$1" in
+               "--latest"|"-l")
+                       ONLY_LATEST=1
+                       ;;
+               "--quick"|"-q")
+                       QUICK=1
+                       ;;
+               "-"*)
+                       Usage
+                       ;;
+               *)
+                       break
+       esac
        shift
-fi
-
-case "$1" in
-    "-"*)
-       echo "Usage: $NAME [-q] [<system> [<system> [...]]]"
-       echo "       $NAME {-r|--running}"
-       exit 2
-       ;;
-esac
+done
 
 if [ $# -ge 1 ]; then
        for s in "$@"; do
@@ -116,8 +133,6 @@ else
        sys="${conf_d}/"*
 fi
 
-[ -r "${conf_d}/backup-script.conf" ] && source "${conf_d}/backup-script.conf"
-
 for f in $sys; do
        [ -r "$f" -a -f "$f" ] || continue
 
@@ -136,7 +151,7 @@ for f in $sys; do
        # Read in system configuration file
        source "$f"
 
-       target="$target/$system"
+       target="$target/$(basename "$f")"
 
        [ -d "$target" ] || continue
 
@@ -147,13 +162,16 @@ for f in $sys; do
        echo "- Target: $target"
 
        if [ $generations -gt 0 ]; then
-               for s in $target/current $target/[0-9]*-[0-9]*; do
-                       [ -e "$s" ] || continue
-                       echo "  - Snapshot: $s"
-                       Check_Size "$s" "  "
-                       Check_Stamp "$s/.stamp" "  "
+               if [ "$ONLY_LATEST" = "0" ]; then
+                       for s in $target/[0-9]*-[0-9]* $target/current; do
+                               [ -e "$s" ] || continue
+                               Snapshot_Info "$s"
+                               snapshots=$snapshots+1
+                       done
+               elif [ -e "$target/latest" ]; then
+                       Snapshot_Info "$target/latest"
                        snapshots=$snapshots+1
-               done
+               fi
        else
                # Timestamp and result code
                Check_Size "$target"