fix timestamp double-bracket

This commit is contained in:
Asif Bacchus 2019-07-26 03:16:55 -06:00
parent 8edd833544
commit 8e30cb4048

View File

@ -53,32 +53,32 @@ cleanup () {
if [ "$err503Copied" -eq 1 ]; then if [ "$err503Copied" -eq 1 ]; then
if ! rm -f "$webroot/$err503File" 2>>"$logFile"; then if ! rm -f "$webroot/$err503File" 2>>"$logFile"; then
printf "${warn}[%s] -- [WARNING] Could not remove 503 error page." \ printf "${warn}[%s] -- [WARNING] Could not remove 503 error page." \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf " Web interface will not function until this file is " \ printf " Web interface will not function until this file is " \
>> "$logFile" >> "$logFile"
printf "removed --${norm}\n" >> "$logFile" printf "removed --${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
else else
printf "${cyan}[%s] -- [INFO] 503 error page removed --${norm}\n" \ printf "${cyan}[%s] -- [INFO] 503 error page removed --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
fi fi
fi fi
if [ "$sqlCopied" -eq 1 ]; then if [ "$sqlCopied" -eq 1 ]; then
if ! rm -rf "$sqlDumpDir" 2>>"$logFile"; then if ! rm -rf "$sqlDumpDir" 2>>"$logFile"; then
printf "${warn}[%s] -- [WARNING] Could not remove temporary " \ printf "${warn}[%s] -- [WARNING] Could not remove temporary " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "SQL dump directory at %s. " "$sqlDumpDir" >> "$logFile" printf "SQL dump directory at %s. " "$sqlDumpDir" >> "$logFile"
printf "Remove manually to free up space.${norm}\n" >> "$logFile" printf "Remove manually to free up space.${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
else else
printf "${cyan}[%s] -- [INFO] Temporary SQL dump directory " \ printf "${cyan}[%s] -- [INFO] Temporary SQL dump directory " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "removed --${norm}\n" >> "$logFile" printf "removed --${norm}\n" >> "$logFile"
fi fi
fi fi
if [ "$offlineBackup" -eq 1 ]; then if [ "$offlineBackup" -eq 1 ]; then
printf "${cyan}[%s] -- [INFO] Starting seafile services --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Starting seafile services --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
seafSvc start seafSvc start
fi fi
} }
@ -86,11 +86,11 @@ cleanup () {
# call cleanup and then exit with error report # call cleanup and then exit with error report
exitError () { exitError () {
printf "${err}[%s] -- [ERROR] %s: %s --${norm}\n" \ printf "${err}[%s] -- [ERROR] %s: %s --${norm}\n" \
"[$(stamp)]" "$1" "$2" >> "$logFile" "$(stamp)" "$1" "$2" >> "$logFile"
cleanup cleanup
# note script completion with error # note script completion with error
printf "${err}[%s] --- %s execution completed with error ---${norm}\n" \ printf "${err}[%s] --- %s execution completed with error ---${norm}\n" \
"[$(stamp)]" "$scriptName" >> "$logFile" "$(stamp)" "$scriptName" >> "$logFile"
exit "$1" exit "$1"
} }
@ -178,26 +178,26 @@ seafSvc () {
exitError 100 "Could not start ${seafService}" exitError 100 "Could not start ${seafService}"
else else
printf "${cyan}[%s] -- [INFO] Started service: %s --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Started service: %s --${norm}\n" \
"[$(stamp)]" "$seafService" >> "$logFile" "$(stamp)" "$seafService" >> "$logFile"
fi fi
if ! systemctl start "${seafHub}" >> "$logFile" 2>&1; then if ! systemctl start "${seafHub}" >> "$logFile" 2>&1; then
exitError 101 "Could not start ${seafHub}" exitError 101 "Could not start ${seafHub}"
else else
printf "${cyan}[%s] -- [INFO] Started service: %s --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Started service: %s --${norm}\n" \
"[$(stamp)]" "$seafHub" >> "$logFile" "$(stamp)" "$seafHub" >> "$logFile"
fi fi
elif [ "$1" = "stop" ]; then elif [ "$1" = "stop" ]; then
if ! systemctl stop "${seafHub}" >> "$logFile" 2>&1; then if ! systemctl stop "${seafHub}" >> "$logFile" 2>&1; then
exitError 103 "Could not stop ${seafHub}" exitError 103 "Could not stop ${seafHub}"
else else
printf "${cyan}[%s] -- [INFO] Stopped service: %s --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Stopped service: %s --${norm}\n" \
"[$(stamp)]" "$seafService" >> "$logFile" "$(stamp)" "$seafService" >> "$logFile"
fi fi
if ! systemctl stop "${seafService}" >> "$logFile" 2>&1; then if ! systemctl stop "${seafService}" >> "$logFile" 2>&1; then
exitError 102 "Could not stop ${seafService}" exitError 102 "Could not stop ${seafService}"
else else
printf "${cyan}[%s] -- [INFO] Stopped service: %s --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Stopped service: %s --${norm}\n" \
"[$(stamp)]" "$seafHub" >> "$logFile" "$(stamp)" "$seafHub" >> "$logFile"
fi fi
fi fi
} }
@ -210,11 +210,11 @@ stamp () {
# same as exitError but for signal captures # same as exitError but for signal captures
trapExit () { trapExit () {
printf "${err}[%s] -- [ERROR] 99: Caught signal --${norm}\n" \ printf "${err}[%s] -- [ERROR] 99: Caught signal --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
cleanup cleanup
# note script completion with error # note script completion with error
printf "${err}[%s] --- %s execution was terminated via signal ---${norm}\n" \ printf "${err}[%s] --- %s execution was terminated via signal ---${norm}\n" \
"[$(stamp)]" "$scriptName" >> "$logFile" "$(stamp)" "$scriptName" >> "$logFile"
exit 99 exit 99
} }
@ -432,25 +432,25 @@ fi
### start logging ### start logging
printf "${magenta}[%s] --- Start %s execution ---${norm}\n" \ printf "${magenta}[%s] --- Start %s execution ---${norm}\n" \
"[$(stamp)]" "$scriptName" >> "$logFile" "$(stamp)" "$scriptName" >> "$logFile"
printf "${cyan}[%s] -- [INFO] Log located at ${yellow}%s${cyan} --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Log located at ${yellow}%s${cyan} --${norm}\n" \
"[$(stamp)]" "$logFile" >> "$logFile" "$(stamp)" "$logFile" >> "$logFile"
### 503 functionality ### 503 functionality
if [ "$use503" -eq 1 ]; then if [ "$use503" -eq 1 ]; then
printf "${cyan}[%s] -- [INFO] Copying 503 error page to " \ printf "${cyan}[%s] -- [INFO] Copying 503 error page to " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "webroot -- ${norm}\n" >> "$logFile" printf "webroot -- ${norm}\n" >> "$logFile"
if ! \cp --force "${err503Path}" "${webroot}/${err503File}" 2>> "$logFile" if ! \cp --force "${err503Path}" "${webroot}/${err503File}" 2>> "$logFile"
then then
printf "${warn}[%s] -- [WARNING] Failed to copy 503 error page. " \ printf "${warn}[%s] -- [WARNING] Failed to copy 503 error page. " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "Web users will NOT be notified --${norm}\n" >> "$logFile" printf "Web users will NOT be notified --${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
else else
printf "${ok}[%s] -- [SUCCESS] 503 error page copied --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] 503 error page copied --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
# set cleanup flag # set cleanup flag
err503Copied=1 err503Copied=1
fi fi
@ -460,7 +460,7 @@ fi
### stop seahub and seafile service if offline backup requested ### stop seahub and seafile service if offline backup requested
if [ "$offlineBackup" -eq 1 ]; then if [ "$offlineBackup" -eq 1 ]; then
printf "${cyan}[%s] -- [INFO] Stopping seafile services --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Stopping seafile services --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
seafSvc stop seafSvc stop
fi fi
@ -478,7 +478,7 @@ case "${configDetails}" in
;; ;;
esac esac
printf "${cyan}[%s] -- [INFO] ${yellow}%s${cyan} imported --${norm}\n" \ printf "${cyan}[%s] -- [INFO] ${yellow}%s${cyan} imported --${norm}\n" \
"[$(stamp)]" "$configDetails" >> "$logFile" "$(stamp)" "$configDetails" >> "$logFile"
### dump sql databases ### dump sql databases
@ -504,7 +504,7 @@ fi
## create tmp directory and generate dumpfile names ## create tmp directory and generate dumpfile names
printf "${cyan}[%s] -- [INFO] Dumping SQL databases --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Dumping SQL databases --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
# create temporary directory to dump files before borg backup # create temporary directory to dump files before borg backup
if ! sqlDumpDir=$( mktemp -d 2>>"$logFile" ); then if ! sqlDumpDir=$( mktemp -d 2>>"$logFile" ); then
exitError 111 "Could not create temporary directory to dump SQL files" exitError 111 "Could not create temporary directory to dump SQL files"
@ -512,7 +512,7 @@ fi
# set cleanup flag # set cleanup flag
sqlCopied=1 sqlCopied=1
printf "${cyan}[%s] -- [INFO] SQL dump files will be temporarily stored in:" \ printf "${cyan}[%s] -- [INFO] SQL dump files will be temporarily stored in:" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "\n${yellow}%s/${cyan} --${norm}\n" "$sqlDumpDir" >> "$logFile" printf "\n${yellow}%s/${cyan} --${norm}\n" "$sqlDumpDir" >> "$logFile"
# create unique names for database dump files # create unique names for database dump files
sqlDump_ccnet="backup-$(date +%Y%m%d_%H%M%S)_${ccnetDB_name}.sql" sqlDump_ccnet="backup-$(date +%Y%m%d_%H%M%S)_${ccnetDB_name}.sql"
@ -538,17 +538,17 @@ if ! mysqldump -h"${sqlServer}" -u"${sqlUser}" -p"${sqlPass}" \
exitError 117 "Could not dump ${seahubDB_name} database" exitError 117 "Could not dump ${seahubDB_name} database"
fi fi
printf "${ok}[%s] -- [SUCCESS] SQL databases dumped successfully --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] SQL databases dumped successfully --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
### pre-backup tasks completed -- move to borg tasks ### pre-backup tasks completed -- move to borg tasks
printf "${ok}[%s] -- [SUCCESS] Pre-backup tasks completed --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] Pre-backup tasks completed --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
### Run borg variable checks ### Run borg variable checks
printf "${cyan}[%s] -- [INFO] Verifying supplied borg details --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Verifying supplied borg details --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
## verify borg base directory ## verify borg base directory
if [ -z "${borgBaseDir}" ]; then if [ -z "${borgBaseDir}" ]; then
@ -640,7 +640,7 @@ if [ ! -d "${borgBaseDir}/tmp" ]; then
exitError 132 "Unable to create borg ${borgBaseDir}/tmp directory" exitError 132 "Unable to create borg ${borgBaseDir}/tmp directory"
else else
printf "${cyan}[%s] -- [INFO] Created ${yellow}%s/tmp " \ printf "${cyan}[%s] -- [INFO] Created ${yellow}%s/tmp " \
"[$(stamp)]" "${borgBaseDir}" >> "$logFile" "$(stamp)" "${borgBaseDir}" >> "$logFile"
printf "${cyan}--${norm}\n" >> "$logFile" printf "${cyan}--${norm}\n" >> "$logFile"
fi fi
fi fi
@ -673,18 +673,18 @@ fi
# execute borg # execute borg
printf "${cyan}[%s] -- [INFO] Executing borg backup operation --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Executing borg backup operation --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
${borgCMD} 2>> "$logFile" ${borgCMD} 2>> "$logFile"
borgResult="$?" borgResult="$?"
## check borg exit status ## check borg exit status
if [ "$borgResult" -eq 0 ]; then if [ "$borgResult" -eq 0 ]; then
printf "${ok}[%s] -- [SUCCESS] Borg backup completed " \ printf "${ok}[%s] -- [SUCCESS] Borg backup completed " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "successfully --${norm}\n" >> "$logFile" printf "successfully --${norm}\n" >> "$logFile"
elif [ "$borgResult" -eq 1 ]; then elif [ "$borgResult" -eq 1 ]; then
printf "${warn}[%s] -- [WARNING] Borg completed with warnings. " \ printf "${warn}[%s] -- [WARNING] Borg completed with warnings. " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "Review this logfile for details --${norm}\n" >> "$logFile" printf "Review this logfile for details --${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
elif [ "$borgResult" -ge 2 ]; then elif [ "$borgResult" -ge 2 ]; then
@ -693,7 +693,7 @@ elif [ "$borgResult" -ge 2 ]; then
exitError 138 "$err_1 $err_2" exitError 138 "$err_1 $err_2"
else else
printf "${warn}[%s] -- [WARNING] Borg exited with unknown return code. " \ printf "${warn}[%s] -- [WARNING] Borg exited with unknown return code. " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "Review this logfile for details --${norm}\n" >> "$logFile" printf "Review this logfile for details --${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
fi fi
@ -702,13 +702,13 @@ fi
### execute borg prune if paramters are provided, otherwise skip with a warning ### execute borg prune if paramters are provided, otherwise skip with a warning
if [ -n "${borgPruneSettings}" ]; then if [ -n "${borgPruneSettings}" ]; then
printf "${cyan}[%s] -- [INFO] Executing borg prune operation --${norm}\n" \ printf "${cyan}[%s] -- [INFO] Executing borg prune operation --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
borg prune --show-rc -v ${borgPruneParams} ${borgPruneSettings} \ borg prune --show-rc -v ${borgPruneParams} ${borgPruneSettings} \
2>> "$logFile" 2>> "$logFile"
borgPruneResult="$?" borgPruneResult="$?"
else else
printf "${warn}[%s] -- [WARNING] No prune parameters provided. " \ printf "${warn}[%s] -- [WARNING] No prune parameters provided. " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "Your archive will continue growing with each backup --${norm}\n" \ printf "Your archive will continue growing with each backup --${norm}\n" \
>> "$logFile" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
@ -718,10 +718,10 @@ fi
if [ -n "${borgPruneResult}" ]; then if [ -n "${borgPruneResult}" ]; then
if [ "${borgPruneResult}" -eq 0 ]; then if [ "${borgPruneResult}" -eq 0 ]; then
printf "${ok}[%s] -- [SUCCESS] Borg prune completed --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] Borg prune completed --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
elif [ "$borgPruneResult" -eq 1 ]; then elif [ "$borgPruneResult" -eq 1 ]; then
printf "${warn}[%s] -- [WARNING] Borg prune completed with warnings. " \ printf "${warn}[%s] -- [WARNING] Borg prune completed with warnings. " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "Review this logfile for details --${norm}\n" >> "$logFile" printf "Review this logfile for details --${norm}\n" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
elif [ "$borgPruneResult" -ge 2 ]; then elif [ "$borgPruneResult" -ge 2 ]; then
@ -730,7 +730,7 @@ if [ -n "${borgPruneResult}" ]; then
exitError 139 "$err_1 $err_2" exitError 139 "$err_1 $err_2"
else else
printf "${warn}[%s] -- [WARNING] Borg prune exited with an unknown " \ printf "${warn}[%s] -- [WARNING] Borg prune exited with an unknown " \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "return code. Review this logfile for details --${norm}\n" \ printf "return code. Review this logfile for details --${norm}\n" \
>> "$logFile" >> "$logFile"
warnCount=$((warnCount+1)) warnCount=$((warnCount+1))
@ -742,16 +742,16 @@ fi
# note successful completion of borg commands # note successful completion of borg commands
printf "${ok}[%s] -- [SUCCESS] Backup operations completed --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] Backup operations completed --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
# cleanup # cleanup
cleanup cleanup
# note complete success, tally warnings and exit # note complete success, tally warnings and exit
printf "${ok}[%s] -- [SUCCESS] All processes completed --${norm}\n" \ printf "${ok}[%s] -- [SUCCESS] All processes completed --${norm}\n" \
"[$(stamp)]" >> "$logFile" "$(stamp)" >> "$logFile"
printf "${magenta}[%s] --- %s execution completed ---${norm}\n" \ printf "${magenta}[%s] --- %s execution completed ---${norm}\n" \
"[$(stamp)]" "$scriptName" >> "$logFile" "$(stamp)" "$scriptName" >> "$logFile"
if [ "$warnCount" -gt 0 ]; then if [ "$warnCount" -gt 0 ]; then
printf "${warn}%s warnings issued!${norm}\n" "${warnCount}" >> "$logFile" printf "${warn}%s warnings issued!${norm}\n" "${warnCount}" >> "$logFile"
else else