mirror of
https://github.com/fradelg/docker-mysql-cron-backup.git
synced 2024-11-01 08:31:45 +01:00
db19ca1130
A missing space at the end of an if condition was generating a warning message. /restore.sh: line 14: [: missing `]' Adding it delete this error message
27 lines
743 B
Bash
Executable file
27 lines
743 B
Bash
Executable file
#!/bin/bash
|
|
[ -z "${MYSQL_USER}" ] && { echo "=> MYSQL_USER cannot be empty" && exit 1; }
|
|
[ -z "${MYSQL_PASS}" ] && { echo "=> MYSQL_PASS cannot be empty" && exit 1; }
|
|
|
|
if [ "$#" -ne 1 ]
|
|
then
|
|
echo "You must pass the path of the backup file to restore"
|
|
fi
|
|
|
|
set -o pipefail
|
|
|
|
SQL=$(gunzip -c "$1")
|
|
DB_NAME=${MYSQL_DATABASE:-${MYSQL_DB}}
|
|
if [ -z "${DB_NAME}" ]
|
|
then
|
|
DB_NAME=$(echo "$SQL" | grep -oE '(Database: (.+))' | cut -d ' ' -f 2)
|
|
fi
|
|
[ -z "${DB_NAME}" ] && { echo "=> database name cannot be found" && exit 1; }
|
|
|
|
echo "=> Restore database $DB_NAME from $1"
|
|
|
|
if echo "$SQL" | mysql -h "$MYSQL_HOST" -P "$MYSQL_PORT" -u "$MYSQL_USER" -p"$MYSQL_PASS" "$DB_NAME"
|
|
then
|
|
echo "=> Restore succeeded"
|
|
else
|
|
echo "=> Restore failed"
|
|
fi
|