diff options
| author | Micah Anderson <micah@riseup.net> | 2005-05-06 01:17:25 +0000 | 
|---|---|---|
| committer | Micah Anderson <micah@riseup.net> | 2005-05-06 01:17:25 +0000 | 
| commit | 85cb64d249b2a31a401025b48167cab394989cb4 (patch) | |
| tree | 57d3e294d9e528a468df10174309a96a5f5160e8 | |
| parent | a917f89b1d0ef7b6ba08ae7c3b341683805b04a7 (diff) | |
| download | backupninja-85cb64d249b2a31a401025b48167cab394989cb4.tar.gz backupninja-85cb64d249b2a31a401025b48167cab394989cb4.tar.bz2 | |
Implemented fix to report errors (via cron) on fatal problems in the main backupninja script
| -rwxr-xr-x | backupninja | 29 | ||||
| -rw-r--r-- | etc/cron.d/backupninja | 2 | 
2 files changed, 26 insertions, 5 deletions
| diff --git a/backupninja b/backupninja index 380ffcc..687571b 100755 --- a/backupninja +++ b/backupninja @@ -159,9 +159,11 @@ function check_perms() {  	local perms=`ls -ld $file`  	perms=${perms:4:6}  	if [ "$perms" != "------" ]; then +		echo "Configuration files must not be group or world readable! Dying on file $file"  		fatal "Configuration files must not be group or world readable! Dying on file $file"  	fi  	if [ `ls -ld $file | awk '{print $3}'` != "root" ]; then +		echo "Configuration files must be owned by root! Dying on file $file"  		fatal "Configuration files must be owned by root! Dying on file $file"  	fi  } @@ -351,6 +353,7 @@ while [ $# -ge 1 ]; do  			if [ -f $2 ]; then  				conffile=$2  			else +				echo "-f|--conffile option must be followed by an existing filename"  				fatal "-f|--conffile option must be followed by an existing filename"  				usage  			fi @@ -363,6 +366,7 @@ while [ $# -ge 1 ]; do  				singlerun=$2  				processnow=1  			else +				echo "--run option must be fallowed by a backupninja action file"  				fatal "--run option must be fallowed by a backupninja action file"  				usage  			fi @@ -370,6 +374,7 @@ while [ $# -ge 1 ]; do  			;;  		*)  			debug=1 +			echo "Unknown option $1"  			fatal "Unknown option $1"  			usage  			exit @@ -385,10 +390,22 @@ done  ## Load and confirm basic configuration values  # bootstrap -[ -r "$conffile" ] || fatal "Configuration file $conffile not found." +if [ ! -r "$conffile" ]; then +	echo "Configuration file $conffile not found."  +	fatal "Configuration file $conffile not found." +fi +  scriptdir=`grep scriptdirectory $conffile | awk '{print $3}'` -[ -n "$scriptdir" ] || fatal "Cound not find entry 'scriptdirectory' in $conffile" -[ -d "$scriptdir" ] || fatal "Script directory $scriptdir not found." +if [ ! -n "$scriptdir" ]; then +	echo "Cound not find entry 'scriptdirectory' in $conffile"  +	fatal "Cound not find entry 'scriptdirectory' in $conffile" +fi + +if [ ! -d "$scriptdir" ]; then +	echo "Script directory $scriptdir not found."  +	fatal "Script directory $scriptdir not found." +fi +  setfile $conffile  # get global config options (second param is the default) @@ -410,7 +427,11 @@ getconf MYSQLDUMP /usr/bin/mysqldump  getconf GZIP /bin/gzip  getconf RSYNC /usr/bin/rsync -[ -d "$configdirectory" ] || fatal "Configuration directory '$configdirectory' not found." +if [ ! -d "$configdirectory" ]; then +	echo "Configuration directory '$configdirectory' not found." +	fatal "Configuration directory '$configdirectory' not found." +fi +  [ -f "$logfile" ] || touch $logfile  if [ "$UID" != "0" ]; then diff --git a/etc/cron.d/backupninja b/etc/cron.d/backupninja index 82f21f9..b612bd8 100644 --- a/etc/cron.d/backupninja +++ b/etc/cron.d/backupninja @@ -3,4 +3,4 @@  PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin  # run backupninja every hour on the hour -00 * * * * root if [ -x /usr/sbin/backupninja -a -f /etc/backupninja.conf ]; then /usr/sbin/backupninja; fi +00 * * * * root if [ -x /usr/sbin/backupninja ]; then /usr/sbin/backupninja; fi | 
