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'
[ -z "$vsnames" ] || warning 'vservers support disabled in backupninja.conf, vsnames configuration line will be ignored'
fi
### see if we can login ###

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 ###
scpoptions="$sshoptions"
[ "$bandwidthlimit" == 0 ] || scpoptions="$scpoptions -l $bandwidthlimit"
execstr="$options --no-print-statistics --scp-command 'scp $scpoptions' --ssh-command 'ssh $sshoptions' "

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
[ -n "$password" ] || fatal "The password option must be set when using symmetric encryption."
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"
# check password validity
[ -n "$password" ] || fatal "The password option must be set when signing."
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
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
for i in $exclude; do
i=`readlink -f ${i#}`
execstr="${execstr}--exclude '$str' "

intrigeri
committed
for i in $include; do
i=`readlink -f ${i#}`
execstr="${execstr}--include '$str' "

intrigeri
committed
for vi in $vsinclude; do
i=`readlink -f $VROOTDIR/$vserver$vi`
str="${i//__star__/*}"
execstr="${execstr}--include '$VROOTDIR/$vserver$str' "
done
done
fi

intrigeri
committed
set +o noglob

intrigeri
committed
### EXECUTE ###
# exclude everything else, start with root
#execstr="${execstr}--exclude '**' / "
# include client-part and server-part
#execstr="$execstr $execstr_serverpart"
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."