From: Carl Baldwin Date: Fri, 25 Nov 2005 18:25:05 +0000 (-0700) Subject: Merge a fix to release-0.1 X-Git-Tag: release-0.4~15 X-Git-Url: http://git.pippins.net/embedvideo/.git/static/gitweb.js?a=commitdiff_plain;h=31e73cf58bbda828b42c96e0c02eda6435d4f929;hp=89d2e005aadc06c608545fb477356cb3b4d12bed;p=backups%2F.git Merge a fix to release-0.1 --- diff --git a/scripts/burn-imgs.sh b/scripts/burn-imgs.sh index 5d030bf..bffc5e9 100755 --- a/scripts/burn-imgs.sh +++ b/scripts/burn-imgs.sh @@ -3,8 +3,13 @@ export PATH=$(dirname $0):/bin:/usr/bin:/sbin cronstopstart="/etc/init.d/cron" + +# source the default configuration . config.sh +# source the system specific configuration +[ -f /etc/lsbackups.conf ] && . /etc/lsbackups.conf + # If the noburn file is there then don't burn. [ -f "$noburnfile" ] && exit 0 diff --git a/scripts/config.sh b/scripts/config.sh index 056bb2c..c3b4a26 100755 --- a/scripts/config.sh +++ b/scripts/config.sh @@ -23,3 +23,11 @@ backupdirs=" /var/lib/iptables /var/lib/mailman " + +excludedirs=" +" + +function err() { + echo 2>&1 "-E- $1" + exit 1 +} diff --git a/scripts/cron-burn.sh b/scripts/cron-burn.sh index 4967935..4fe9a0b 100755 --- a/scripts/cron-burn.sh +++ b/scripts/cron-burn.sh @@ -2,8 +2,12 @@ export PATH=$(dirname $0):/bin:/usr/bin:/sbin +# source the default configuration . config.sh +# source the system specific configuration +[ -f /etc/lsbackups.conf ] && . /etc/lsbackups.conf + # burn-imgs.sh needs to be detached so that it can stop and start cron without # dying itself. diff --git a/scripts/cron-pack.sh b/scripts/cron-pack.sh index 2127e42..906b010 100755 --- a/scripts/cron-pack.sh +++ b/scripts/cron-pack.sh @@ -2,8 +2,12 @@ export PATH=$(dirname $0):/bin:/usr/bin:/sbin +# source the default configuration . config.sh +# source the system specific configuration +[ -f /etc/lsbackups.conf ] && . /etc/lsbackups.conf + days=15 minutes=$(($days * 1440 - 60)) diff --git a/scripts/eject-disk.sh b/scripts/eject-disk.sh index 32220f1..811a456 100755 --- a/scripts/eject-disk.sh +++ b/scripts/eject-disk.sh @@ -2,8 +2,12 @@ export PATH=$(dirname $0):/bin:/usr/bin:/sbin +# source the default configuration . config.sh +# source the system specific configuration +[ -f /etc/lsbackups.conf ] && . /etc/lsbackups.conf + eject $dev rm -f $noburnfile diff --git a/scripts/pack-image.sh b/scripts/pack-image.sh index ec7b1da..9a06f71 100755 --- a/scripts/pack-image.sh +++ b/scripts/pack-image.sh @@ -4,52 +4,104 @@ scriptsdir=$(dirname $0) export PATH=$scriptsdir:/bin:/usr/bin:/sbin:/usr/sbin +# source the default configuration . config.sh +# source the system specific configuration +[ -f /etc/lsbackups.conf ] && . /etc/lsbackups.conf + # file locations and other values today=$(date +%Y%m%d%H%M%S) isoimage="$imagedir/$today.img" isomountdir="$isoimage.mnt" restorescript="$scriptsdir/restore.sh" -echo "Creating directories" +echo "-> Creating directories" mkdir --mode=700 -p $datadir $imagedir $isomountdir $tmpdir +if [ $? != 0 ] +then + if test -d $isomountdir + then + rm -rf $isomountdir + fi + err "Unable to create the following directories: + $datadir $imagedir $isomountdir $tmpdir" +fi + +echo "-> Creating the iso image in $isoimage" +dd of=$isoimage bs=1M count=0 seek=4440 + +[ $? != 0 ] && err "dd failed to create $isoimage" -echo "Creating the iso image in $isoimage" -dd if=/dev/null of=$isoimage bs=1M count=0 seek=4440 mke2fs -b 2048 -F $isoimage -echo "Mounting the iso image" +if [ $? != 0 ] +then + rm -rf $isomountdir $isoimage + err "Unable to create the iso image: $isoimage" +fi + +echo "-> Mounting the iso image" mount -t ext2 -o loop $isoimage $isomountdir +if [ $? != 0 ] +then + rm -rf $isomountdir $isoimage + err "Unable to mount the iso image: $isoimage -> $isomountdir" +fi + +echo "-> Directories being backedup and excluded:" +echo "backupdirs: $backupdirs" +echo "excludedirs: $excludedirs" -echo "Running find to get the status of files" +echo "-> Running find to get the status of files" { for type in d f l; do findformat="$type %#m %u %g %s %CY%Cm%Cd%CH%CM%CS 0 %p\0" - find $backupdirs -type $type -printf "$findformat" + if [ -z $excludeddirs ] + then + find $backupdirs -type $type -printf "$findformat" + else + regex=`echo $excludedirs | sed -e 's/ /.*\\\\|/g'` + regex=`echo "'\($regex.*\)'"` + find $backupdirs -type $type -o -regex $regex -prune -o -printf "$findformat" + fi done } > $currentfiles -echo "Determining list of files to backup with lsbackups" +echo "-> Determining list of files to backup with lsbackups" { # lsbackups expects the current date followed by a null before the list of files printf "$today\0" cat $currentfiles } | lsbackups > $backups 2>$statusfile -echo "Running rsync to pack the image" +echo "-> Running rsync to pack the image" rsyncopts="-W -H -S -l -p -t -g -o -0 --files-from=- --stats --progress" cat $backups | rsync $rsyncopts / $isomountdir +if [ $? != 0 ] +then + umount $isomountdir + rm -rf $isomountdir $isoimage + err "Unable to rsync to pack the image" +fi -echo "Copying over database and status file" +echo "-> Copying over database and status file" cp $statusfile $backupdb $restorescript $isomountdir -echo "Unmounting image" +[ $? != 0 ] && err "Unable to copy the database and status file" + +echo "-> Unmounting image" umount $isomountdir -echo "Calculating md5sum for image" +[ $? != 0 ] && err "Unable to unmount the iso dir: $isomountdir" + +echo "-> Calculating md5sum for image" md5sum $isoimage | awk '{print$1}' > $isoimage.md5sum +[ $? != 0 ] && err "Unable to calculate the md5sum for this image: $isoimage" + cat $statusfile | mailx -s "DVD image available to burn - $today" $mailto echo $today > $lastbackupfile + +