mirror of
https://github.com/deajan/obackup.git
synced 2025-01-12 15:13:53 +01:00
Fixed bogus backup when no recursive directories set
This commit is contained in:
parent
eead765d69
commit
bc396270df
122
dev/n_obackup.sh
122
dev/n_obackup.sh
@ -7,7 +7,7 @@ PROGRAM="obackup"
|
|||||||
AUTHOR="(C) 2013-2016 by Orsiris de Jong"
|
AUTHOR="(C) 2013-2016 by Orsiris de Jong"
|
||||||
CONTACT="http://www.netpower.fr/obackup - ozy@netpower.fr"
|
CONTACT="http://www.netpower.fr/obackup - ozy@netpower.fr"
|
||||||
PROGRAM_VERSION=2.1-dev
|
PROGRAM_VERSION=2.1-dev
|
||||||
PROGRAM_BUILD=2017010205
|
PROGRAM_BUILD=2017010206
|
||||||
IS_STABLE=no
|
IS_STABLE=no
|
||||||
|
|
||||||
include #### OFUNCTIONS FULL SUBSET ####
|
include #### OFUNCTIONS FULL SUBSET ####
|
||||||
@ -455,70 +455,74 @@ function ListRecursiveBackupDirectories {
|
|||||||
local excluded
|
local excluded
|
||||||
local fileArray
|
local fileArray
|
||||||
|
|
||||||
if [ "$RECURSIVE_DIRECTORY_LIST" == "" ]; then
|
if [ "$RECURSIVE_DIRECTORY_LIST" != "" ]; then
|
||||||
fi
|
|
||||||
# Return values from subfunctions can be 0 (no error), 1 (only errors) or 2 (some errors). Do process output except on 1 return code
|
|
||||||
Logger "Listing directories to backup." "NOTICE"
|
|
||||||
if [ "$BACKUP_TYPE" == "local" ] || [ "$BACKUP_TYPE" == "push" ]; then
|
|
||||||
_ListRecursiveBackupDirectoriesLocal &
|
|
||||||
WaitForTaskCompletion $! $SOFT_MAX_EXEC_TIME_FILE_TASK $HARD_MAX_EXEC_TIME_FILE_TASK $SLEEP_TIME $KEEP_LOGGING true true false
|
|
||||||
if [ $? -eq 1 ]; then
|
|
||||||
output_file=""
|
|
||||||
else
|
|
||||||
output_file="$RUN_DIR/$PROGRAM._ListRecursiveBackupDirectoriesLocal.$SCRIPT_PID.$TSTAMP"
|
|
||||||
fi
|
|
||||||
elif [ "$BACKUP_TYPE" == "pull" ]; then
|
|
||||||
_ListRecursiveBackupDirectoriesRemote &
|
|
||||||
WaitForTaskCompletion $! $SOFT_MAX_EXEC_TIME_FILE_TASK $HARD_MAX_EXEC_TIME_FILE_TASK $SLEEP_TIME $KEEP_LOGGING true true false
|
|
||||||
if [ $? -eq 1 ]; then
|
|
||||||
output_file=""
|
|
||||||
else
|
|
||||||
output_file="$RUN_DIR/$PROGRAM._ListRecursiveBackupDirectoriesRemote.$SCRIPT_PID.$TSTAMP"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f "$output_file" ]; then
|
# Return values from subfunctions can be 0 (no error), 1 (only errors) or 2 (some errors). Do process output except on 1 return code
|
||||||
while read -r line; do
|
Logger "Listing directories to backup." "NOTICE"
|
||||||
file_exclude=0
|
if [ "$BACKUP_TYPE" == "local" ] || [ "$BACKUP_TYPE" == "push" ]; then
|
||||||
IFS=$PATH_SEPARATOR_CHAR read -r -a fileArray <<< "$RECURSIVE_EXCLUDE_LIST"
|
_ListRecursiveBackupDirectoriesLocal &
|
||||||
for excluded in "${fileArray[@]}"; do
|
WaitForTaskCompletion $! $SOFT_MAX_EXEC_TIME_FILE_TASK $HARD_MAX_EXEC_TIME_FILE_TASK $SLEEP_TIME $KEEP_LOGGING true true false
|
||||||
if [ "$excluded" == "$line" ]; then
|
if [ $? -eq 1 ]; then
|
||||||
file_exclude=1
|
output_file=""
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
if [ $file_exclude -eq 0 ]; then
|
|
||||||
if [ "$FILE_RECURSIVE_BACKUP_TASKS" == "" ]; then
|
|
||||||
FILE_SIZE_LIST_LOCAL="\"$line\""
|
|
||||||
FILE_SIZE_LIST_REMOTE="\'$line\'"
|
|
||||||
FILE_RECURSIVE_BACKUP_TASKS="$line"
|
|
||||||
else
|
|
||||||
FILE_SIZE_LIST_LOCAL="$FILE_SIZE_LIST_LOCAL \"$line\""
|
|
||||||
FILE_SIZE_LIST_REMOTE="$FILE_SIZE_LIST_REMOTE \'$line\'"
|
|
||||||
FILE_RECURSIVE_BACKUP_TASKS="$FILE_RECURSIVE_BACKUP_TASKS$PATH_SEPARATOR_CHAR$line"
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
FILE_RECURSIVE_EXCLUDED_TASKS="$FILE_RECURSIVE_EXCLUDED_TASKS$PATH_SEPARATOR_CHAR$line"
|
output_file="$RUN_DIR/$PROGRAM._ListRecursiveBackupDirectoriesLocal.$SCRIPT_PID.$TSTAMP"
|
||||||
fi
|
fi
|
||||||
done < "$output_file"
|
elif [ "$BACKUP_TYPE" == "pull" ]; then
|
||||||
|
_ListRecursiveBackupDirectoriesRemote &
|
||||||
|
WaitForTaskCompletion $! $SOFT_MAX_EXEC_TIME_FILE_TASK $HARD_MAX_EXEC_TIME_FILE_TASK $SLEEP_TIME $KEEP_LOGGING true true false
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
output_file=""
|
||||||
|
else
|
||||||
|
output_file="$RUN_DIR/$PROGRAM._ListRecursiveBackupDirectoriesRemote.$SCRIPT_PID.$TSTAMP"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "$output_file" ]; then
|
||||||
|
while read -r line; do
|
||||||
|
file_exclude=0
|
||||||
|
IFS=$PATH_SEPARATOR_CHAR read -r -a fileArray <<< "$RECURSIVE_EXCLUDE_LIST"
|
||||||
|
for excluded in "${fileArray[@]}"; do
|
||||||
|
if [ "$excluded" == "$line" ]; then
|
||||||
|
file_exclude=1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ $file_exclude -eq 0 ]; then
|
||||||
|
if [ "$FILE_RECURSIVE_BACKUP_TASKS" == "" ]; then
|
||||||
|
FILE_SIZE_LIST_LOCAL="\"$line\""
|
||||||
|
FILE_SIZE_LIST_REMOTE="\'$line\'"
|
||||||
|
FILE_RECURSIVE_BACKUP_TASKS="$line"
|
||||||
|
else
|
||||||
|
FILE_SIZE_LIST_LOCAL="$FILE_SIZE_LIST_LOCAL \"$line\""
|
||||||
|
FILE_SIZE_LIST_REMOTE="$FILE_SIZE_LIST_REMOTE \'$line\'"
|
||||||
|
FILE_RECURSIVE_BACKUP_TASKS="$FILE_RECURSIVE_BACKUP_TASKS$PATH_SEPARATOR_CHAR$line"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
FILE_RECURSIVE_EXCLUDED_TASKS="$FILE_RECURSIVE_EXCLUDED_TASKS$PATH_SEPARATOR_CHAR$line"
|
||||||
|
fi
|
||||||
|
done < "$output_file"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
IFS=$PATH_SEPARATOR_CHAR read -r -a fileArray <<< "$DIRECTORY_LIST"
|
if [ "$DIRECTORY_LIST" != "" ]; then
|
||||||
for directory in "${fileArray[@]}"; do
|
|
||||||
if [ "$FILE_SIZE_LIST_LOCAL" == "" ]; then
|
|
||||||
FILE_SIZE_LIST_LOCAL="\"$directory\""
|
|
||||||
FILE_SIZE_LIST_REMOTE="\'$directory\'"
|
|
||||||
else
|
|
||||||
FILE_SIZE_LIST_LOCAL="$FILE_SIZE_LIST_LOCAL \"$directory\""
|
|
||||||
FILE_SIZE_LIST_REMOTE="$FILE_SIZE_LIST_REMOTE \'$directory\'"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$FILE_BACKUP_TASKS" == "" ]; then
|
IFS=$PATH_SEPARATOR_CHAR read -r -a fileArray <<< "$DIRECTORY_LIST"
|
||||||
FILE_BACKUP_TASKS="$directory"
|
for directory in "${fileArray[@]}"; do
|
||||||
else
|
if [ "$FILE_SIZE_LIST_LOCAL" == "" ]; then
|
||||||
FILE_BACKUP_TASKS="$FILE_BACKUP_TASKS$PATH_SEPARATOR_CHAR$directory"
|
FILE_SIZE_LIST_LOCAL="\"$directory\""
|
||||||
fi
|
FILE_SIZE_LIST_REMOTE="\'$directory\'"
|
||||||
done
|
else
|
||||||
|
FILE_SIZE_LIST_LOCAL="$FILE_SIZE_LIST_LOCAL \"$directory\""
|
||||||
|
FILE_SIZE_LIST_REMOTE="$FILE_SIZE_LIST_REMOTE \'$directory\'"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$FILE_BACKUP_TASKS" == "" ]; then
|
||||||
|
FILE_BACKUP_TASKS="$directory"
|
||||||
|
else
|
||||||
|
FILE_BACKUP_TASKS="$FILE_BACKUP_TASKS$PATH_SEPARATOR_CHAR$directory"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function _GetDirectoriesSizeLocal {
|
function _GetDirectoriesSizeLocal {
|
||||||
|
Loading…
Reference in New Issue
Block a user