From 914e3c958c00a3a1de1ff32bbf36554788660449 Mon Sep 17 00:00:00 2001 From: intrigeri Date: Sat, 3 Jun 2006 21:08:38 +0000 Subject: [PATCH] dup: more or less support duplicity 0.4.2 (bandwidthlimit maybe not working anymore, though) --- NEWS | 9 ++++++--- examples/example.dup | 1 + handlers/dup | 16 +++++++++++++++- handlers/dup.helper | 1 + 4 files changed, 23 insertions(+), 4 deletions(-) diff --git a/NEWS b/NEWS index fbf6654..7b262c4 100644 --- a/NEWS +++ b/NEWS @@ -1,5 +1,8 @@ WARNING FOR DUPLICITY USERS -Old (pre-0.9.4) example.dup file used to give false information about the way -the GnuPG-related options are used. Please read the new example.dup file, and -update your own configuration files if needed. +1. Old (pre-0.9.4) example.dup file used to give false information about the way + the GnuPG-related options are used. Please read the new example.dup file, and + update your own configuration files if needed. + +2. The bandwidthlimit option does not work anymore with duplicity >=0.4.2. + Trying to solve this... diff --git a/examples/example.dup b/examples/example.dup index b906551..539a7ab 100644 --- a/examples/example.dup +++ b/examples/example.dup @@ -105,6 +105,7 @@ exclude = /home/*/.gnupg #keep = yes # 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 # passed directly to ssh and scp 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 -- 2.30.2