X-Git-Url: http://git.pippins.net/embedvideo/.git/?a=blobdiff_plain;f=scripts%2Frestore-script.sh;h=66ac4fb5b4da27c64842c96444daf04313059a71;hb=9c5abcc59e83fa16bfeb810cc4d51960f8586a4e;hp=6592d72a612f8360d74e473bbd916387637931d4;hpb=4d43b38a139fcc3ef784f7fe3cab00019f679b54;p=backups%2F.git diff --git a/scripts/restore-script.sh b/scripts/restore-script.sh index 6592d72..66ac4fb 100755 --- a/scripts/restore-script.sh +++ b/scripts/restore-script.sh @@ -1,5 +1,14 @@ #!/bin/sh +function err() { + echo 2>&1 "-E- $1" + exit 1 +} + +if [ ! -z "$3" ]; then + mountdir=$3 +fi + if [ -z "$mountdir" ]; then echo >&2 '$mountdir must be set' exit 1 @@ -12,9 +21,12 @@ fi export PATH=${rundir%%/}:/bin:/usr/bin:/sbin:/usr/sbin:/sw/bin -if [ $# != 2 -o ! -d "$1" -o ! -d "$2" ]; then - echo >&2 "Usage: $0 " - echo >&2 "Example: $0 / /" +if [ ! -d "$1" -o ! -d "$2" ]; then + echo >&2 "Usage: $0 []" + echo >&2 " source-dir - directory on backup disks to restore from" + echo >&2 " target-dir - directory to restore files to" + echo >&2 " mnt-dir - directory where backup disk is mounted (optional)" + echo >&2 "Example: $0 / / /mnt/cdrom" exit 1 fi @@ -34,7 +46,9 @@ for date in $dates; do success=false while ! $success; do eject $device + [ $? != 0 ] && err "Cannot eject the disk. Drive is busy. Run lsof $mountdir to see why." echo >&2 "Please insert backup disk: $date" + echo >&2 "Press Enter to continue" read bogus eject -t $device @@ -44,10 +58,10 @@ for date in $dates; do if grep -q $date ${mountdir%%/}/backup-status.txt; then success=true else - echo >&2 "This doesn't seem to be the right disk." + echo "This doesn't seem to be the right disk." fi done rsyncopts="-W -H -S -l -p -t -g -o -0 --files-from=- --stats --progress" - cat $dbfile | files-from-date.sh $date | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ + cat $dbfile | files-from-date.sh $date | grep -z -e "${1}" | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ done