#!/bin/bash [ -z "${MYSQL_USER}" ] && { echo "=> MYSQL_USER cannot be empty" && exit 1; } # If provided, take password from file [ -z "${MYSQL_PASS_FILE}" ] || { MYSQL_PASS=$(head -1 "${MYSQL_PASS_FILE}"); } # Alternatively, take it from env var [ -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 if [ -z "${USE_PLAIN_SQL}" ] then SQL=$(gunzip -c "$1") else SQL=$(cat "$1") fi DB_NAME=${MYSQL_DATABASE:-${MYSQL_DB}} if [ -z "${DB_NAME}" ] then echo "=> Searching database name in $1" DB_NAME=$(echo "$SQL" | grep -oE '(Database: (.+))' | cut -d ' ' -f 2) fi [ -z "${DB_NAME}" ] && { echo "=> Database name not 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" $MYSQL_SSL_OPTS "$DB_NAME" then echo "=> Restore succeeded" else echo "=> Restore failed" fi