crafty-4/docker_launcher.sh

47 lines
1.9 KiB
Bash
Raw Normal View History

2021-08-26 03:47:56 +01:00
#!/bin/sh
2022-06-10 23:30:33 +00:00
# Check if config exists taking one from image if needed.
if [ ! "$(ls -A --ignore=.gitkeep ./app/config)" ]; then
2022-06-10 23:30:33 +00:00
echo "Wrapper | 🏗️ Config not found, pulling defaults..."
2022-03-07 01:51:25 +00:00
mkdir ./app/config/ 2> /dev/null
2021-08-26 03:47:56 +01: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.
echo "Wrapper | 📋 Looking for problem bind mount permissions globally..."
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
2021-08-26 03:47:56 +01: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.
if [ "$(ls -A --ignore=.gitkeep ./import)" ]; then
2022-06-10 23:30:33 +00:00
echo "Wrapper | 📋 Files present in import, checking/fixing permissions..."
echo "Wrapper | ⏳ Please be paitent for larger servers..."
find . ! -group root -exec chgrp root {} \;
find . ! -perm g+rw -exec chmod g+rw {} \;
find . -type d ! -perm g+s -exec chmod g+s {} \;
echo "Wrapper | ✅ Permissions Fixed! (This will happen every boot until /import is empty!)"
fi
2022-03-07 01:51:25 +00:00
# Switch user, activate our prepared venv and lauch crafty
args="$@"
2022-06-10 23:30:33 +00:00
echo "Wrapper | 🚀 Launching crafty with [$args]"
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-10 23:30:33 +00:00
echo "Wrapper | 🚀 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