blob: 25dd354179bbf0362a8b94e00ce1820530f47e72 (
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
|
#!/bin/bash
#
# Copy a site backup between servers.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public
# License along with this program. If not, see
# <http://www.gnu.org/licenses/>.
# Load.
source $APP_BASE/lib/hydra/functions || exit 1
hydra_config_load
# Basic parameters.
SITES="/var/sites"
DEST="$1"
SITE="$2"
DATE="`date +%Y%m%d`"
ORIG="$SITES/backups/site/$SITE/`facter hostname`"
# Syntax check.
if [ -z "$SITE" ]; then
hydra_action_usage
exit 1
fi
# Ensure we have a recent local backup.
if [ ! -d "$ORIG/$DATE" ]; then
echo "Backup for $SITE at $DATE not found, creating one..."
hydractl site-backup $SITE
fi
# Parse server name and port.
if echo $DEST | grep -q ":"; then
SERVER="`echo $DEST | cut -d : -f 1`"
PORT="`echo $DEST | cut -d : -f 2`"
else
SERVER="$DEST"
fi
# Ensure we have a port.
if [ -z "$PORT" ]; then
PORT="22"
fi
# Sync to remote destination.
ssh -p $PORT backups@$SERVER mkdir -p $ORIG
rsync -av -e "ssh -p $PORT" $ORIG/ backups@$SERVER:/$ORIG/
|