aboutsummaryrefslogtreecommitdiff
path: root/handlers/rdiff
blob: 10cb3c06d7523b4cf4cf219d4e64a1f9e782298d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#
# rdiff-backup handler script for backupninja
# requires rdiff-backup
#

getconf options
getconf testconnect yes
getconf nicelevel 0

setsection source
getconf type; sourcetype=$type
getconf label
getconf keep 60
getconf include
getconf vsinclude
getconf exclude

### DESTINATION ###

setsection dest
getconf directory; destdir=$directory
# strip trailing /
destdir=${destdir%/}
getconf type; desttype=$type
getconf user; destuser=$user
getconf host; desthost=$host

# See if vservers are configured
if [ "$vservers" = "yes" ]
then
	if [ ! -d $VROOTDIR ]
	then
		fatal "vservers enabled, but $VROOTDIR does not exist!"
	else
		info "vserver method enabled"
		usevserver=1
	fi
fi

[ "$destdir" != "" ] || fatal "Destination directory not set"

if [ "$desttype" == "remote" ]; then
	# see if we can login
	if [ "$testconnect" == "yes" ]; then
		hostalive=0
	    debug "ssh -o PreferredAuthentications=publickey $desthost -l $destuser 'echo -n 1'"
		ret=`ssh -o PreferredAuthentications=publickey $desthost -l $destuser 'echo -n host is alive'`
		if echo $ret | grep "host is alive"; then
			debug "Connected to $desthost as $destuser successfully"
		else
			fatal "Can't connect to $desthost as $destuser."
		fi
	fi
	# see that rdiff-backup has the same version as here
	debug "ssh -o PreferredAuthentications=publickey $desthost -l $destuser '$RDIFFBACKUP -V'\""
	remoteversion=`ssh -o PreferredAuthentications=publickey $desthost -l $destuser "$RDIFFBACKUP -V | grep rdiff-backup"`
	localversion=`$RDIFFBACKUP -V`
	if [ "$remoteversion" != "$localversion" ]; then
		fatal "rdiff-backup does not have the same version on this computer and the backup server."
	fi
	execstr_serverpart="$destuser@$desthost::$destdir/$label"
else
	execstr_serverpart="$destdir/$label"
fi

### SOURCE ###

[ "$label" != "" ] || fatal "Source missing label"
[ "$sourcetype" == "local" ] || fatal "Only local source type supported"
[ "$include" != "" -o "$vsinclude" != "" ] || fatal "No source includes specified"
#TODO should I test for vsinclude if usevservers=1?

execstr_clientpart="/"
	
## REMOVE OLD BACKUPS

if [ "`echo $keep | tr -d 0-9`" == "" ]; then
	keep="${keep}D"
fi

removestr="rdiff-backup --force --remove-older-than $keep "
if [ "$desttype" == "remote" ]; then
	removestr="${removestr}${destuser}@${desthost}::"
fi
removestr="${removestr}${destdir}/${label}";

debug "$removestr"
if [ ! $test ]; then
	output=`$removestr 2>&1`
	code=$?
	if [ "$code" == "0" ]; then
		debug $output
		info "Removing backups older than $keep days succeeded."
	else
		warning $output
		warning "Failed removing backups older than $keep."
	fi
fi

## EXECUTE ##

execstr="$RDIFFBACKUP $options --print-statistics "

# TODO: order the includes and excludes

# excludes
for i in $exclude; do
	str="${i//__star__/*}"
	execstr="${execstr}--exclude '$str' "
done
	
# includes 
for i in $include; do
	str="${i//__star__/*}"
	execstr="${execstr}--include '$str' "
done

# vsinclude
if [ $usevserver ] 
then
	for vserver in `ls $VROOTDIR | grep -E -v "lost+found|ARCHIVES"`
	do
		for vi in $vsinclude
		do
			str="${vi//__star__/*}"
			execstr="${execstr}--include '$VROOTDIR/$vserver$str' "
		done
	done
fi

# exclude everything else
execstr="${execstr}--exclude '/*' "
		
# include client-part and server-part
execstr="${execstr}$execstr_clientpart $execstr_serverpart"

debug "$execstr"
if [ ! $test ]; then
	output=`nice -n $nicelevel su -c "$execstr" 2>&1`
	code=$?
	if [ "$code" == "0" ]; then
		debug $output
		info "Successfully finished backing up source '$label'"
	else
		warning $output
		warning "Failed backup up source '$label'"
	fi
fi	

return 0