Update install.sh - added Daemon access check

Added Docker daemon access check, updated output with colorized ERROR, OK, and NOTICE flags for readability.
This commit is contained in:
ShockDW 2020-12-13 15:04:02 -06:00 committed by GitHub
parent e1390633ff
commit 4a23b615fc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -11,18 +11,36 @@
# * Modifies docker-compose.yml rather than relying on a static alternative file to hopefully # * Modifies docker-compose.yml rather than relying on a static alternative file to hopefully
# avoid the need for parallel maintenance of two files. # avoid the need for parallel maintenance of two files.
############################################################################################# #############################################################################################
ERROR="[\e[31mERROR\e[0m]"
OK="[\e[32mOK\e[0m]"
NOTICE="[\e[33mNOTICE\e[0m]"
echo "Welcome to Szurubooru. This install script will ask you to" echo 'Welcome to Szurubooru. This install script will ask you to set a few basic'\
echo "set a few config values, then get szurubooru up and running." 'config values, then get szurubooru up and running.'
# Check to ensure Docker and Docker-Compose are both installed before proceeding echo "Checking a few things to ensure successful deployment..."
# Check to ensure Docker and Docker-Compose are both installed and usable via standard commands
if ! command -v docker &> /dev/null || ! command -v docker-compose &> /dev/null; then if ! command -v docker &> /dev/null || ! command -v docker-compose &> /dev/null; then
echo "Both Docker and Docker-Compose must already be installed to use this script." echo -e "${ERROR} Both Docker and Docker-Compose must already be installed to use this script."
echo "Please ensure both are installed and accessible using commands 'docker' and 'docker-compose', then run this script again." echo " Please ensure both are installed and available using commands docker and"
echo " docker-compose, then run this script again."
exit 1 exit 1
else echo "Docker and Docker-Compose verified. Continuing installation..." else echo -e "${OK} Docker and Docker-Compose Installation verified"
fi fi
# Check to ensure the current user can access the Docker daemon
# https://github.com/rr-/szurubooru/pull/366#discussion_r541795141
if [[ "$(docker ps &> /dev/null | echo $?)" > 0 ]]; then
echo -e "${ERROR} Unable to verify Docker daemon access! Please ensure the current user is"
echo " authorized for Docker access."
echo " For more info, see the official Docker documentation at"
echo " https://docs.docker.com/engine/install/linux-postinstall/#manage-docker-as-a-non-root-user"
exit 1
else echo "${OK} Docker Daemon accessible."
fi
######################################################################################## ########################################################################################
# Check CPU architectue and, if ARM (such as Raspberry Pi), modify docker-compose.yml # Check CPU architectue and, if ARM (such as Raspberry Pi), modify docker-compose.yml
# https://github.com/rr-/szurubooru/wiki/ARM-and-Raspberry-Pi-Support-for-Docker-builds # https://github.com/rr-/szurubooru/wiki/ARM-and-Raspberry-Pi-Support-for-Docker-builds
@ -30,7 +48,7 @@ fi
######################################################################################## ########################################################################################
if [[ "$(uname -m)" == 'a'* ]]; then if [[ "$(uname -m)" == 'a'* ]]; then
echo "ARM architecture detected. Modfying docker-compose.yml for local build." echo -e "${NOTICE} ARM architecture detected. Modfying docker-compose.yml for local build."
# Modify docker-compose file to build locally instead of pulling from dockerhub # Modify docker-compose file to build locally instead of pulling from dockerhub
sed -zi "s|image: szurubooru/server:latest|build:\n context: ./server|; \ sed -zi "s|image: szurubooru/server:latest|build:\n context: ./server|; \
s|image: szurubooru/client:latest|build:\n context: ./client|" ./docker-compose.yml s|image: szurubooru/client:latest|build:\n context: ./client|" ./docker-compose.yml
@ -73,8 +91,8 @@ function server_config () {
s|pass: |pass: $SMTP_PASS|; \ s|pass: |pass: $SMTP_PASS|; \
s|from: |from: $SMTP_FROM|" ./server/config.yaml s|from: |from: $SMTP_FROM|" ./server/config.yaml
else # Warn user that they should set a contact email if no smtp host is specified else # Warn user that they should set a contact email if no smtp host is specified
echo "WARNING: No SMTP host specified!" echo -e "${NOTICE} No SMTP host specified! It is strongly recommended you set a contact email"
echo "It is recommended you set a contact email in the next prompt for manual password reset requests." echo " in the next prompt for manual password reset requests."
fi fi
echo "Enter your server's primary contact email address." echo "Enter your server's primary contact email address."