]> git.llucax.com Git - software/bacap.git/commitdiff
Fix overriding config per-host
authorLeandro Lucarella <luca@llucax.com>
Sat, 25 Sep 2021 10:19:47 +0000 (12:19 +0200)
committerLeandro Lucarella <luca@llucax.com>
Sat, 25 Sep 2021 10:20:50 +0000 (12:20 +0200)
All the config has to be re-evaluated when overriding a host's config.

bacap

diff --git a/bacap b/bacap
index db92c50d805001327e5edadb857e132c17ba5cfb..30983f5dfe850edea82535c993b3cee7506ad7c8 100755 (executable)
--- a/bacap
+++ b/bacap
@@ -50,26 +50,27 @@ BACAPRC=$1
 
 # Load configuration files
 load_config() {
 
 # Load configuration files
 load_config() {
+       extra_config=$1
        source "/etc/bacaprc" 2> /dev/null
        source "/etc/bacap/bacaprc" 2> /dev/null
        source "$SCRIPT_DIR/bacaprc" 2> /dev/null
        test -n "$BACAPRC" && source "$BACAPRC"
        source "/etc/bacaprc" 2> /dev/null
        source "/etc/bacap/bacaprc" 2> /dev/null
        source "$SCRIPT_DIR/bacaprc" 2> /dev/null
        test -n "$BACAPRC" && source "$BACAPRC"
+       test -n "$extra_config" && source "$1" 2> /dev/null
+
+       run=
+       [ $DRY_RUN -eq 1 ] &&
+               run=echo
+       [ $VERBOSE -eq 1 ] &&
+               RSYNC_FLAGS="$RSYNC_FLAGS $RSYNC_VERBOSE_FLAGS"
+       [ $DEBUG -eq 1 ] &&
+               V=-v
+       exec 3>&2
+       [ -n "$LOG_FILE" ] &&
+               exec 1>>"$LOG_FILE" &&
+               exec 2>>"$LOG_FILE"
+
+       export RSYNC_RSH
 }
 }
-load_config
-
-export RSYNC_RSH
-
-run=
-[ $DRY_RUN -eq 1 ] &&
-       run=echo
-[ $VERBOSE -eq 1 ] &&
-       RSYNC_FLAGS="$RSYNC_FLAGS $RSYNC_VERBOSE_FLAGS"
-[ $DEBUG -eq 1 ] &&
-       V=-v
-exec 3>&2
-[ -n "$LOG_FILE" ] &&
-       exec 1>>"$LOG_FILE" &&
-       exec 2>>"$LOG_FILE"
 
 error() {
        echo "$@" >&3
 
 error() {
        echo "$@" >&3
@@ -99,8 +100,7 @@ for host_path in "$CONFIG_PATH"/*
 do
        saved_ret=$ret
        # Load default config and override config if correspond
 do
        saved_ret=$ret
        # Load default config and override config if correspond
-       load_config
-       source "$host_path/bacaprc" 2>/dev/null
+       load_config "$host_path/bacaprc"
        host=`basename "$host_path"`
        host_backup_path="$BACKUP_PATH/$host"
        mkdir -p $host_backup_path
        host=`basename "$host_path"`
        host_backup_path="$BACKUP_PATH/$host"
        mkdir -p $host_backup_path