Removed over zelous vsnames check
[matthijs/upstream/backupninja.git] / handlers / dup
index 2e4312b0d34ad5d62007a79633b3494ab722e691..e490aa533e239fef24f4879e10efc8ec980b1306 100644 (file)
@@ -35,28 +35,22 @@ destdir=${destdir%/}
 
 ### vservers stuff ###
 
-# See if vservers are configured.
-# If so, check that the ones listed in $vsnames do exist.
-if [ "$vservers" == "yes" ]; then
-    [ -d "$VROOTDIR" ] || fatal "vservers enabled, but $VROOTDIR does not exist!"
-    if [ "$vsnames" == "all" ]; then
-       vsnames=""
-       for vserver in `ls $VROOTDIR | grep -E -v "lost+found|ARCHIVES"`; do
-           vsnames="$vserver $vsnames"
-       done
-    else
-       for vserver in "$vsnames"; do
-           [ -d "$VROOTDIR/$vserver" ] || fatal "vserver '$vserver' does not exist."
-       done
-    fi
-    if [ -n "$vsnames" ]; then
-       if [ -n "$vsinclude" ]; then
-           info "Using vservers '$vsnames'"
-           usevserver=1
-       fi
-    else
-       [ -z "$vsinclude" ] || warning 'vsnames is empty, vsinclude configuration lines will be ignored'
-    fi
+# If vservers are configured, check that the ones listed in $vsnames do exist.
+local usevserver=no
+if [ $vservers_are_available = yes ]; then
+   if [ "$vsnames" = all ]; then
+      vsnames="$found_vservers"
+   else
+      if ! vservers_exist "$vsnames" ; then
+            fatal "At least one of the vservers listed in vsnames ($vsnames) does not exist."
+      fi
+   fi
+   if [ -n "$vsinclude" ]; then
+      info "Using vservers '$vsnames'"
+      usevserver=yes
+   fi
+else
+   [ -z "$vsinclude" ] || warning 'vservers support disabled in backupninja.conf, vsincludes configuration lines will be ignored'
 fi
 
 ### see if we can login ###
@@ -119,28 +113,35 @@ execstr_clientpart="/"
 
 ### SOURCE ###
 
+set -o noglob
+
 # excludes
-for i in "$exclude"; do
+for i in $exclude; do
        str="${i//__star__/*}"
+       i=`readlink -f ${i#}`
        execstr="${execstr}--exclude '$str' "
 done
        
 # includes 
-for i in "$include"; do
+for i in $include; do
        str="${i//__star__/*}"
+       i=`readlink -f ${i#}`
        execstr="${execstr}--include '$str' "
 done
 
 # vsincludes
-if [ $usevserver ]; then
+if [ $usevserver = yes ]; then
     for vserver in $vsnames; do
-       for vi in "$vsinclude"; do
-           str="${vi//__star__/*}"
+       for vi in $vsinclude; do
+           i=`readlink -f $VROOTDIR/$vserver$vi`
+           str="${i//__star__/*}"
            execstr="${execstr}--include '$VROOTDIR/$vserver$str' "
        done
     done
 fi
 
+set +o noglob
+
 ### EXECUTE ###
 
 # exclude everything else, start with root