Skip to content
Snippets Groups Projects
dup 4.47 KiB
Newer Older
  • Learn to ignore specific revisions
  • # -*- mode: sh; sh-basic-offset: 3; indent-tabs-mode: nil; -*-
    
    elijah's avatar
    elijah committed
    #
    # duplicity script for backupninja
    # requires duplicity
    #
    
    getconf options
    
    getconf testconnect yes
    getconf nicelevel 0
    
    setsection gpg
    getconf password
    getconf sign no
    getconf encryptkey
    
    elijah's avatar
    elijah committed
    getconf include
    
    getconf vsnames all
    getconf vsinclude
    
    elijah's avatar
    elijah committed
    getconf exclude
    
    getconf bandwidthlimit 0
    
    elijah's avatar
    elijah committed
    getconf desthost
    getconf destdir
    getconf destuser
    destdir=${destdir%/}
    
    [ "$destdir" != "" ] || fatal "Destination directory not set"
    [ "$include" != "" ] || fatal "No source includes specified"
    
    
    ### vservers stuff ###
    
    # If vservers are configured, check that the ones listed in $vsnames do exist.
    
    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 ###
    
    
    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'`
    
    elijah's avatar
    elijah committed
    	if [ "$result" != "1" ]; then
    
    	    fatal "Can't connect to $desthost as $destuser."
    	else
    	    debug "Connected to $desthost as $destuser successfully"
    
    elijah's avatar
    elijah committed
    	fi
    
    elijah's avatar
    elijah committed
    fi
    
    
    scpoptions="$sshoptions"
    [ "$bandwidthlimit" == 0 ] || scpoptions="$scpoptions -l $bandwidthlimit"
    
    execstr="$options --no-print-statistics --scp-command 'scp $scpoptions' --ssh-command 'ssh $sshoptions' "
    
    # 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."
    
    fi
    
    if [ "$keep" != "yes" ]; then
        if [ "`echo $keep | tr -d 0-9`" == "" ]; then
    
    elijah's avatar
    elijah committed
    	keep="${keep}D"
    
        fi
        execstr="${execstr}--remove-older-than $keep "
    
    elijah's avatar
    elijah committed
    fi
    
    
    if [ "$incremental" == "no" ]; then
        execstr="${execstr}--full "
    fi
    
    
    elijah's avatar
    elijah committed
    execstr_serverpart="scp://$destuser@$desthost/$destdir"
    execstr_clientpart="/"
    
    elijah's avatar
    elijah committed
    
    
    elijah's avatar
    elijah committed
    # excludes
    
    elijah's avatar
    elijah committed
    	str="${i//__star__/*}"
    
    	execstr="${execstr}--exclude '$str' "
    
    elijah's avatar
    elijah committed
    done
    	
    # includes 
    
    elijah's avatar
    elijah committed
    	str="${i//__star__/*}"
    
    	execstr="${execstr}--include '$str' "
    
    elijah's avatar
    elijah committed
    done
    
    
    if [ $usevserver = yes ]; then
    
        for vserver in $vsnames; do
    
    	    i=`readlink -f $VROOTDIR/$vserver$vi`
    	    str="${i//__star__/*}"
    
    	    execstr="${execstr}--include '$VROOTDIR/$vserver$str' "
    	done
        done
    fi
    
    
    elijah's avatar
    elijah committed
    # 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
    
                        "duplicity $execstr --exclude '**' / $execstr_serverpart 2>&1"`
    
    elijah's avatar
    elijah committed
    	code=$?
    
    elijah's avatar
    elijah committed
    		debug $output
    		info "Duplicity finished successfully."
    	else
    
    elijah's avatar
    elijah committed
    	fi
    fi	
    
    return 0