55 lines
1.8 KiB
Bash
55 lines
1.8 KiB
Bash
|
#!/usr/bin/env bash
|
||
|
# Use this script to start a docker container for a local development database
|
||
|
|
||
|
# TO RUN ON WINDOWS:
|
||
|
# 1. Install WSL (Windows Subsystem for Linux) - https://learn.microsoft.com/en-us/windows/wsl/install
|
||
|
# 2. Install Docker Desktop for Windows - https://docs.docker.com/docker-for-windows/install/
|
||
|
# 3. Open WSL - `wsl`
|
||
|
# 4. Run this script - `./start-database.sh`
|
||
|
|
||
|
# On Linux and macOS you can run this script directly - `./start-database.sh`
|
||
|
|
||
|
DB_CONTAINER_NAME="titles-mysql"
|
||
|
|
||
|
if ! [ -x "$(command -v docker)" ]; then
|
||
|
echo -e "Docker is not installed. Please install docker and try again.\nDocker install guide: https://docs.docker.com/engine/install/"
|
||
|
exit 1
|
||
|
fi
|
||
|
|
||
|
if [ "$(docker ps -q -f name=$DB_CONTAINER_NAME)" ]; then
|
||
|
echo "Database container '$DB_CONTAINER_NAME' already running"
|
||
|
exit 0
|
||
|
fi
|
||
|
|
||
|
if [ "$(docker ps -q -a -f name=$DB_CONTAINER_NAME)" ]; then
|
||
|
docker start "$DB_CONTAINER_NAME"
|
||
|
echo "Existing database container '$DB_CONTAINER_NAME' started"
|
||
|
exit 0
|
||
|
fi
|
||
|
|
||
|
# import env variables from .env
|
||
|
set -a
|
||
|
source .env
|
||
|
|
||
|
DB_PASSWORD=$(echo "$DATABASE_URL" | awk -F':' '{print $3}' | awk -F'@' '{print $1}')
|
||
|
DB_PORT=$(echo "$DATABASE_URL" | awk -F':' '{print $4}' | awk -F'\/' '{print $1}')
|
||
|
|
||
|
if [ "$DB_PASSWORD" == "password" ]; then
|
||
|
echo "You are using the default database password"
|
||
|
read -p "Should we generate a random password for you? [y/N]: " -r REPLY
|
||
|
if ! [[ $REPLY =~ ^[Yy]$ ]]; then
|
||
|
echo "Please set a password in the .env file and try again"
|
||
|
exit 1
|
||
|
fi
|
||
|
# Generate a random URL-safe password
|
||
|
DB_PASSWORD=$(openssl rand -base64 12 | tr '+/' '-_')
|
||
|
sed -i -e "s#:password@#:$DB_PASSWORD@#" .env
|
||
|
fi
|
||
|
|
||
|
docker run -d \
|
||
|
--name $DB_CONTAINER_NAME \
|
||
|
-e MYSQL_ROOT_PASSWORD="$DB_PASSWORD" \
|
||
|
-e MYSQL_DATABASE=titles \
|
||
|
-p "$DB_PORT":3306 \
|
||
|
docker.io/mysql && echo "Database container '$DB_CONTAINER_NAME' was successfully created"
|