Newer
Older
# -*- mode: sh; sh-basic-offset: 3; indent-tabs-mode: nil; -*-
#
# duplicity script for backupninja
# requires duplicity
#
getconf options
intrigeri
committed
getconf testconnect yes
getconf nicelevel 0
setsection gpg
getconf password
getconf sign no
getconf encryptkey
intrigeri
committed
setsection source
getconf vsnames all
getconf vsinclude
intrigeri
committed
setsection dest
intrigeri
committed
getconf incremental yes
intrigeri
committed
getconf keep 60
getconf sshoptions
getconf desthost
getconf destdir
getconf destuser
destdir=${destdir%/}
[ "$destdir" != "" ] || fatal "Destination directory not set"
[ "$include" != "" ] || fatal "No source includes specified"
intrigeri
committed
# If vservers are configured, check that the ones listed in $vsnames do exist.
intrigeri
committed
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'
intrigeri
committed
intrigeri
committed
if [ "$testconnect" == "yes" ]; then
debug "ssh $sshoptions -o PasswordAuthentication=no $desthost -l $destuser 'echo -n 1'"
if [ ! $test ]; then
result=`ssh $sshoptions -o PasswordAuthentication=no $desthost -l $destuser 'echo -n 1'`
intrigeri
committed
fatal "Can't connect to $desthost as $destuser."
else
debug "Connected to $desthost as $destuser successfully"
intrigeri
committed
fi
intrigeri
committed
### COMMAND-LINE MANGLING ###
intrigeri
committed
# 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"
intrigeri
committed
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
intrigeri
committed
# deal with symmetric or asymmetric (public/private key pair) encryption
if [ -n "$encryptkey" ]; then
execstr="${execstr}--encrypt-key $encryptkey "
debug "Data will be encrypted with the GnuPG key $encryptkey."
else
debug "Data will be encrypted using symmetric encryption."
fi
# deal with data signing
if [ "$sign" == yes ]; then
# duplicity is not able to sign data when using symmetric encryption
[ -n "$encryptkey" ] || fatal "The encryptkey option must be set when signing."
# if needed, initialize signkey to a value that is not empty (checked above)
[ -n "$signkey" ] || signkey="$encryptkey"
execstr="${execstr}--sign-key $signkey "
debug "Data will be signed will the GnuPG key $signkey."
else
debug "Data won't be signed."
intrigeri
committed
fi
# deal with GnuPG passphrase
[ -n "$password" ] || fatal "The password option must be set."
intrigeri
committed
if [ "$keep" != "yes" ]; then
if [ "`echo $keep | tr -d 0-9`" == "" ]; then
intrigeri
committed
fi
execstr="${execstr}--remove-older-than $keep "
intrigeri
committed
if [ "$incremental" == "no" ]; then
execstr="${execstr}--full "
fi
execstr_serverpart="scp://$destuser@$desthost/$destdir"
execstr_clientpart="/"
intrigeri
committed
### SOURCE ###
intrigeri
committed
set -o noglob
intrigeri
committed
symlinks_warning="Maybe you have mixed symlinks and '*' in this statement, which is not supported."
intrigeri
committed
for i in $exclude; do
intrigeri
committed
str="${i//__star__/*}"
execstr="${execstr}--exclude '$str' "
intrigeri
committed
for i in $include; do
[ "$i" != "/" ] || fatal "Sorry, you cannot use 'include = /'"
intrigeri
committed
str="${i//__star__/*}"
execstr="${execstr}--include '$str' "
intrigeri
committed
for vserver in $vsnames; do
for vi in $vsinclude; do
str="${vi//__star__/*}"
str="$VROOTDIR/$vserver$str"
execstr="${execstr}--include '$str' "
intrigeri
committed
done
done
intrigeri
committed
set +o noglob
intrigeri
committed
### EXECUTE ###
execstr=${execstr//\\*/\\\\\\*}
debug "duplicity $execstr --exclude '**' / $execstr_serverpart"
if [ ! $test ]; then
intrigeri
committed
export PASSPHRASE=$password
intrigeri
committed
output=`nice -n $nicelevel \
su -c \
intrigeri
committed
"duplicity $execstr --exclude '**' / $execstr_serverpart 2>&1"`
intrigeri
committed
if [ $code -eq 0 ]; then
intrigeri
committed
debug $output
fatal "Duplicity failed."