Improved duplicity handler: option to disable remote files cleaning, optionnal backups gpg signing, option to specify the gpg key to use, nicelevel & testconnect options, optionnal string to pass to ssh/scp e.g. to use a non-default identity file ; created an example.dup file ; config is now split in sections.

This commit is contained in:
intrigeri 2005-05-24 19:08:51 +00:00
parent 62e15fc0b9
commit 26a57c396c
2 changed files with 45 additions and 11 deletions

1
README
View File

@ -49,6 +49,7 @@ file in /etc/backup.d according to the file's suffix:
.sh -- run this file as a shell script.
.rdiff -- this is a configuration for rdiff-backup
.maildir -- this is a configuration to backup maildirs
.dup -- this is a configuration for duplicity
.mysql -- mysql backup configuration
.ldap -- ldap backup configuration
.sys -- general system reports

View File

@ -3,11 +3,22 @@
# requires duplicity
#
getconf password
getconf options
getconf keep 60
getconf testconnect yes
getconf nicelevel 0
setsection gpg
getconf password
getconf sign no
getconf encryptkey
setsection source
getconf include
getconf exclude
setsection dest
getconf keep 60
getconf sshoptions
getconf desthost
getconf destdir
getconf destuser
@ -18,21 +29,40 @@ destdir=${destdir%/}
[ "$password" != "" ] || fatal "No password specified"
# see if we can login
debug "ssh -o PasswordAuthentication=no $desthost -l $destuser 'echo -n 1'"
if [ ! $test ]; then
result=`ssh -o PasswordAuthentication=no $desthost -l $destuser 'echo -n 1' 2>&1`
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' 2>&1`
if [ "$result" != "1" ]; then
fatal "Can't connect to $desthost as $destuser."
fatal "Can't connect to $desthost as $destuser."
else
debug "Connected to $desthost as $destuser successfully"
fi
fi
fi
if [ "`echo $keep | tr -d 0-9`" == "" ]; then
### COMMAND-LINE MANGLING ###
execstr="$options --no-print-statistics --scp-command 'scp $sshoptions' --ssh-command 'ssh $sshoptions' "
if [ "$encryptkey" == "" ]; then
[ "$sign" != "yes" ] || fatal "encryptkey option must be set when signing."
else
execstr="${execstr}--encrypt-key $encryptkey "
[ "$sign" != "yes" ] || execstr="${execstr}--sign-key $encryptkey "
fi
if [ "$keep" != "yes" ]; then
if [ "`echo $keep | tr -d 0-9`" == "" ]; then
keep="${keep}D"
fi
execstr="${execstr}--remove-older-than $keep "
fi
execstr_serverpart="scp://$destuser@$desthost/$destdir"
execstr_clientpart="/"
execstr="$options --no-print-statistics --remove-older-than $keep "
### SOURCE ###
# excludes
for i in $exclude; do
@ -46,6 +76,8 @@ for i in $include; do
execstr="${execstr}--include $str "
done
### EXECUTE ###
# exclude everything else, start with root
#execstr="${execstr}--exclude '**' / "
@ -56,9 +88,10 @@ execstr=${execstr//\\*/\\\\\\*}
debug "duplicity $execstr --exclude '**' / $execstr_serverpart"
if [ ! $test ]; then
PASSPHRASE=$password
export PASSPHRASE
output=`duplicity $execstr --exclude '**' / $execstr_serverpart 2>&1`
output=`nice -n $nicelevel \
su -c \
"export PASSPHRASE=$password \
&& duplicity $execstr --exclude '**' / $execstr_serverpart 2>&1"`
code=$?
if [ "$code" == "0" ]; then
debug $output