|
@@ -66,10 +66,32 @@ if [ ! -d $SERVER_DIRECTORY/backup ]; then
|
66
|
66
|
mkdir -p $SERVER_DIRECTORY/backup
|
67
|
67
|
fi
|
68
|
68
|
|
|
69
|
+# The name of a currently suspended site
|
|
70
|
+# Sites are suspended so that verification should work
|
|
71
|
+SUSPENDED_SITE=
|
|
72
|
+
|
|
73
|
+function suspend_site {
|
|
74
|
+ # suspends a given website
|
|
75
|
+ SUSPENDED_SITE="$1"
|
|
76
|
+ nginx_dissite $SUSPENDED_SITE
|
|
77
|
+ service nginx reload
|
|
78
|
+}
|
|
79
|
+
|
|
80
|
+function restart_site {
|
|
81
|
+ # restarts a given website
|
|
82
|
+ if [ ! $SUSPENDED_SITE ]; then
|
|
83
|
+ return
|
|
84
|
+ fi
|
|
85
|
+ nginx_ensite $SUSPENDED_SITE
|
|
86
|
+ service nginx reload
|
|
87
|
+ SUSPENDED_SITE=
|
|
88
|
+}
|
|
89
|
+
|
69
|
90
|
function backup_directory_to_friend {
|
70
|
91
|
BACKUP_KEY_EXISTS=$(gpg --list-keys "$ADMIN_NAME (backup key)")
|
71
|
92
|
if [ ! "$?" = "0" ]; then
|
72
|
93
|
echo $"Backup key could not be found"
|
|
94
|
+ restart_site
|
73
|
95
|
exit 43382
|
74
|
96
|
fi
|
75
|
97
|
ADMIN_BACKUP_KEY_ID=$(gpg --list-keys "$ADMIN_NAME (backup key)" | grep 'pub ' | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
|
|
@@ -86,6 +108,7 @@ function backup_directory_to_friend {
|
86
|
108
|
fi
|
87
|
109
|
# Send a warning email
|
88
|
110
|
echo "Unable to verify ${2}" | mail -s "${PROJECT_NAME} backup to friends" ${ADMIN_EMAIL_ADDRESS}
|
|
111
|
+ restart_site
|
89
|
112
|
exit 953
|
90
|
113
|
fi
|
91
|
114
|
obnam forget --keep=30d -r $SERVER_DIRECTORY/backup/${2} --encrypt-with ${ADMIN_BACKUP_KEY_ID}
|
|
@@ -96,6 +119,7 @@ function backup_directory_to_friend {
|
96
|
119
|
fi
|
97
|
120
|
# Send a warning email
|
98
|
121
|
echo "Unable to backup ${2}" | mail -s "${PROJECT_NAME} backup to friends" ${ADMIN_EMAIL_ADDRESS}
|
|
122
|
+ restart_site
|
99
|
123
|
exit 853
|
100
|
124
|
fi
|
101
|
125
|
if [[ ${1} == "/root/temp"* || ${1} == *"tempbackup" ]]; then
|
|
@@ -107,6 +131,7 @@ function backup_directory_to_friend {
|
107
|
131
|
function backup_database_to_friend {
|
108
|
132
|
if [ ${#DATABASE_PASSWORD} -lt 2 ]; then
|
109
|
133
|
echo $"No MariaDB password was given"
|
|
134
|
+ restart_site
|
110
|
135
|
exit 5783
|
111
|
136
|
fi
|
112
|
137
|
if [ ! -d $SERVER_DIRECTORY/backup/${1} ]; then
|
|
@@ -126,6 +151,7 @@ function backup_database_to_friend {
|
126
|
151
|
rm -rf /root/temp${1}data
|
127
|
152
|
# Send a warning email
|
128
|
153
|
echo $"Unable to export ${1} database" | mail -s $"${PROJECT_NAME} backup to friends" $ADMIN_EMAIL_ADDRESS
|
|
154
|
+ restart_site
|
129
|
155
|
exit 5738
|
130
|
156
|
fi
|
131
|
157
|
}
|
|
@@ -226,10 +252,12 @@ function backup_gnusocial {
|
226
|
252
|
if grep -q "GNU Social domain" $COMPLETION_FILE; then
|
227
|
253
|
MICROBLOG_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "GNU Social domain" | awk -F ':' '{print $2}')
|
228
|
254
|
if [ -d /var/www/${MICROBLOG_DOMAIN_NAME}/htdocs ]; then
|
|
255
|
+ suspend_site ${MICROBLOG_DOMAIN_NAME}
|
229
|
256
|
backup_database_to_friend gnusocial
|
230
|
257
|
backup_directory_to_friend /root/tempgnusocialdata gnusocialdata
|
231
|
258
|
echo $"Backing up GNU social installation"
|
232
|
259
|
backup_directory_to_friend /var/www/${MICROBLOG_DOMAIN_NAME}/htdocs gnusocial
|
|
260
|
+ restart_site
|
233
|
261
|
else
|
234
|
262
|
echo $"GNU Social domain specified but not found in /var/www/${MICROBLOG_DOMAIN_NAME}"
|
235
|
263
|
fi
|
|
@@ -240,10 +268,12 @@ function backup_hubzilla {
|
240
|
268
|
if grep -q "Hubzilla domain" $COMPLETION_FILE; then
|
241
|
269
|
HUBZILLA_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Hubzilla domain" | awk -F ':' '{print $2}')
|
242
|
270
|
if [ -d /var/www/${HUBZILLA_DOMAIN_NAME} ]; then
|
|
271
|
+ suspend_site ${HUBZILLA_DOMAIN_NAME}
|
243
|
272
|
backup_database_to_friend hubzilla
|
244
|
273
|
backup_directory_to_friend /root/temphubzilladata hubzilladata
|
245
|
274
|
echo "Backing up Hubzilla installation"
|
246
|
275
|
backup_directory_to_friend /var/www/${HUBZILLA_DOMAIN_NAME}/htdocs hubzilla
|
|
276
|
+ restart_site
|
247
|
277
|
else
|
248
|
278
|
echo $"Hubzilla domain specified but not found in /var/www/${HUBZILLA_DOMAIN_NAME}"
|
249
|
279
|
exit 2578
|
|
@@ -253,16 +283,21 @@ function backup_hubzilla {
|
253
|
283
|
|
254
|
284
|
function backup_owncloud {
|
255
|
285
|
if [ -d /etc/owncloud ]; then
|
|
286
|
+ OWNCLOUD_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Owncloud domain" | awk -F ':' '{print $2}')
|
|
287
|
+ suspend_site ${OWNCLOUD_DOMAIN_NAME}
|
256
|
288
|
backup_database_to_friend owncloud
|
257
|
289
|
backup_directory_to_friend /root/tempownclouddata ownclouddata
|
258
|
290
|
echo $"Backing up Owncloud data"
|
259
|
291
|
backup_directory_to_friend /var/lib/owncloud owncloud
|
260
|
292
|
backup_directory_to_friend /etc/owncloud owncloud2
|
|
293
|
+ restart_site
|
261
|
294
|
fi
|
262
|
295
|
}
|
263
|
296
|
|
264
|
297
|
function backup_gogs {
|
265
|
298
|
if [ -d /home/git/go/src/github.com/gogits ]; then
|
|
299
|
+ GIT_DOMAIN_NAME=$(cat $COMPLETION_FILE | grep "Gogs domain" | awk -F ':' '{print $2}')
|
|
300
|
+ suspend_site ${GIT_DOMAIN_NAME}
|
266
|
301
|
backup_database_to_friend gogs
|
267
|
302
|
backup_directory_to_friend /root/tempgogsdata gogsdata
|
268
|
303
|
echo $"Obtaining Gogs settings backup"
|
|
@@ -272,6 +307,7 @@ function backup_gogs {
|
272
|
307
|
backup_directory_to_friend /home/git/gogs-repositories gogsrepos
|
273
|
308
|
echo $"Obtaining Gogs authorized_keys backup"
|
274
|
309
|
backup_directory_to_friend /home/git/.ssh gogsssh
|
|
310
|
+ restart_site
|
275
|
311
|
fi
|
276
|
312
|
}
|
277
|
313
|
|
|
@@ -537,7 +573,7 @@ do
|
537
|
573
|
if [ $REMOTE_SERVER ]; then
|
538
|
574
|
REMOTE_DOMAIN=$(echo "${remote_server}" | awk -F ' ' '{print $1}' | awk -F '@' '{print $2}')
|
539
|
575
|
REMOTE_SSH_PORT=$(echo "${remote_server}" | awk -F ' ' '{print $2}')
|
540
|
|
- REMOTE_DIRECTORY=$(echo "${remote_server}" | awk -F ' ' '{print $3}')
|
|
576
|
+ REMOTE_DIRECTORY=$(echo "${remote_server}" | awk -F ' ' '{print $3}')
|
541
|
577
|
REMOTE_PASSWORD=$(echo "${remote_server}" | awk -F ' ' '{print $4}')
|
542
|
578
|
NOW=$(date +"%Y-%m-%d %H:%M:%S")
|
543
|
579
|
REMOTE_SERVER=$REMOTE_SERVER:$REMOTE_DIRECTORY
|