2021-08-26 02:47:56 +00:00
|
|
|
|
#!/bin/sh
|
|
|
|
|
|
2022-06-10 23:30:33 +00:00
|
|
|
|
# Check if config exists taking one from image if needed.
|
2022-03-02 13:28:36 +00:00
|
|
|
|
if [ ! "$(ls -A --ignore=.gitkeep ./app/config)" ]; then
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[33m🏗️ Config not found, pulling defaults..."
|
2022-03-07 01:51:25 +00:00
|
|
|
|
mkdir ./app/config/ 2> /dev/null
|
2021-08-26 02:47:56 +00:00
|
|
|
|
cp -r ./app/config_original/* ./app/config/
|
2022-06-10 23:30:33 +00:00
|
|
|
|
|
|
|
|
|
if [ $(id -u) -eq 0 ]; then
|
|
|
|
|
# We're running as root;
|
|
|
|
|
# Look for files & dirs that require group permissions to be fixed
|
|
|
|
|
# This will do the full /crafty dir, so will take a miniute.
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[35m📋 Looking for problem bind mount permissions globally..."
|
2022-06-10 23:30:33 +00:00
|
|
|
|
find . ! -group root -exec chgrp root {} \;
|
|
|
|
|
find . ! -perm g+rw -exec chmod g+rw {} \;
|
|
|
|
|
find . -type d ! -perm g+s -exec chmod g+s {} \;
|
|
|
|
|
fi
|
2022-06-16 15:45:08 +00:00
|
|
|
|
else
|
|
|
|
|
# Keep version file up to date with image
|
|
|
|
|
cp -f ./app/config_original/version.json ./app/config/version.json
|
|
|
|
|
|
|
|
|
|
# Compare if user's config is different from image, and show differences.
|
|
|
|
|
echo "\033[36mWrapper | \033[35m🏗️ Checking for config.json changes..."
|
|
|
|
|
cp -f ./app/config_original/config.json ./app/config/config_image_template
|
|
|
|
|
if [ "$(diff -q ./app/config/config.json ./app/config/config_image_template)" ]; then
|
|
|
|
|
echo "\033[36mWrapper | \033[33m👷 We've found differences in your local config, please review!,"
|
|
|
|
|
echo "\033[36m | \033[33m (This could be an outdated config.json)"
|
|
|
|
|
else
|
|
|
|
|
echo "\033[36mWrapper | \033[32m✅ Config good! Proceeding..."
|
|
|
|
|
fi
|
2021-08-26 02:47:56 +00:00
|
|
|
|
fi
|
|
|
|
|
|
2022-03-07 01:51:25 +00:00
|
|
|
|
|
|
|
|
|
if [ $(id -u) -eq 0 ]; then
|
2022-06-10 23:30:33 +00:00
|
|
|
|
# We're running as root
|
2022-03-07 01:51:25 +00:00
|
|
|
|
|
2022-06-10 23:30:33 +00:00
|
|
|
|
# If we find files in import directory, we need to ensure all dirs are owned by the root group,
|
|
|
|
|
# This fixes bind mounts that may have incorrect perms.
|
2022-06-11 00:43:02 +00:00
|
|
|
|
if [ "$(ls -A --ignore=.gitkeep ./import)" ]; then
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[35m📋 Files present in import directory, checking/fixing permissions..."
|
|
|
|
|
echo "\033[36mWrapper | \033[33m⏳ Please be paitent for larger servers..."
|
2022-06-10 23:30:33 +00:00
|
|
|
|
find . ! -group root -exec chgrp root {} \;
|
|
|
|
|
find . ! -perm g+rw -exec chmod g+rw {} \;
|
|
|
|
|
find . -type d ! -perm g+s -exec chmod g+s {} \;
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[32m✅ Permissions Fixed! (This will happen every boot until /import is empty!)"
|
2022-06-10 23:30:33 +00:00
|
|
|
|
fi
|
2022-03-07 01:51:25 +00:00
|
|
|
|
|
|
|
|
|
# Switch user, activate our prepared venv and lauch crafty
|
|
|
|
|
args="$@"
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[32m🚀 Launching crafty with [\033[34m$args\033[32m]"
|
2022-03-07 01:51:25 +00:00
|
|
|
|
exec sudo -u crafty bash -c "source ./.venv/bin/activate && exec python3 main.py $args"
|
|
|
|
|
else
|
|
|
|
|
# Activate our prepared venv
|
2022-06-16 15:45:08 +00:00
|
|
|
|
echo "\033[36mWrapper | \033[32m🚀 Non-root host detected, using normal exec"
|
2022-03-07 01:51:25 +00:00
|
|
|
|
. ./.venv/bin/activate
|
|
|
|
|
# Use exec as our perms are already correct
|
|
|
|
|
# This is likely if using Kubernetes/OpenShift etc
|
|
|
|
|
exec python3 main.py $@
|
|
|
|
|
fi
|