Skip to content

Commit 3babcac

Browse files
author
nacho
committed
backup/restore: include datadir
1 parent 0d48f1e commit 3babcac

File tree

3 files changed

+66
-17
lines changed

3 files changed

+66
-17
lines changed

etc/nextcloudpi-config.d/nc-backup.sh

Lines changed: 18 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -16,29 +16,42 @@
1616

1717

1818
DESTDIR_=/media/USBdrive
19-
BASEDIR_=/var/www
19+
INCLUDEDATA_=no
2020
DESCRIPTION="Backup this NC instance to a file"
2121

2222
DESTFILE=$DESTDIR_/nextcloud-bkp_`date +"%Y%m%d"`.tar
2323
DBBACKUP=nextcloud-sqlbkp_`date +"%Y%m%d"`.bak
24+
BASEDIR=/var/www
2425

2526
configure()
2627
{
27-
cd $BASEDIR_/nextcloud
28+
local DATADIR
29+
DATADIR=$( cd $BASEDIR/nextcloud; sudo -u www-data php occ config:system:get datadirectory ) || {
30+
echo -e "Error reading data directory. Is NextCloud running and configured?";
31+
return 1;
32+
}
33+
34+
cd $BASEDIR/nextcloud
2835
sudo -u www-data php occ maintenance:mode --on
2936

30-
cd $BASEDIR_
37+
cd $BASEDIR
3138
echo -e "backup database..."
3239
mysqldump -u root --single-transaction nextcloud > $DBBACKUP
3340

41+
[[ "$INCLUDEDATA_" == "yes" ]] && echo -e "backup datadir... "
3442
echo -e "backup files..."
3543
mkdir -p $DESTDIR_
36-
tar -cf $DESTFILE $DBBACKUP nextcloud/ && \
44+
tar -cf $DESTFILE $DATAFILE $DBBACKUP nextcloud/ --exclude "nextcloud/data/*/files/*" && \
3745
echo -e "backup $DESTFILE generated" || \
3846
echo -e "error generating backup"
3947
rm $DBBACKUP
4048

41-
cd $BASEDIR_/nextcloud
49+
[[ "$INCLUDEDATA_" == "yes" ]] && {
50+
tar -rf $DESTFILE -C $DATADIR/.. $( basename $DATADIR ) || \
51+
echo -e "error generating data backup"
52+
}
53+
54+
cd $BASEDIR/nextcloud
4255
sudo -u www-data php occ maintenance:mode --off
4356
}
4457

etc/nextcloudpi-config.d/nc-restore.sh

Lines changed: 47 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -43,16 +43,18 @@ configure()
4343
[ -d $BASEDIR_ ] || { echo -e "$BASEDIR_ not found"; return 1; }
4444
[ -d $BASEDIR_/nextcloud ] && { echo -e "WARNING: overwriting old instance"; }
4545

46-
cd $BASEDIR_/nextcloud
47-
sudo -u www-data php occ maintenance:mode --on
46+
local TMPDIR="$( dirname $BACKUPFILE_ )/$( basename ${BACKUPFILE_}-tmp )"
47+
rm -rf "$TMPDIR" && mkdir -p "$TMPDIR"
48+
tar -xf "$BACKUPFILE_" -C "$TMPDIR" || return 1
49+
50+
## RESTORE FILES
4851

49-
# RESTORE FILES
5052
echo -e "restore files..."
51-
cd $BASEDIR_
52-
rm -rf nextcloud
53-
tar -xf $BACKUPFILE_ || return 1
53+
rm -rf $BASEDIR_/nextcloud
54+
mv "$TMPDIR"/nextcloud $BASEDIR_
55+
56+
## RE-CREATE DATABASE TABLE
5457

55-
# RE-CREATE DATABASE TABLE
5658
local DBPASSWD=$( grep password /root/.my.cnf | cut -d= -f2 )
5759
echo -e "restore database..."
5860
mysql -u root -p$DBPASSWD <<EOF
@@ -64,15 +66,48 @@ CREATE USER '$DBADMIN_'@'localhost' IDENTIFIED BY '$DBPASSWD';
6466
GRANT ALL PRIVILEGES ON nextcloud.* TO $DBADMIN_@localhost;
6567
EXIT
6668
EOF
67-
[ $? -ne 0 ] && { echo -e "error configuring nextcloud database"; return 1; }
69+
[ $? -ne 0 ] && { echo -e "Error configuring nextcloud database"; return 1; }
6870

69-
mysql -u root -p$DBPASSWD nextcloud < nextcloud-sqlbkp_*.bak || { echo -e "error restoring nextcloud database"; return 1; }
71+
mysql -u root -p$DBPASSWD nextcloud < "$TMPDIR"/nextcloud-sqlbkp_*.bak || { echo -e "Error restoring nextcloud database"; return 1; }
7072

71-
# Just in case we moved the opcache dir
72-
sed -i "s|^opcache.file_cache=.*|opcache.file_cache=$BASEDIR_/nextcloud/data/.opcache|" /etc/php/7.0/mods-available/opcache.ini
73+
## RESTORE DATADIR
7374

7475
cd $BASEDIR_/nextcloud
75-
sudo -u www-data php occ maintenance:mode --off
76+
77+
# INCLUDEDATA=yes situation
78+
79+
if [[ $( ls "$TMPDIR" | wc -l ) == 2 ]]; then
80+
local DATADIR=$( grep datadirectory $BASEDIR_/nextcloud/config/config.php | awk '{ print $3 }' | grep -oP "[^']*[^']" | head -1 )
81+
[[ "$DATADIR" == "" ]] && { echo -e "Error reading data directory"; return 1; }
82+
echo -e "restore datadir to $DATADIR..."
83+
rm -rf "$DATADIR"
84+
mkdir -p "$( dirname "$DATADIR" )"
85+
mv "$TMPDIR/$( basename "$DATADIR" )" "$DATADIR"
86+
sudo -u www-data php occ maintenance:mode --off
87+
88+
# INCLUDEDATA=no situation
89+
90+
else
91+
echo -e "no datadir found in backup"
92+
sed -i "s|'datadirectory' =>.*|'datadirectory' => '/var/www/nextcloud/data',|" "config/config.php"
93+
94+
sudo -u www-data php occ maintenance:mode --off
95+
sudo -u www-data php occ files:scan --all
96+
97+
# cache needs to be cleaned as of NC 12
98+
(
99+
sleep 3
100+
systemctl stop php7.0-fpm
101+
systemctl stop mysqld
102+
sleep 0.5
103+
systemctl start php7.0-fpm
104+
systemctl start mysqld
105+
) &>/dev/null &
106+
fi
107+
rm -r "$TMPDIR"
108+
109+
# Just in case we moved the opcache dir
110+
sed -i "s|^opcache.file_cache=.*|opcache.file_cache=$BASEDIR_/nextcloud/data/.opcache|" /etc/php/7.0/mods-available/opcache.ini
76111
}
77112

78113
install() { :; }

tests/tests.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -111,6 +111,7 @@ def test_user_login(self):
111111
driver.find_element_by_id("user").send_keys("test_user1")
112112
driver.find_element_by_id("password").send_keys("ownyourbits")
113113
driver.find_element_by_id("submit").click()
114+
self.assertNotIn("Wrong password", driver.page_source)
114115

115116
time.sleep(60) # first run can be really slow on QEMU
116117
wait = WebDriverWait(driver, 210)

0 commit comments

Comments
 (0)