aboutsummaryrefslogtreecommitdiff
path: root/handlers
diff options
context:
space:
mode:
authorintrigeri <intrigeri@boum.org>2006-06-03 21:08:38 +0000
committerintrigeri <intrigeri@boum.org>2006-06-03 21:08:38 +0000
commit914e3c958c00a3a1de1ff32bbf36554788660449 (patch)
treed59e96e48fdc2bec6c04c92b90b392f060f103f0 /handlers
parenta031bc2d53eb90b6b4255d344967ec39a9f3ea26 (diff)
downloadbackupninja-914e3c958c00a3a1de1ff32bbf36554788660449.tar.gz
backupninja-914e3c958c00a3a1de1ff32bbf36554788660449.tar.bz2
dup: more or less support duplicity 0.4.2 (bandwidthlimit maybe not working anymore, though)
Diffstat (limited to 'handlers')
-rw-r--r--handlers/dup16
-rw-r--r--handlers/dup.helper1
2 files changed, 16 insertions, 1 deletions
diff --git a/handlers/dup b/handlers/dup
index 7c8a7c6..59bb9bf 100644
--- a/handlers/dup
+++ b/handlers/dup
@@ -53,6 +53,7 @@ else
[ -z "$vsinclude" ] || warning 'vservers support disabled in backupninja.conf, vsincludes configuration lines will be ignored'
fi
+
### see if we can login ###
if [ "$testconnect" == "yes" ]; then
@@ -69,10 +70,23 @@ fi
### COMMAND-LINE MANGLING ###
+# duplicity >= 0.4.2 needs --sftp-command (NB: sftp does not support the -l option)
+duplicity_version="`duplicity --version | awk '{print $2}'`"
+duplicity_major="`echo $duplicity_version | awk -F '.' '{print $1}'`"
+duplicity_minor="`echo $duplicity_version | awk -F '.' '{print $2}'`"
+duplicity_sub="`echo $duplicity_version | awk -F '.' '{print $3}'`"
+if [ "$duplicity_major" -ge 0 -a "$duplicity_minor" -ge 4 -a "$duplicity_sub" -ge 2 ]; then
+ sftpoptions="$sshoptions"
+fi
+
scpoptions="$sshoptions"
[ "$bandwidthlimit" == 0 ] || scpoptions="$scpoptions -l $bandwidthlimit"
-execstr="$options --no-print-statistics --scp-command 'scp $scpoptions' --ssh-command 'ssh $sshoptions' "
+if [ -z "$sftpoptions" ]; then
+ execstr="$options --no-print-statistics --scp-command 'scp $scpoptions' --ssh-command 'ssh $sshoptions' "
+else
+ execstr="$options --no-print-statistics --scp-command 'scp $scpoptions' --sftp-command 'sftp $sftpoptions' --ssh-command 'ssh $sshoptions' "
+fi
# deal with symmetric or asymmetric (public/private key pair) encryption
if [ -n "$encryptkey" ]; then
diff --git a/handlers/dup.helper b/handlers/dup.helper
index a18063d..b366b53 100644
--- a/handlers/dup.helper
+++ b/handlers/dup.helper
@@ -398,6 +398,7 @@ incremental = $dup_incremental
keep = $dup_keep
# bandwith limit, in kbit/s ; default is 0, i.e. no limit
+# NB: does not work anymore with duplicity >=0.4.2, work in progress to fix this
#bandwidthlimit = 128
bandwidthlimit = $dup_bandwidth