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__/*}"
str=`readlink -f $str`
if [ -n "$str" ]; then
execstr="${execstr}--exclude '$str' "
else
warning "exclude statement '${i//__star__/*}' will be ignored. $symlinks_warning"

intrigeri
committed
fi

intrigeri
committed
for i in $include; do
[ "$i" != "/" ] || fatal "Sorry, you cannot use 'include = /'"

intrigeri
committed
str="${i//__star__/*}"
str=`readlink -f $str`
if [ -n "$str" ]; then
execstr="${execstr}--include '$str' "
else
warning "include statement '${i//__star__/*}' will be ignored. $symlinks_warning"

intrigeri
committed
fi

intrigeri
committed
for vserver in $vsnames; do
for vi in $vsinclude; do
str="${vi//__star__/*}"
str=`readlink -f $VROOTDIR/$vserver$str`
if [ -n "$str" ]; then
execstr="${execstr}--include '$str' "
else
warning "vsinclude statement '${vi//__star__/*}' will be ignored for VServer $vserver. $symlinks_warning"

intrigeri
committed
fi
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."